## ELEC2142 Embedded Systems Design Course Outline - Semester 2, 2015 **Never Stand Still** Faculty of Engineering School of Electrical Engineering and Telecommunications ### **Course Staff** Course Convener: Dr. Chamith Wijenayake, Room 206, c.wijenayake@unsw.edu.au Tutors: Dr. Chamith Wijenayake Dr. Joon Wayn Cheong, cjwayn@unsw.edu.au Laboratory Contact: Hugh Braico, <a href="https://hugh.braico@gmail.com">hugh.braico@gmail.com</a> **Consultations:** You are encouraged to ask questions on the course material, after the lecture class times in the first instance, rather than via email. Lecturer consultation time for this course will be on every Friday 4-5 pm. You are welcome to email the tutor or laboratory demonstrator, who can answer your questions on this course and can also provide you with consultation times. ALL email enquiries should be made from your student email address with ELEC2142 in the subject line, otherwise they will not be answered. **Keeping Informed:** Announcements may be made during classes, via email (to your student email address) and/or via online learning and teaching platforms – in this course, we will use Moodle <a href="https://moodle.telt.unsw.edu.au/login/index.php">https://moodle.telt.unsw.edu.au/login/index.php</a>. Please note that you will be deemed to have received this information, so you should take careful note of all announcements. ## **Course Summary** #### **Contact Hours** The course consists of 3 hours of lectures, a 1-hour tutorial, and a 2-hour laboratory session each week. Tutorials will start in week 2 and laboratory sessions will start in week 4. | Lectures | Day | Time | Location | |--------------|-----------|---------------|-------------| | | Monday | 10am – 12noon | Colombo ThA | | | Tuesday | 1pm – 2pm | Ritchie Th | | | | | | | Tutorials | Tuesday | 5pm – 6pm | CivEng G8 | | | Wednesday | 4pm – 5pm | CivEng G8 | | | Thursday | 1pm - 2pm | Quad G035 | | | Thursday | 4pm - 5pm | Quad G032 | | Laboratories | Monday | 1pm – 3pm | ElecEng233 | | | Monday | 3pm – 5pm | ElecEng233 | | | Tuesday | 9am – 11am | ElecEng233 | | | Tuesday | 11am – 1pm | ElecEng233 | | | Wednesday | 1pm – 3pm | ElecEng233 | | | Thursday | 9am – 11am | ElecEng233 | | | Thursday | 11am – 1pm | ElecEng233 | | | Friday | 9am – 11am | ElecEng233 | | | Friday | 1pm – 3pm | ElecEng233 | | Consultation | Friday | 4pm – 5pm | EE Room 206 | #### **Context and Aims** Embedded systems are pervasive in all areas of society, and as such, knowledge of how to design them is a vital skill for all electrical engineers. The objective of this course is to equip students with the necessary fundamental knowledge and skill that enable them to understand, analyse and design basic embedded systems, where a microprocessor or microcontroller is the central element. The first half of the course will focus on ARM architecture, instruction sets, assembly fundamentals and techniques. Input and output, floating point representation, interrupts, exceptions, caches and virtual memory will be covered in the second half of the course. At the completion of the course, students should be in a position to be able to design reliable embedded system using ARM processors in particular and other processors in general. The course aims to provide students with fundamental knowledge of embedded systems with respect to several different levels of abstraction, from a low level dealing with hardware interaction and driving the processor via assembly language, through to high level software design, multitasking, and programming with the C language, plus much in the middle. #### **Indicative Lecture Schedule** | Period | Summary of Lecture Program | | | | |---------|-------------------------------------------------------------------|--|--|--| | Week 1 | ARM programmer's Model, assembly programming examples, directives | | | | | Week 2 | Data processing | | | | | Week 3 | Memory Access | | | | | Week 4 | Control Flow | | | | | Week 5 | Functions, pointers and Arrays | | | | | Week 6 | Constants and Literal pools, pseudo-instructions | | | | | Week 7 | Input and Output, Memory Mapped Peripherals | | | | | Week 8 | Instructions Encoding/Decoding | | | | | Week 9 | Mid-session exam (material up to end of week 6) | | | | | | Break | | | | | Week 10 | Exception handling | | | | | Week 11 | Fixed and Floating point numbers | | | | | Week 12 | Caches and virtual memory | | | | #### **Indicative Laboratory Schedule** | Period | Summary of Laboratory Program | | |--------|-------------------------------------------------------------|--| | Week 4 | Introduction to the QVGA Base Board, µVision, and Debugging | | | Week 5 | Data Types, Control Flow, Assembly Programming | | | Week 6 | Functions | | | Week 7 | Inputs and Outputs | | | Week 8 | Digital to Analog Conversion | | | Week 9 | LCD and Touchscreen | | | Break | | | | Week 10 | LCD and Touchscreen - continue | |---------|--------------------------------| | Week 11 | Interrupts part I | | Week 12 | Interrupts Part II | | Week 13 | Interrupts Part II - continue | #### Assessment | Laboratory Practical Experiments | 30% (+5% bonus) | |----------------------------------|-----------------| | Fortnightly quizzes | 5% | | Mid-Semester Exam | 15% | | Final Exam (3 hours) | 50% | #### **Course Details** #### **Credits** This is a 6 UoC course and the expected workload is 10–12 hours per week throughout the 13 week semester. #### **Relationship to Other Courses** This is a 2<sup>nd</sup> year course in the School of Electrical Engineering and Telecommunications. It is a core subject for students following a BE (Electrical) or (Telecommunications) program. #### Pre-requisites and Assumed Knowledge The pre-requisite for this course is ELEC2141: Digital Circuit Design and COMP1911/COMP1921: Computing 1A/1B. The fundamental knowledge for this course is based on the aforementioned pre-requisites. The students should have a good understanding, in particular, on number systems, C programming and basic computer architecture. #### **Following Courses** The course is a pre-requisite for TELE3118: Network technologies and ELEC4601: Advanced Digital and Embedded Systems Design in which the embedded systems design concepts that will be introduced in this course and digital design principles from ELEC2141 will be applied extensively.. #### Learning outcomes After successful completion of this course, you should be able to: - 1. Demonstrate an understanding of what an embedded system is, and what its main components are. - 2. Demonstrate competency in working with and manipulating number systems. - 3. Demonstrate the fundamentals of assembly language programming. - 4. Demonstrate a competency in using the C programming language for embedded applications. - 5. Demonstrate the principles of "good" software design. - 6. Demonstrate an understanding of how CPU operates, in particular the ARM processor. - 7. Demonstrate an understanding of the principles in converting high level code to low level instructions. 8. Use a mix of C and assembly to design simple embedded systems which involve the use of interrupts, multitasking, and I/O. This course is designed to provide the above learning outcomes which arise from targeted graduate capabilities listed in *Appendix A*. The targeted graduate capabilities broadly support the UNSW and Faculty of Engineering graduate capabilities (listed in *Appendix B*). This course also addresses the Engineers Australia (National Accreditation Body) Stage I competency standard as outlined in *Appendix C*. #### **Syllabus** C syntax, pointers, pointer arithmetic, memory allocation, arrays, C operators. Binary numbers, hexadecimal numbers, signed and unsigned numbers, 2s complement, status flags, ASCII. Programmer's model of a microprocessor, registers, fetch-decode-execute cycle, instruction set. Assembly design, assembly variables, data processing instructions, arithmetic operations, logical operations. Memory access instructions, word and byte addressing, memory alignment, block data transfer. Control flow, conditional branches, loops, jump tables. Functions, link register, stack, stack frames, register conventions. Fractions, fixed-point numbers, fractions multiplication and division. Floating-point numbers, range and precision, IEEE 754 standard, number distribution, zero- infinity- and NaN-representation. Instructions format, instructions encoding/decoding. Compiler, assembler, linker, loader, assembler directives, pseudo-instructions, object files, relocation tables. Input/output, memory mapped I/O, polling, interrupts. Exceptions, software interrupts, traps, modes of operation, user mode and privileged mode, vector table. Memory hierarchy, cache, direct-mapped cache, associative cache, block replacement policy. Virtual memory, segmentation, page table. ## **Teaching Strategies** #### **Delivery Mode** The teaching in this course aims at establishing a good fundamental understanding of the areas covered using: - Formal face-to-face lectures, which provide you with a focus on the core analytical material in the course, together with qualitative, alternative explanations to aid your understanding; - Tutorials, which allow for exercises in problem solving and allow time for you to resolve problems in understanding of lecture material; - Laboratory sessions, which support the formal lecture material and also provide you with practical construction, measurement and debugging skills; - Fortnight online quiz, which is based on the lecture materials covered in the previous fortnight and keeps you up to date with the lecture material. #### Learning in this course You are expected to attend <u>all</u> lectures, tutorials, labs, and mid-semester exams in order to maximize learning. You must prepare well for your laboratory classes and your lab work will be assessed. In addition to the lecture notes/video, you should read relevant sections of the recommended text. Reading additional texts will further enhance your learning experience. Group learning is also encouraged. UNSW *assumes* that self-directed study of this kind is undertaken in addition to attending face-to-face classes throughout the course. #### **Tutorial classes** You should attempt all of your problem sheet questions in advance of attending the tutorial classes. The importance of adequate preparation prior to each tutorial cannot be overemphasized, as the effectiveness and usefulness of the tutorial depends to a large extent on this preparation. Group learning is encouraged. Answers for these questions will be discussed during the tutorial class and the tutor will cover the more complex questions in the tutorial class. In addition, during the tutorial class, 1-2 new questions that are not in your notes may be provided by the tutor, for you to try in class. These questions and solutions may not be made available on the web, so it is worthwhile for you to attend your tutorial classes to gain maximum benefit from this course. Tutorials will begin in week 2 and attendance will be taken on a regular base. #### Laboratory program The laboratory schedule is deliberately designed to provide practical, hands-on exposure to the concepts conveyed in lectures soon after they are covered in class. There will be 8 laboratory tasks. Each week, a new design problem related to the lectured material is presented. You will be required to step through the problem to a complete solution using the guidelines given per lab exercise. You are strongly encouraged to read over all the material and attempt any code writing before coming to your lab session as it will allow you to complete the required tasks within the allocated time slot. Throughout the lab, NXP LPC2478 microcontroller with ARM7TDMI-S core and Keil µVision Integrated Development Environment (IDE) will be used. In the first three exercises, tasks will be focused on various fundamental assembly programming techniques: data processing, control flow, and functions. The interaction of the processor with inputs and outputs peripherals and handling interrupts will be the subject of the other five labs. You are required to attend laboratory from Week 4 to Week 13. Laboratory attendance WILL be kept, and you MUST attend at least 80% of labs. One bonus lab task will be released after week 9 for students looking for a challenge. Although you are strongly encouraged to attempt the bonus task, there will only be minimal help from the lab demonstrators, allowing you to further demonstrate your ability to analyse and resolve issues independently. #### **Laboratory Exemption** There is no laboratory exemption for this course. Regardless of whether equivalent labs have been completed in previous courses, all students enrolled in this course for Semester 2, 2015 must take the labs. If, for medical reasons, (note that a valid medical certificate must be provided) you are unable to attend a lab, you will need to apply for a catch-up lab during another lab time, as agreed by the laboratory coordinator. #### **Assessment** The assessment scheme in this course reflects the intention to assess your learning progress through the semester. Ongoing assessment occurs through the lab checkpoints (see lab manual), fortnight quizzes, and the mid-semester exam. #### **Laboratory Assessment** Laboratories are primarily about learning, and the laboratory assessment is designed mainly to check your knowledge as you progress through each stage of the laboratory tasks. You are required to purchase a printed lab manual and bring this manual to every lab session. Each lab exercise will consist of one checkpoint that will be marked by the lab assessors. Although there is only one checkpoint, you will be marked for a number of tasks. It is important that you save or make records of your works as you will need them for the checkpoint. Demonstrators will be available to help students with any questions or difficulties. Upon completion of a checkpoint, you will be required to write down your student and bench numbers on the Laboratory Queue Sheet and wait for the laboratory assessor to mark your work. The marking sheet will be completely closed off 10 minutes before the end of the lab session. Students may record their name on the sheet for the previous week's checkpoints in the first 30 minutes of the lab if they were not marked in the previous session. The lab manual provides detailed additional background information that is necessary for the laboratory tasks and it is essential that you read the lab manual, complete any laboratory preparation and attempt any coding you may need before coming to the lab. Otherwise, you will most likely not finish in time to be marked for the checkpoint. Assessment marks will be awarded according to how much of the lab you were able to complete, your understanding of the experiment conducted during the lab and the topic covered by the lab, and the quality of the code you write during your lab work. Detailed information on the guideline for lab assessment is given in your lab manual. There will be 5% bonus marks available for those students who wish to attempt the additional lab tasks. Students attempting the bonus mark are expected to work independently as there will be minimal support provided for this task. Students are required to read and sign the plagiarism declaration at the front of the lab manual. Any instance of clear plagiarism will result in zero mark for the entire laboratory component. #### **Mid-Semester Exam** The mid-session examination tests your general understanding of the course material, and is designed to give you feedback on your progress through the analytical components of the course. Questions may be drawn from any course material up to the end of week 6. It will be held in the lecture room during normal lecture time in Week 9 on Monday from 10am-12noon. It will contain questions requiring you to describe qualitatively important concepts in the course and to write efficient ARM assembly codes. Marks will be assigned according to the correctness of the responses. #### **Fortnight Quizzes** The fortnight quizzes are designed to gauge your capacity to follow and understand the lecture material and to keep you engaged with course concepts regularly throughout the session. Each quiz will consist of a number of multiple choice questions and will be marked according to the number of correct answers. The quizzes are a mandatory component of the overall assessment and failure to attempt a quiz will result in no marks being given for the quiz. Each quiz will be available for a period of two weeks and the results per quiz will be published at the end of the period. No late attempts will be permitted. Students must attempt all quizzes to pass this subject. #### **Final Exam** The exam in this course is a standard closed-book a 3-hour written examination, comprising five compulsory questions. University approved calculators are allowed. The examination tests analytical and critical thinking and general understanding of the course material in a controlled fashion. Questions may be drawn from any aspect of the course (including laboratory), unless specifically indicated otherwise by the lecturer. Marks will be assigned according to the correctness of the responses. Please note that you must pass the final exam in order to pass the course. #### **Relationship of Assessment Methods to Learning Outcomes** | | Learning outcomes | | | | | | | | |----------------------------------|-------------------|---|---|---|---|---|---|---| | Assessment | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | | Laboratory practical assessments | <b>√</b> | - | ✓ | ✓ | ✓ | ✓ | - | ✓ | | Fortnight quizzes | <b>√</b> | ✓ | ✓ | - | - | ✓ | - | - | | Mid-semester exam | <b>√</b> | - | ✓ | - | ✓ | ✓ | - | ✓ | | Final exam | ✓ | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | #### **Course Resources** #### **Textbooks** Prescribed textbook: There is no single textbook for this course #### Reference books - William Hohl, ARM Assembly Language: Fundamentals and Techniques, CRC Press, 2009 (2nd Edition). - Steve Furber, ARM System On-Chip, 2nd Edition, Addison-Wesley, 2000. - Daniel W. Lewis, Fundamentals of Embedded software: where C and Assembly meet, Prentice Hall, 2002 - Steven F.Barrett and Daniel J. Pack, Embedded systems: Design and Applications with 68HC12 and HCS12, Prentice Hall, 2005. - Frederick M. Cady, Microcontrollers and Microcomputers: Principles of Software and Hardware Engineering, Oxford, 1997. #### **On-line resources** #### Moodle As a part of the teaching component, Moodle will be used to disseminate teaching materials, host forums and occasionally quizzes. Assessment marks will also be made available via Moodle: https://moodle.telt.unsw.edu.au/login/index.php. #### Mailing list Announcements concerning course information will be given in the lectures and/or on Moodle and/or via email (which will be sent to your student email address). #### **Other Matters** #### **Academic Honesty and Plagiarism** Plagiarism is the unacknowledged use of other people's work, including the copying of assignment works and laboratory results from other students. Plagiarism is considered a form of academic misconduct, and the University has very strict rules that include some severe penalties. For UNSW policies, penalties and information to help you avoid plagiarism, see <a href="https://student.unsw.edu.au/plagiarism">https://student.unsw.edu.au/plagiarism</a>. To find out if you understand plagiarism correctly, try this short quiz: <a href="https://student.unsw.edu.au/plagiarism-quiz">https://student.unsw.edu.au/plagiarism-quiz</a>. #### **Student Responsibilities and Conduct** Students are expected to be familiar with and adhere to all UNSW policies (see <a href="https://student.unsw.edu.au/quide">https://student.unsw.edu.au/quide</a>), and particular attention is drawn to the following: #### Workload It is expected that you will spend at least **ten to twelve hours per week** studying a 6 UoC course, from Week 1 until the final assessment, including both face-to-face classes and *independent, self-directed study*. In periods where you need to need to complete assignments or prepare for examinations, the workload may be greater. Over-commitment has been a common source of failure for many students. You should take the required workload into account when planning how to balance study with employment and other activities. #### **Attendance** Regular and punctual attendance at all classes is expected. UNSW regulations state that if students attend less than 80% of scheduled classes they may be refused final assessment. #### **General Conduct and Behaviour** Consideration and respect for the needs of your fellow students and teaching staff is an expectation. Conduct which unduly disrupts or interferes with a class is not acceptable and students may be asked to leave the class. #### **Work Health and Safety** UNSW policy requires each person to work safely and responsibly, in order to avoid personal injury and to protect the safety of others. #### **Special Consideration and Supplementary Examinations** You must submit all assignments and attend all examinations scheduled for your course. You should seek assistance early if you suffer illness or misadventure which affects your course progress. All applications for special consideration must be **lodged online through myUNSW within 3 working days of the assessment**, not to course or school staff. For more detail, consult <a href="https://student.unsw.edu.au/special-consideration">https://student.unsw.edu.au/special-consideration</a>. #### **Continual Course Improvement** This course is under constant revision in order to improve the learning outcomes for all students. Please forward any feedback (positive or negative) on the course to the course convener or via the Course and Teaching Evaluation and Improvement Process. You can also provide feedback to ELSOC who will raise your concerns at student focus group meetings. As a result of previous feedback obtained for this course and in our efforts to provide a rich and meaningful learning experience, we have continued to evaluate and modify our delivery and assessment methods. #### **Administrative Matters** On issues and procedures regarding such matters as special needs, equity and diversity, occupational health and safety, enrolment, rights, and general expectations of students, please refer to the School and UNSW policies: http://www.engineering.unsw.edu.au/electrical-engineering/policies-and-procedures https://my.unsw.edu.au/student/atoz/ABC.html ## **Appendix A: Targeted Graduate Capabilities** Electrical Engineering and Telecommunications programs are designed to address the following targeted capabilities which were developed by the school in conjunction with the requirements of professional and industry bodies: - The ability to apply knowledge of basic science and fundamental technologies; - The skills to communicate effectively, not only with engineers but also with the wider community; - The capability to undertake challenging analysis and design problems and find optimal solutions; - Expertise in decomposing a problem into its constituent parts, and in defining the scope of each part; - A working knowledge of how to locate required information and use information resources to their maximum advantage; - Proficiency in developing and implementing project plans, investigating alternative solutions, and critically evaluating differing strategies; - An understanding of the social, cultural and global responsibilities of the professional engineer; - The ability to work effectively as an individual or in a team; - An understanding of professional and ethical responsibilities; - The ability to engage in lifelong independent and reflective learning. ## **Appendix B: UNSW Graduate Capabilities** The course delivery methods and course content directly or indirectly addresses a number of core UNSW graduate capabilities, as follows - Developing scholars who have a deep understanding of their discipline, through lectures and solution of analytical problems in tutorials and assessed by assignments and written examinations. - Developing rigorous analysis, critique, and reflection, and ability to apply knowledge and skills to solving problems. These will be achieved by the laboratory experiments and interactive checkpoint assessments and lab exams during the labs. - Developing capable independent and collaborative enquiry, through a series of tutorials spanning the duration of the course. - Developing digital and information literacy and lifelong learning skills through assignment work. # Appendix C: Engineers Australia (EA) Professional Engineer Competency Standard | | Program Intended Learning Outcomes | | | | | |-------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------|--|--|--| | | PE1.1 Comprehensive, theory-based understanding of underpinning fundamentals | <b>√</b> | | | | | PE1: Knowledge<br>and Skill Base | PE1.2 Conceptual understanding of underpinning maths, analysis, statistics, computing | <b>√</b> | | | | | No ≡ | PE1.3 In-depth understanding of specialist bodies of knowledge | | | | | | 7 X | PE1.4 Discernment of knowledge development and research directions | | | | | | E1: | PE1.5 Knowledge of engineering design practice | ✓ | | | | | | PE1.6 Understanding of scope, principles, norms, accountabilities of sustainable engineering practice | | | | | | ring | PE2.1 Application of established engineering methods to complex problem solving | <b>√</b> | | | | | nee<br>Itioi<br>ty | PE2.2 Fluent application of engineering techniques, tools and resources | <b>√</b> | | | | | PE2: Engineering<br>Application<br>Ability | PE2.3 Application of systematic engineering synthesis and design processes | | | | | | PE2: | PE2.4 Application of systematic approaches to the conduct and management of engineering projects | | | | | | _ | PE3.1 Ethical conduct and professional accountability | | | | | | PE3: Professional<br>and Personal<br>Attributes | PE3.2 Effective oral and written communication (professional and lay domains) | <b>√</b> | | | | | ofes<br>ers<br>but | PE3.3 Creative, innovative and pro-active demeanour | <b>√</b> | | | | | : Professi<br>nd Person<br>Attributes | PE3.4 Professional use and management of information | <b>√</b> | | | | | E3: | PE3.5 Orderly management of self, and professional conduct | | | | | | Δ. | PE3.6 Effective team membership and team leadership | <b>√</b> | | | |