Forum Replies Created

Viewing 4 posts - 1 through 4 (of 4 total)
  • Author
    Posts
  • lookaside
    Participant
    Post count: 4

    That seems inefficient compared to a conventional register system. On the Mill, if my example code were implemented with pick, the code would be twice the size and always execute whether the condition was true or false (all for keeping track of previous arguments). A register system would just branch and execute the code or not. The mill makes up for this with parallelization but if a register system were equally parallel, it seems it would have better performance no?

  • lookaside
    Participant
    Post count: 4

    Yeah I had that solution too for cases as simple as my example. The problem is when you try to scale that to a larger conditional code block that could push several arguments on the belt. Another example:

    add b0, b1
    if(cond) {
    mult b0, b1
    div  b0, b1
    add  b0, b1
    sub  b0, b1
    xor  b0, b1
    and  b0, b1
    }

    That would either be turned into a branch or you could make each statement conditional with pick but that would increase code size, execution time, and could push a lot of useless stuff onto the belt just to keep indices consistent. Only other option I see would be to store anything important / send it to the spiller and restore them after the branch was executed but that’s still slow because latencies. 🙁

  • lookaside
    Participant
    Post count: 4

    I was attempting to write a few programs using this model but I ran into a problem I couldn’t solve. I might be overlooking something but I found that if you have an instruction that conditionally pushes something onto the belt, you can no longer know the indices of the other belt positions. For example…
    If you had this code:

    add b0, b1
    if(cond) {b0++}

    And you wanted to read the result from the addition, how do you know whether to read it from b0 or b1? I’m thinking you’d have to restore the result if the condition is true but that could potentially double code size…
    Hopefully there’s a simple solution.

  • lookaside
    Participant
    Post count: 4

    Missed the reply button. Responded to you below.

Viewing 4 posts - 1 through 4 (of 4 total)