## Learning Goals for Computer Organization II

| Main theme    | Prerequisites                                                                                                  | Approaching Learning<br>Goals                                                                                                                                                                                                                                                                                                                                                                                               | Reaches Learning Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Deepens Learning Goals                                                                                                                                                                                                                                                                         |
|---------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Digital logic | <ul> <li>Knows the<br/>concepts Boolean<br/>variable and truth<br/>value (Discrete<br/>mathematics)</li> </ul> | <ul> <li>Can explain Boolean<br/>algebra operations, truth<br/>tables, assumptions and<br/>identities</li> <li>Knows the basic gates<br/>and can explain the basic<br/>ideas and ways to<br/>describe combination<br/>and sequential circuits</li> <li>Can explain the<br/>implementation of<br/>selection and (de)coding<br/>circuits</li> <li>Can explain the basic<br/>idea of storing data with<br/>circuits</li> </ul> | <ul> <li>Can us a functionally complete set<br/>of gates to implement gates<br/>missing from it</li> <li>Can implement a given logical<br/>function with combinational circuits<br/>and optimize it with Karnaugh<br/>maps</li> <li>Can explain roughly the<br/>combinatorial circuit<br/>implementation of addition and<br/>ROM-memory circuits</li> <li>Can explain the operation and<br/>differences of various clocked flip-<br/>flops, as well as the<br/>implementation of registers, shift<br/>registers, and counters with flip-<br/>flops</li> </ul> | <ul> <li>Can explain the Quine-McKluskey or Lugue methods to simplify combinational circuits</li> <li>Can explain precisely the combinatorial circuit implementation of addition and ROM-memory circuits</li> <li>Can consider timing and voltage problems in implementing circuits</li> </ul> |

| Main theme    | Prerequisites                                                                                                                                                                                                                   | Approaching Learning<br>Goals                                                                                                                                                                                      | Reaches Learning Goals                                                                                                                                                                                                | Deepens Learning Goals                                                             |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| Bus operation | <ul> <li>Can explain the need and operation of bus hierarchy (CO-I)</li> <li>Can explain how CPU operates to execute instructions (CO-I)</li> <li>Knows the huge speed differences for various memory devices (CO-I)</li> </ul> | <ul> <li>Can explain the usage of various buses in the system</li> <li>Can explain the basic features of time-interleaved bus</li> <li>can explain different bus timing schemes and data transfer types</li> </ul> | <ul> <li>Knows differences of various<br/>arbitration methods and their<br/>signal level implementation</li> <li>Can explain at the signal and bus<br/>event level operation for at least<br/>one bus type</li> </ul> | <ul> <li>Can explain the signal level operation of the latest bus types</li> </ul> |

| Main theme       | Prerequisites                                                                                                                                                                                                                                                    | Approaching Learning<br>Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Reaches Learning Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Deepens Learning Goals                                                                                                                                                                                                                                                 |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory hierarchy | <ul> <li>Can explain the huge speed differences of various memory devices, as well the significance of them (CO-I)</li> <li>Can explain why cache memory if needed (CO-I)</li> <li>Know the basic ideas of cache and virtual memory operations (CO-I)</li> </ul> | <ul> <li>Can explain the effect of temporal and spatial locality at various memory hierarchy levels</li> <li>Can explain the memory implementation at combination circuit level</li> <li>Can explain types and policies for various cache organization methods</li> <li>Can explain the operation of paged and segmented virtual memory</li> <li>Can explain inversed and multi-level virtual memory address translation concepts</li> <li>Can explain the requirements and basic features for TLB operation</li> </ul> | <ul> <li>Can explain he details for set-<br/>associative cache operation</li> <li>Can explain the need for using<br/>hierarchical cache memories with<br/>separate instruction and data<br/>caches</li> <li>Can explain the similarities and<br/>differences of TLB and cache</li> <li>Can explain the precise CPU<br/>operation as related to TLB and<br/>cache loops</li> <li>Can explain various replacement<br/>policies for cache memories</li> <li>Can estimate the memory<br/>reference time considering both<br/>virtual memory and cache effects</li> </ul> | <ul> <li>Can explain differences<br/>between Rambus DRAM<br/>and normal DRAM</li> <li>Can explain TLB and<br/>cache memory details for<br/>some certain CPUs</li> <li>Can explain various<br/>replacement policies for<br/>virtual memory back-up<br/>store</li> </ul> |

