## Learning Goals for Computer Organization II

| Main theme       | Prerequisites                                                                       | Approaching Learning Goals                                                                                                                                                                                       | Reaches Learning Goals                                                                                      | Deepens Learning Goals                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Digital logic    | Knows the concepts<br>Boolean variable and<br>truth value (Discrete<br>mathematics) | Can explain computer operation at electrical component (gates, circuits, flip-flops) level.                                                                                                                      | Can implement a given logical function<br>with combinational circuits and optimize<br>it with Karnaugh maps | Can explain the Quine-<br>McKluskey or Lugue methods<br>to simplify combinational<br>circuits<br>Can explain the combinatorial<br>circuit implementation of<br>addition and ROM-memory<br>circuits |
|                  |                                                                                     | Can build a truth table to describe circuit function.                                                                                                                                                            | Can explain the operation of clocked flip-<br>flops and the register implementation<br>with flip-flops      |                                                                                                                                                                                                    |
|                  |                                                                                     | Can describe basic functionality of flip-<br>flops.                                                                                                                                                              |                                                                                                             |                                                                                                                                                                                                    |
|                  |                                                                                     | Can list basic gates and explain the basic idea of how circuits fgunction and describe their use in data storage.                                                                                                |                                                                                                             | Can consider timing and voltage problems in implementing circuits                                                                                                                                  |
| Bus<br>operation | Can explain the need<br>and operation of bus<br>hierarchy (CO-I)                    | Can describe the meaning and function of one or multiple buses in component communication.                                                                                                                       | Can list the differences of arbitration methods and describe their signal level implementation.             | Can explain the signal level operation for the latest bus types.                                                                                                                                   |
|                  |                                                                                     | Can list and describe the central<br>concepts relating to buses (e.g., speed,<br>width, signaling, timing, synchronization,<br>arbitration) and their meaning in overall<br>system, using PCI bus as an example. | Can explain at the signal and bus event level operation for at least one bus type.                          |                                                                                                                                                                                                    |

