







































## Full/Empty bit

- Tag on data indicates data presence
  - E.g. tag in memory, RF
  - Like Scoreboard present bit
- When computation allocated, set to empty
  - E.g. operation issued into pipe, future call made
- When computation completes
  - Future computation completes
  - Data written into slot (register, memory)
  - Bit set to full
- On data access
  - Bit full, strict operation can get value
- CALTECH cs184c Bit empty strict operation block on completion























## Scheduling Hierarchy

- Intra-frame
  - Related threads in same frame
  - Frame runs on single processor
  - Schedule together, exploit locality
    - (cache, maybe regs)
- Inter-frame
  - Only swap when exhaust work in current frame

CALTECH cs184c Spring2001 -- DeHon























## **Big Ideas**

- Primitives
  - Parallel Assembly Language
  - Threads for control
  - Synchronization (post, full-empty)
- Latency Hiding
  - Threads, split-phase operation
- Exploit Locality
  - Create locality
    - Scheduling quanta

CALTECH cs184c Spring2001 -- DeHon