| Main theme       | Prerequisites                                                                                                                                                                                                                                                                                                     | Approaching Learning<br>Goals                                                                                                                                                                                                                                                  | Reaches Learning Goals                                                                                                                                                                                                                                       | Deepens Learning Goals                                                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Arithmetic       | <ul> <li>Can explain<br/>addition and<br/>multiplication<br/>algorithms with<br/>paper and pencil<br/>(CO-I)</li> <li>Can explain the<br/>IEEE floating<br/>point presentation<br/>(CO-I)</li> </ul>                                                                                                              | <ul> <li>Can explain integer basic<br/>arithmetic circuit level<br/>implementation</li> <li>Can explain IEEE floating<br/>point presentation for<br/>very large and very small<br/>numbers</li> <li>Can explain various<br/>methods for floating point<br/>rounding</li> </ul> | <ul> <li>Can explain the implementation of 2's complement addition and subtraction</li> <li>Can explain Booth's algorithm for multiplication</li> <li>Can explain the basics of IEEE floating point arithmetic implementation</li> </ul>                     | <ul> <li>Can explain precisely<br/>integer division<br/>implementation</li> <li>Can explain detailed<br/>implementation for IEEE<br/>arithmetic implementation</li> </ul>                             |
| Instruction sets | <ul> <li>Can explain how<br/>instruction<br/>execution cycle<br/>works and the<br/>differences<br/>between machine<br/>language and<br/>symbolic<br/>assembly<br/>language (CO-I)</li> <li>Can explain<br/>different data<br/>reference<br/>methods as well<br/>as different data<br/>locations (CO-I)</li> </ul> | <ul> <li>Can explain machine<br/>instruction components</li> <li>Can explain the meaning<br/>of registers</li> <li>Can explain various ways<br/>to store multi-byte data</li> <li>Can compare instruction<br/>sets based on their<br/>fundamental features</li> </ul>          | <ul> <li>Can classify instruction sets based<br/>on their features</li> <li>Can classify processors based on<br/>their instruction sets</li> <li>Can explain the structure and data<br/>reference methods for real<br/>processor instruction sets</li> </ul> | <ul> <li>Can give examples of<br/>Load-Store processors</li> <li>Can explain registers,<br/>data types and data<br/>reference methods for<br/>Intel Pentium and IBM<br/>PowerPC processors</li> </ul> |

| Main theme                           | Prerequisites                                                                                                                                                     | Approaching Learning<br>Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reaches Learning Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Deepens Learning Goals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Processor structure<br>and operation | <ul> <li>Can explain the basic idea of von Neumann processor architecture (CO-I)</li> <li>Can explain instruction fetch execute cycle operation (CO-I)</li> </ul> | <ul> <li>Can explain processor<br/>general structure at<br/>register and control unit<br/>level</li> <li>Can explain the basic<br/>idea of pipelining</li> <li>Can explained give<br/>examples on pipeline<br/>dependency problems</li> <li>Can explain the basic<br/>idea of RISC<br/>architecture, and its<br/>differences, advantages,<br/>and disadvantages as<br/>compared to CISC<br/>architecture</li> <li>Can explain the basic<br/>ideas of superscalar<br/>processor and give<br/>examples of new<br/>dependency problems it<br/>causes</li> <li>Can explain the basic<br/>idea of predicated<br/>execution</li> </ul> | <ul> <li>Can compute the speed<br/>advantage obtained with pipelining</li> <li>Can give solutions to problems<br/>caused by pipeline dependencies</li> <li>Can explain register window usage<br/>to speed up procedure calls</li> <li>Can explain register allocation<br/>problem solution with net-coloring<br/>problem</li> <li>Can explain how RISC and CISC<br/>architectures can be combined</li> <li>Can give solutions to problems<br/>caused by write- and anti-<br/>dependencies</li> <li>Can explain the ideas and<br/>operations of control speculation,<br/>and software pipelining</li> </ul> | <ul> <li>Can introduce special<br/>registers in Intel Pentium<br/>and IBM PowerPC and<br/>how they are used</li> <li>Can explain interrupt<br/>mechanisms for Intel<br/>Pentium and IBM<br/>PowerPC</li> <li>Can explain basic ideas of<br/>combining multiple<br/>processor architectures in<br/>Intel Pentium II and<br/>Transmeta Crusoe<br/>processors</li> <li>Can explain exact<br/>operation in executing<br/>multiple instructions<br/>simultaneously in IBM<br/>PowerPC and Intel IA-64<br/>processors</li> </ul> |

| Main theme | Prerequisites | Approaching Learning<br>Goals                                                                                                                                                                                                                                                      | Reaches Learning Goals                                                                                                                                                                                                                                                                                                                                                            | Deepens Learning Goals                                                                                                                                                    |
|------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Control    |               | <ul> <li>Can explain how control signals for instruction fetch-execute cycle are produces with a state automata</li> <li>Can explain the basic idea of micro-programmed control</li> <li>Can explain the function of control memory in micro-programmed control control</li> </ul> | <ul> <li>Can explain the operation of hard-wired and micro-programmed control</li> <li>Can explain how clock cycle length is determined</li> <li>Can explain the differences, advantages and disadvantages of horizontal and vertical micro-programming</li> <li>Can explain the advantages and disadvantages of various ways to select next micro-program instruction</li> </ul> | <ul> <li>Can explain, how modern processor combines micro-programmed and direct control</li> <li>Can explain precise implementation of some current processors</li> </ul> |