| Main theme          | Prerequisites                                                                                                                                                                                                                                                     | Approaching Learning Goals                                                                                                                                                                                                                                                            | Reaches Learning Goals                                                                                                   | Deepens Learning Goals                                                                                                                                    |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory              | Can explain the huge<br>speed differences of<br>various memory<br>devices, as well the<br>significance of them<br>(CO-I).<br>Can explain why cache<br>memory is needed<br>(CO-I).<br>Know the basic ideas<br>of cache and virtual<br>memory operations<br>(CO-I). | Can explain memory reference actions when both cache and virtual memory are used.                                                                                                                                                                                                     | Can explain the need for and implemen-<br>tation of cache memory hierarchy with<br>separate instruction and data caches. | Can explain differences<br>between Rambus DRAM and<br>normal DRAM.                                                                                        |
|                     |                                                                                                                                                                                                                                                                   | Can list and describe cache organization<br>methods, their types and policies<br>governing them.<br>Can explain address translation in (multi-<br>level) virtual memory, possibly using<br>inverted page table.<br>Can list the requirements and basic<br>features for TLB operation. | Can explain the details of set-associative cache operation.                                                              | Can explain TLB and cache<br>memory details for some<br>certain CPUs.<br>Can explain various<br>replacement policies for virtual<br>memory back-up store. |
|                     |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                       | Can explain with details how TLB ope-<br>rates, including its replacement policies.                                      |                                                                                                                                                           |
|                     |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                       | Can explain the similarities and differences of TLB and cache.                                                           |                                                                                                                                                           |
|                     |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                       | Can estimate the memory reference time considering both virtual memory and cache effects.                                |                                                                                                                                                           |
| Arithmetic          | Can explain addition<br>and multiplication<br>algorithms with paper<br>and pencil (high                                                                                                                                                                           | Can explain integer basic arithmetic circuit level implementation.                                                                                                                                                                                                                    | Can explain the implementation of 2's complement addition and subtraction.                                               | Can explain precisely integer division implementation                                                                                                     |
|                     |                                                                                                                                                                                                                                                                   | Can explain Booth's algorithm.<br>Can explain IEEE floating point<br>presentation for very large and very small<br>numbers.                                                                                                                                                           | Can apply Booth's algorithm for multiplication.                                                                          | Can explain detailed<br>implementation for IEEE<br>arithmetic implementation.                                                                             |
|                     | Can explain the IEEE<br>floating point<br>presentation (CO-I).                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                       | Can explain the basics of IEEE floating point arithmetic implementation.                                                 |                                                                                                                                                           |
|                     |                                                                                                                                                                                                                                                                   | Can list and describe floating point rounding methods.                                                                                                                                                                                                                                |                                                                                                                          |                                                                                                                                                           |
| Instruction<br>sets | Can explain instruction<br>execution cycle and the<br>differences between<br>machine and symbolic<br>assembly language<br>(CO-I).                                                                                                                                 | Can describe and compare instruction<br>sets based on their fundamental features<br>Can explain machine instruction<br>components, meaning of registers, and<br>ways to store multi-byte data.                                                                                        | Can classify instruction based on their features and processors based on their                                           | Can give examples of Load-<br>Store processors.                                                                                                           |
|                     |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                       | Instruction sets.<br>Can explain the structure and data                                                                  | Can explain registers, data<br>types and data reference<br>methods for Intel Pentium and<br>Arm 11 processors.                                            |
|                     |                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                       | reference methods for real instruction sets (e.g., Intel Pentium and ARM11).                                             |                                                                                                                                                           |
|                     | Can explain different<br>data reference<br>methods and where<br>data can locate (CO-I).                                                                                                                                                                           |                                                                                                                                                                                                                                                                                       |                                                                                                                          |                                                                                                                                                           |

| Main theme                              | Prerequisites                                                                                                                                          | Approaching Learning Goals                                                                                                                                                                                                                                                                                                                 | Reaches Learning Goals                                                                                                                                                                                                                                                                                                                            | Deepens Learning Goals                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Processor<br>structure and<br>operation | Can explain the basic<br>idea of von Neumann<br>processor architecture<br>(CO-I)<br>Can explain instruction<br>fetch execute cycle<br>operation (CO-I) | Can explain processor general structure<br>at register and control unit level.<br>Can explain the basic idea of pipelining<br>and superscalar processor and give<br>examples of their dependency problems.<br>Can compare RISC and CISC<br>architectures.                                                                                  | Can compute the speed advantage<br>obtained with pipelining<br>Can give solutions to problems caused<br>by structural, control and data pipeline<br>dependencies.<br>Can explain how RISC and CISC<br>architectures can be combined                                                                                                               | Can explain special registers<br>and interrupt mechanisms in<br>Intel Pentium and ARM11.<br>Can explain basic ideas of<br>combining multiple processor<br>architectures in Intel Pentium II<br>and Transmeta Crusoe<br>processors.<br>Can explain exact operation in<br>executing multiple instructions<br>simultaneously in IBM<br>PowerPC and Intel IA-64<br>processors |
| Control                                 |                                                                                                                                                        | Can explain machine language execution<br>at micro-programmed control level.<br>Can explain how control signals for<br>instruction fetch-execute cycle are<br>produced with a state automata.<br>Can explain the basic idea of micro-<br>programmed control.<br>Can explain the function of control<br>memory in micro-programmed control. | Can explain hard-wired and micro-<br>programmed control.<br>Can explain how clock cycle length is<br>determined.<br>Can explain the differences, advantages<br>and disadvantages of horizontal and<br>vertical micro-programming.<br>Can explain the advantages and<br>disadvantages of various ways to select<br>next micro-program instruction. | Can explain, how modern<br>processor combines micro-<br>programmed and direct control.<br>Can explain precise implemen-<br>tation of some current<br>processors.                                                                                                                                                                                                          |