Difference between revisions of "BITL MCU"
|  (→24.09.21) |  (→Calendar) | ||
| Line 9: | Line 9: | ||
| </big> | </big> | ||
| '''Course: Introduction to Processors''' | '''Course: Introduction to Processors''' | ||
| =Calendar= | =Calendar= | ||
| Line 36: | Line 37: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab :: Quiz 1'''</big> | ||
| |} | |} | ||
| ''' | '''Lab''' | ||
| Practicing the conversion between the counting systems | Practicing the conversion between the counting systems | ||
| '''Quiz 1''' | '''Quiz 1''' | ||
| Decimal, binary, octal and hexadecimal systems.  | Decimal, binary, octal and hexadecimal systems.  | ||
| | | | | ||
| * Assignment '''Lab_Binary''' | * Assignment '''Lab_Binary''' - Lab | ||
| |- style='vertical-align: top;' | |- style='vertical-align: top;' | ||
| | | | | ||
| ====21.09.21==== | ====21.09.21==== | ||
| 11:10 | 11:10 | ||
| Line 70: | Line 76: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab :: Quiz 2'''</big> | ||
| |} | |} | ||
| ''' | '''Lab''' | ||
| Exercises with the two's complement | Exercises with the two's complement | ||
| '''Quiz 2''' | '''Quiz 2''' | ||
| Two's complement. | Two's complement. | ||
| | | | | ||
| * Assignment '''Lab_Complement''' | * Assignment '''Lab_Complement''' - Lab | ||
| |- style='vertical-align: top;' | |- style='vertical-align: top;' | ||
| | | | | ||
| ====28.09.21==== | ====28.09.21==== | ||
| 11:10 | 11:10 | ||
| Line 104: | Line 115: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| Developing and testing a simple Assembly program.  Using cross-compilation tools. Introduction to the Make system. | |||
| Make system, using for compilation and testing | |||
| | | | | ||
| * Assignment '''Lab_Make''' | * Assignment '''Lab_Make''' - Lab | ||
| Line 131: | Line 142: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| Advanced features of the Make system. | |||
| TBD | |||
| | | | | ||
| * Assignment ''' | * Assignment '''Lab_Make_2''' - Lab | ||
| Line 158: | Line 169: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| Evaluating and following the code "on paper". | |||
| TBD | |||
| | | | | ||
| * Assignment ''' | * Assignment '''Lab_Dry_Run''' - Lab | ||
| Line 185: | Line 196: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab :: Quiz 3'''</big> | ||
| |} | |} | ||
| '''Lab''' | |||
| TBD | |||
| Debugging Assembly programs. Gnu debugger gdb. | |||
| '''Quiz 3''' | |||
| Code comprehension. | |||
| | | | | ||
| * Assignment ''' | * Assignment '''Lab_Debug''' - Lab | ||
| * '''Due''' '''HW1''' - Arithmetic progression | * '''Due''' '''HW1''' - Arithmetic progression | ||
| Line 213: | Line 236: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| TBD | TBD | ||
| | | | | ||
| * Assignment '''Lab_TBD''' | * Assignment '''Lab_TBD''' - Lab | ||
| Line 240: | Line 263: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| TBD | TBD | ||
| | | | | ||
| * Assignment '''Lab_TBD''' | * Assignment '''Lab_TBD''' - Lab | ||
| * '''Due''' '''HW2''' - Matrix multiplication | * '''Due''' '''HW2''' - Matrix multiplication | ||
| Line 300: | Line 323: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| TBD | TBD | ||
| | | | | ||
| * Assignment '''Lab_TBD''' | * Assignment '''Lab_TBD''' - Lab | ||
| Line 340: | Line 363: | ||
| | | | | ||
| {| width='100%' style='background-color:#ddd;' | {| width='100%' style='background-color:#ddd;' | ||
| |<big>''' | |<big>'''Lab'''</big> | ||
| |} | |} | ||
| Review of the course topics | Review of the course topics | ||
| | | | | ||
| * Assignment '''Lab_Summary''' | * Assignment '''Lab_Summary''' - Lab | ||
| * '''Due By midnight''' '''Proj''' - Project | * '''Due By midnight''' '''Proj''' - Project | ||
| Line 363: | Line 386: | ||
| |- style='vertical-align: top;' | |- style='vertical-align: top;' | ||
| | | | | ||
| ==== | ====13-22.12.21==== | ||
| | | | | ||
Revision as of 22:48, 1 October 2021
Shortcuts: Calendar | Assignments | Resources | Today (if there is a class) Course: Introduction to Processors
Calendar
| Date | Topic, content | Deliverables | |
|---|---|---|---|
| 14.09.2111:10 | 
 Representation of non-negative numbers in hardware, registers and memory. Decimal, binary, octal, and hexadecimal systems. Converting between the systems. | 
 | |
| 17.09.2111:10 | 
 Lab Practicing the conversion between the counting systems 
 
 Decimal, binary, octal and hexadecimal systems. 
 
 | 
 
 | |
| 21.09.2111:10 | 
 Representing negative numbers in hardware. Register size, and why it is important. Methods for encoding negative numbers: packed, signed, bias, one's complement and two's complement. Converting between the value and two's complement in binary and hexadecimal systems. | 
 | |
| 24.09.2111:10 | 
 Lab Exercises with the two's complement 
 
 Two's complement. 
 
 | 
 
 | |
| 28.09.2111:10 | 
 Architecture of a processor. Registers, register file, ALU, datapath. CISC vs. RISC architectures. x86 architecture as CISC representative. ARM architecture as RISC. Instruction encoding. | 
 | |
| 01.10.2111:10 | 
 Developing and testing a simple Assembly program. Using cross-compilation tools. Introduction to the Make system. | 
 
 | |
| 05.10.2111:10 | 
 Environment and tools for compiling and debugging Assembly programs. Compiler, preprocessor, assembly, linker, loader, debugger. Cross-compilation and toolchains. Emulators and virtual machines. | 
 | |
| 08.10.2111:10 | 
 Advanced features of the Make system. | 
 
 | |
| 12.10.2111:10 | 
 Introduction to ARM Assembly language and programming. Instruction types. Arithmetic instructions. MOV, ADD, SUB. MVN, ADC, SBC, RSB, RSC. Barrel Shifter. | 
 | |
| 15.10.2111:10 | 
 Evaluating and following the code "on paper". | 
 
 | |
| 19.10.2111:10 | 
 Flow control in Assembly. Branch instructions. B, BL, BX, BLX. Working directly with PC register. CPSR flags. Condition field. Bit operations. AND, ORR, EOR, BIC, shift and rotation. CMP, CMN, TST, TEQ. Fast flags and the S postfix. | 
 | |
| 22.10.2111:10 | 
 Lab Debugging Assembly programs. Gnu debugger gdb. 
 
 Code comprehension. 
 
 | 
 
 | |
| 26.10.2111:10 | 
 Reading and writing data to memory. Memory access instructions. STR, LDR, STRB, STRH, LDRB, LDRH, LDRSB, LDRSH. Addressing modes: offset, pre-indexed and post-indexed. Using barrel shifter with addressing. Data alignment in memory. | 
 | |
| 29.10.2111:10 | 
 TBD | 
 
 | |
| 02.11.2111:10 | 
 Variable types in C: static, automatic and dynamic. Calling subroutines and parameter passing conventions. Parameters and return value. Stack and registers. Saving the registers, the context. Loading and storing multiple registers: LDM, STM. Interfacing between Assembly and C. | 
 | |
| 05.11.2111:10 | 
 TBD | 
 
 | |
| 09.11.2111:10 | 
 Symbol encoding in hardware and software. Code tables. ASCII. EBCDIC. ISO code tables. Foreign letter symbols. UTF-8, UTF-16. Strings in C and memory. Converting values to symbols and strings. | 
 | |
| 12.11.2111:10 | 
 Data representation in memory. Assembly code comprehension. Two programming tasks. 
 | 
 
 | |
| 16.11.2111:10 | 
 Expressions in Assembly. Operators in expressions. Constants. Assigning values to symbols. Directives: .set, .equiv, .eqv. Conditional compilation. Directives .if, .ifdef, .endif., ifb, .ifc, .ifeqs. More conditionals .ifeq, .ifge, .ifne and others. Macro commands: .macro, .endm., .rept. Recursive macros. Local macros. Macros across sections. | 
 
 | |
| 23.11.2111:10 | 
 TBD | 
 
 | |
| 26.11.2111:10 | 
 Including Assembly in C code. Inline code and Assembly code operands. Tasks for the compiler, linker and loader. Dynamic loaders and libraries. | 
 | |
| 30.11.2111:10 | 
 Execution time for instructions. Case study for code optimization. Leveraging the documentation and specification of instructions. Reordering the code. Unrolling loops. Taking advantage of branch prediction. Cache memory and the code performance. | 
 | |
| 03.12.2111:10 | 
 Review of the course topics | 
 
 | |
| 13-22.12.2021 | 
 Time for exams | 
 | |
| 13-22.12.21 | 
 Data representation in memory. Assembly code comprehension. Multiple choice questions and a programming task. 
 | 
 
 | 
