| USN | | | | | | FB | |-----|--|--|--|--|--|----| | CDI | | | | | | 2 | [4] ## Internal Assessment Test - II | Sub: | Embedded System | Code: | BEC601 | | | | | | | |-------|-----------------|-----------|-----------|-------------|----------|------|-----|---------|-----| | Date: | 27/05/2025 | Duration: | 90 mins | Max Marks: | 50 | Sem: | 6th | Branch: | ECE | | | | Δ | nswer Anv | FIVE FIII I | nestions | 1 | | | | # $\frac{\text{OBE}}{\text{CO}}$ RBT 1. Compare (i) DFG and CDFG models with an example. [10] CO2 L2 ## Data Flow Graph/Diagram (DFG) Model The Data Flow Graph (DFG) model translates the data processing requirements into a data flow graph. The Data Flow Graph (DFG) model is a data driven model in which the program execution is determined by data. This model emphasises on the data and operations on the data which transforms the input data to output data. Indeed Data Flow Graph (DFG) is a visual model in which the operation on the data (process) is represented using a block (circle) and data flow is represented using arrows. An inward arrow to the process (circle) represents input data and an outward arrow from the process (circle) represents output data in DFG notation. Embedded applications which are computational intensive and data driven are modeled using the DFG model. DSP applications are typical examples for it. Now let's have a look at the implementation of a DFG. Suppose one of the functions in our application contains the computational requirement x = a + b; and y = x - c. Figure 7.1 illustrates the implementation of a DFG model for implementing these requirements. In a DFG model, a data path is the data flow path from input to output. A DFG model is said to be acyclic DFG (ADFG) if it doesn't contain multiple values for the input variable and multiple output values for a given set of input(s). Feedback inputs (Output is fed back to Input), events, etc. are examples for non-acyclic inputs. A DFG model translates the program as a single sequential process execution. Fig. 7.1 Data flow graph (DFG) model ## 7.2.2 Control Data Flow Graph/ Diagram (CDFG) We have seen that the DFG model is a data driven model in which the execution is controlled by data and it doesn't involve any control operations (conditionals). The Control DFG (CDFG) model is used for modelling applications involving conditional program execution. CDFG models contains both data operations and control operations. The CDFG uses Data Flow Graph (DFG) as element and conditional (constructs) as decision makers. CDFG contains both data flow nodes and decision nodes, whereas DFG contains only data flow nodes. Let us have a look at the implementation of the CDFG for the following requirement. If flag = 1, x = a + b; else y = a - b; This requirement contains a decision making process. The CDFG model for the same is given in Fig. 7.2. Fig. 7.2 Control Data Flow Graph (CDFG) Model The control node is represented by a 'Diamond' block which is the decision making element in a normal flow chart based design. CDFG translates the requirement, which is modeled to a concurrent process model. The decision on which process is to be executed is determined by the control node. A real world example for modelling the embedded application using CDFG is the capturing and saving of the image to a format set by the user in a digital still camera where everything is data driven starting from the Analog Front End which converts the CCD sensor generated analog signal to Digital Signal and the task which stores the data from ADC to a frame buffer for the use of a media processor which performs various operations like, auto correction, white balance adjusting, etc. The decision on, in which format the image is stored (formats like JPEG, TIFF, BMP, etc.) is controlled by the camera settings, configured by the user. ### (ii) C v/s Embedded C | 'C' is a well structured, well defined and standardised general purpose programming language with extensive bit manipulation support. 'C' offers a combination of the features of high level language and assembly and helps in hardware access programming (system level programming) as well as business package developments (Application developments like pay roll systems, banking applications, etc). The conventional 'C' language follows ANSI standard and it incorporates various library files for different operating systems. A platform (operating system) specific application, known as, compiler is used for the conversion of programs written in 'C' to the target processor (on which the OS is running) specific binary files. Hence it is a platform specific development. Embedded 'C' can be considered as a subset of conventional 'C' language. Embedded 'C' supports all 'C' instructions and incorporates a few target processor specific functions/instructions. It should be noted that the standard ANSI 'C' library implementation is always tailored to the target processor/controller library files in Embedded 'C'. The implementation of target processor/controller specific functions/instructions depends upon the processor/controller as well as the supported cross-compiler for the particular Embedded 'C' language. A software program called 'Cross-compiler' is used for the conversion of programs written in Embedded 'C' to target processor/controller specific instructions (machine language). | [3] | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|----| | (iii) Compiler v/s Cross-Compiler. Compiler is a software tool that converts a source code written in a high level language on top of a particular operating system running on a specific target processor architecture (e.g. Intel x86/Pentium). Here the operating system, the compiler program and the application making use of the source code run on the same target processor. The source code is converted to the target processor specific machine instructions. The development is platform specific (OS as well as target processor on which the OS is running). Compilers are generally termed as 'Native Compilers'. A native compiler generates machine code for the same machine (processor) on which it is running. Cross-compilers are the software tools used in cross-platform development applications. In cross-platform development, the compiler running on a particular target processor/OS converts the source code to machine code for a target processor whose architecture and instruction set is different from the processor on which the compiler is running or for an operating system which is different from the current development environment OS. Embedded system development is a typical example for cross-platform development where embedded firmware is developed on a machine with Intel/AMD or any other target processors and the same is converted into machine code for any other target processor architecture (e.g. 8051, PIC, ARM etc). Keil C51 is an example for cross-compiler. The term 'Compiler' is used interchangeably with 'Cross-compiler' in embedded firmware applications. Whenever you see the term 'Compiler' related to any embedded firmware application, it could be referring to a cross-compiler. | [3] | | | | | [10] | CO2 | L2 | As seen from the FSM, the timer state can be either 'IDLE' or 'READY' or 'RUNNING'. During the normal condition when the timer is not running, it is said to be in the 'IDLE' state. The timer is said to be in the 'READY' state when the timer is loaded with the count corresponding to the required time delay. The timer remains in the 'READY' state until a 'Start Timer' event occurs. The timer changes its state to 'RUNNING' from the 'READY' state on receiving a 'Start Timer' event and remains in the 'RUNNING' state until the timer count expires or a 'Stop Timer' even occurs. The timer state changes to 'IDLE' from 'RUNNING' on receiving a 'Stop Timer' or 'Timer Expire' event. | 3. | With the help of a neat diagram, explain the operating system architecture. | [10] | CO3 | L3 | |----|-----------------------------------------------------------------------------|------|-----|----| | | | | | | | | | | | | | | | | | | The operating system acts as a bridge between the user applications/tasks and the underlying system resources through a set of system functionalities and services. The OS manages the system resources and makes them available to the user applications/tasks on a need basis. A normal computing system is a collection of different I/O subsystems, working, and storage memory. The primary functions of an operating system is LO 1 Understand the basics of an operating system and the need for an operating system [5] - Make the system convenient to use - · Organise and manage the system resources efficiently and correctly Figure 10.1 gives an insight into the basic components of an operating system and their interfaces with rest of the world. Fig. 10.1 The Operating System Architecture #### 10.1.1 The Kernel The kernel is the core of the operating system and is responsible for managing the system resources and the communication among the hardware and other system services. Kernel acts as the abstraction layer between system resources and user applications. Kernel contains a set of system libraries and services. For a general purpose OS, the kernel contains different services for handling the following. **Process Management** Process management deals with managing the processes/tasks. Process management includes setting up the memory space for the process, loading the process's code into the memory space, allocating system resources, scheduling and managing the execution of the process, setting up and managing the Process Control Block (PCB), Inter Process Communication and synchronisation, process termination/ deletion, etc. We will look into the description of process and process management in a later section of this chapter. **Primary Memory Management** The term primary memory refers to the volatile memory (RAM) where processes are loaded and variables and shared data associated with each process are stored. The Memory Management Unit (MMU) of the kernel is responsible for - Keeping track of which part of the memory area is currently used by which process - Allocating and De-allocating memory space on a need basis (Dynamic memory allocation). **File System Management** File is a collection of related information. A file could be a program (source code or executable), text files, image files, word documents, audio/video files, etc. Each of these files differ in the kind of information they hold and the way in which the information is stored. The file operation is a useful service provided by the OS. The file system management service of Kernel is responsible for - · The creation, deletion and alteration of files - · Creation, deletion and alteration of directories - Saving of files in the secondary storage memory (e.g. Hard disk storage) - Providing automatic allocation of file space based on the amount of free space available - Providing a flexible naming convention for the files The various file system management operations are OS dependent. For example, the kernel of Microsoft® DOS OS supports a specific set of file system management operations and they are not the same as the file system operations supported by UNIX Kernel. [3] I/O System (Device) Management Kernel is responsible for routing the I/O requests coming from different user applications to the appropriate I/O devices of the system. In a well-structured OS, the direct accessing of I/O devices are not allowed and the access to them are provided through a set of Application Programming Interfaces (APIs) exposed by the kernel. The kernel maintains a list of all the I/O devices of the system. This list may be available in advance, at the time of building the kernel. Some kernels, dynamically updates the list of available devices as and when a new device is installed (e.g. Windows NT kernel keeps the list updated when a new plug 'n' play USB device is attached to the system). The service 'Device Manager' (Name may vary across different OS kernels) of the kernel is responsible for handling all I/O device related operations. The kernel talks to the I/O device through a set of low-level systems calls, which are implemented in a service, called device drivers. The device drivers are specific to a device or a class of devices. The Device Manager is responsible for · Loading and unloading of device drivers Exchanging information and the system specific control signals to and from the device Secondary Storage Management The secondary storage management deals with managing the secondary storage memory devices, if any, connected to the system. Secondary memory is used as backup medium for programs and data since the main memory is volatile. In most of the systems, the secondary storage is kept in disks (Hard Disk). The secondary storage management service of kernel deals with Disk storage allocation • Disk scheduling (Time interval at which the disk is activated to backup data) • Free Disk space management Protection Systems Most of the modern operating systems are designed in such a way to support multiple users with different levels of access permissions (e.g. Windows 10 with user permissions like 'Administrator', 'Standard', 'Restricted', etc.). Protection deals with implementing the security policies to restrict the access to both user and system resources by different applications or processes or users. In multiuser supported operating systems, one user may not be allowed to view or modify the whole/portions of another user's data or profile details. In addition, some application may not be granted with permission to make use of some of the system resources. This kind of protection is provided by the protection services running within the kernel. **Interrupt Handler** Kernel provides handler mechanism for all external/internal interrupts generated by the system. What is a process/task? Explain with the help of a neat diagram the structure and [10] CO<sub>3</sub> L<sub>2</sub> memory organization of a process. A 'Process' is a program, or part of it, in execution. Process is also known as an instance of a program in execution. Multiple instances of the same program can execute simultaneously. A process requires various system resources like CPU for executing the process, memory for storing the code corresponding to the process and associated variables, I/O devices for information exchange, etc. A process is sequential in execution. [3] The concept of 'Process' leads to concurrent execution (pseudo parallelism) of tasks and thereby the efficient utilisation of the CPU and other system resources. Concurrent execution is achieved through the sharing of CPU among the processes. A process mimics a processor in properties and holds a set of registers, process status, a Program Counter (PC) to point to the next executable instruction of the process, a stack for holding the local variables associated with the process and the code corresponding to the process. This can be visualised as shown in Fig. 10.4. A process which inherits all the properties of the CPU can be considered as a virtual processor, awaiting its turn to have its properties switched into the physical processor. When the process gets its turn, its registers and the program counter register becomes mapped to the physical registers of the CPU. From a memory perspective, the memory occupied by the *process* is segregated into three regions, namely, Stack memory, Data memory and Code memory (Fig. 10.5). Process Stack Memory Stack (Stack pointer) Stack memory grows downwards Working registers Data memory grows upwards Status registers [4] Program counter (PC) **Data Memory** Code memory corresponding to the Code Memory Process Fig. 10.5 Memory organisation of a Process Fig. 10.4 Structure of a Process | 5. What is a barrel shifter with respect to an ARM processor? Explain with the help of a neat diagram and example. BARREL SHIFTER In Example 3.1 we showed a MOV instruction where N is a simple register. But N can be more than just a register or immediate value; it can also be a register Rm that has been preprocessed by the barrel shifter prior to being used by a data processing instruction. Data processing instructions are processed within the arithmetic logic unit (ALU). A unique and powerful feature of the ARM processor is the ability to shift the 32-bit binary pattern in one of the source registers left or right by a specific number of positions before it enters the ALU. This shift increases the power and flexibility of fampy data processing operations. There are data processing instructions that do not use the barrel shift, for example, the MU. (multiply), CLZ (count leading zeros), and QADD (signed saturated 32-bit add) instructions. Pre-processing or shift occurs within the cycle time of the instruction. This is particularly useful for loading constants into a register and achieving fast multiplies or division by a power of 2. Figure 3.1 Barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rm enters the ALU without any pre-processing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. Example: This example shows a simple move instruction. The MOV instruction takes the contents of register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 r7 - 8 MOV r7, r5 ; let r7 = r5 POST r5 - 5 POST r5 - 5 POST r5 - 5 POST r5 - 5 POST r5 - 5 POST r5 - 5 | The 'Stack' memory holds all temporary data such as variables local to the process. Data memory holds all global data for the process. The code memory contains the program code (instructions) corresponding to the process. On loading a process into the main memory, a specific area of memory is allocated for the process. The stack memory usually starts (OS Kernel implementation dependent) at the highest memory address from the memory area allocated for the process. Say for example, the memory map of the memory area allocated for the process is 2048 to 2100, the stack memory starts at address 2100 and grows downwards to accommodate the variables local to the process. | [3] | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----|----| | In Example 3.1 we showed a MOV instruction where N is a simple register. But N can be more than just a register or immediate value; it can also be a register Rm that has been preprocessed by the barrel shifter prior to being used by a data processing instruction. Data processing instructions are processed within the arithmetic logic unit (ALU). A unique and powerful feature of the ARM processor is the ability to shift the 32-bit binary pattern in one of the source registers left or right by a specific number of positions before it enters the ALU. This shift increases the power and flexibility of many data processing operations. There are data processing instructions that do not use the barrel shift, for example, the MUL (multiply), CLZ (count leading zeros), and QADD (signed saturated 32-bit add) instructions. Pre-processing or shift occurs within the cycle time of the instruction. This is particularly useful for loading constants into a register and achieving fast multiplies or division by a power of 2. Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rn enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. Example. This example shows a simple move instruction. The MOV instruction takes the contents of 3.1 register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 POST r5 = 5 POST r5 = 5 | | [10] | CO4 | L2 | | more than just a register or immediate value; it can also be a register Rm that has been preprocessed by the barrel shirter prior to being used by a data processing instruction. Data processing instructions are processed within the arithmetic logic unit (ALU). A unique and powerful feature of the ARM processor is the ability to shift the 52-bit binary pattern in one of the source registers left or right by a specific number of positions before it enters the ALU. This shift increases the power and flexibility of many data processing operations. There are data processing instructions that do not use the barrel shift, for example, the MUL (multiply), CLZ (count leading zeros), and QADD (signed saturated 32-bit add) instructions. Pre-processing or shift occurs within the cycle time of the instruction. This is particularly useful for loading constants into a register and achieving fast multiplies or division by a power of 2. Rn Barrel shifter Result N Arithmetic logic unit Rm Barrel shifter Result N To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register R enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 POST r5 = 5 | | | | | | the MUL (multiply), CLZ (count leading zeros), and QADD (signed saturated 32-bit add) instructions. Pre-processing or shift occurs within the cycle time of the instruction. This is particularly useful for loading constants into a register and achieving fast multiplies or division by a power of 2. Rn Barrel shifter Result N Arithmetic logic unit Rd Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rn enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. Example This example shows a simple move instruction. The MOV instruction takes the contents of 3.1 register r3 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 | more than just a register or immediate value; it can also be a register <i>Rm</i> that has been preprocessed by the barrel shifter prior to being used by a data processing instruction. Data processing instructions are processed within the arithmetic logic unit (ALU). A unique and powerful feature of the ARM processor is the ability to shift the 32-bit binary pattern in one of the source registers left or right by a specific number of positions before it enters the ALU. This shift increases the power and flexibility of many data processing operations. | [3] | | | | Pre-processing or shift occurs within the cycle time of the instruction. This is particularly useful for loading constants into a register and achieving fast multiplies or division by a power of 2. Rn | | | | | | Arithmetic logic unit Rd Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rn enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 | instructions. Pre-processing or shift occurs within the cycle time of the instruction. This is particularly useful for loading constants into a register and achieving fast multiplies or division by | | | | | Arithmetic logic unit Rd Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rn enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 | 50 | | | | | Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rn enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 POST r5 = 5 | No bre-processing Barrel shifter Result N | | | | | Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register Rn enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 POST r5 = 5 | \ Arithmetic logic unit / | | | | | Figure 3.1 Barrel shifter and ALU. To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register <i>Rn</i> enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register <i>r5</i> and copies them into register <i>r7</i> , in this case, taking the value 5, and overwriting the value 8 in register <i>r7</i> . PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 POST r5 = 5 | Rd | | | | | To illustrate the barrel shifter we will take the example in Figure 3.1 and add a shift operation to the move instruction example. Register <i>Rn</i> enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register <i>r5</i> and copies them into register <i>r7</i> , in this case, taking the value 5, and overwriting the value 8 in register <i>r7</i> . PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 POST r5 = 5 | | [3] | | | | operation to the move instruction example. Register <i>Rn</i> enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel shifter. EXAMPLE This example shows a simple move instruction. The MOV instruction takes the contents of register <i>r5</i> and copies them into register <i>r7</i> , in this case, taking the value 5, and overwriting the value 8 in register <i>r7</i> . PRE r5 = 5 r7 = 8 MOV r7, r5 ; let r7 = r5 POST r5 = 5 | Figure 3.1 Barrel shifter and ALU. | | | | | 3.1 register r5 and copies them into register r7, in this case, taking the value 5, and overwriting the value 8 in register r7. PRE r5 = 5 r7 = 8 MOV r7, r5; let r7 = r5 POST r5 = 5 | operation to the move instruction example. Register <i>Rn</i> enters the ALU without any preprocessing of registers. Figure 3.1 shows the data flow between the ALU and the barrel | | | | | PRE r5 = 5<br>r7 = 8<br>MOV r7, r5 ; let r7 = r5<br>POST r5 = 5 | 3.1 register $r5$ and copies them into register $r7$ , in this case, taking the value 5, and overwriting | | | | | MOV r7, r5 ; let r7 = r5 POST r5 = 5 | PRE r5 = 5 | [4] | | | | | MOV r7, r5 ; let r7 = r5 POST r5 = 5 | | | | | Mnemonic | Description S | hift Result | | Shift amount y | | | | |-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|------|-----|--| | | 1 | | | | | | | | LSL<br>LSR | 0 | LSL $y$ $x \ll y$<br>LSR $y$ (unsigned) $x \gg$ | 47 | #0–31 or <i>Rs</i><br>#1–32 or <i>Rs</i> | | | | | ASR | | ASR y (signed) $x \gg y$ | y | #1–32 or <i>Rs</i> | | | | | ROR | | | $y) \mid (x \ll (32 - y))$ | #1–31 or <i>Rs</i> | | | | | RRX | | | $((unsigned)x \gg 1)$ | none | | | | | Note: x represe | nts the register being shifted ar | nd y represents the shift amo | unt. | | _ | | | | | nzcv Condition βags nzCv Condition βags | | Bit 2 0 0 0 0 | ) = 0x80000004<br>) = 0x00000008 | | | | | | Cond | ition flags<br>ated when<br>s present | | | _ | | | | | | | | | | | | | Figure 3.2 | Logical shift left by o | one. | | | | | | | Figure 3.2<br>Table 3.3 | Barrel shift operation | | | 15. | | | | | | , | | essing instruction | ıs. | | | | | | Barrel shift operation N shift operations | | Syntax | | | | | | | Barrel shift operation N shift operations Immediate | | Syntax<br>#immedia | | | | | | | Barrel shift operation N shift operations Immediate Register | n syntax for data proc | Syntax<br>#immedia<br>Rm | ate | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in | n syntax for data proc | Syntax<br>#immedia<br>Rm<br>Rm, LSL | ate<br>#shift_imm | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift left by re | n syntax for data proc<br>mmediate<br>egister | Syntax<br>#immedia<br>Rm<br>Rm, LSL<br>Rm, LSL | ate<br>#shift_imm<br>Rs | | | | | | N shift operations Immediate Register Logical shift left by in Logical shift right by | n syntax for data proc<br>mmediate<br>egister<br>immediate | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR | ate<br>#shift_imm<br>Rs<br>#shift_imm | | | | | | Barrel shift operations N shift operations Immediate Register Logical shift left by in Logical shift left by re Logical shift right by Logical shift right wit | n syntax for data proc<br>mmediate<br>egister<br>immediate<br>th register | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR | #shift_imm<br>Rs<br>#shift_imm<br>Rs | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift left by re Logical shift right by Logical shift right wit Arithmetic shift right | n syntax for data proc<br>mmediate<br>egister<br>immediate<br>th register<br>t by immediate | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, LSR | #shift_imm Rs #shift_imm Rs #shift_imm | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift left by re Logical shift right by Logical shift right wit Arithmetic shift right | n syntax for data proc<br>mmediate<br>egister<br>immediate<br>th register<br>t by immediate<br>t by register | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift left by re Logical shift right by Logical shift right wit Arithmetic shift right Rotate right by immediate | n syntax for data proc<br>mmediate<br>egister<br>immediate<br>th register<br>t by immediate<br>t by register<br>ediate | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR | #shift_imm Rs #shift_imm Rs #shift_imm | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist | mmediate<br>egister<br>immediate<br>th register<br>t by immediate<br>t by register<br>ediate | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift left by re Logical shift right by Logical shift right wit Arithmetic shift right Rotate right by immediate | mmediate<br>egister<br>immediate<br>th register<br>t by immediate<br>t by register<br>ediate | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | | | | | | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist | mmediate<br>egister<br>immediate<br>th register<br>t by immediate<br>t by register<br>ediate | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | | | | | Table 3.3 | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with exte | n syntax for data proc<br>mmediate<br>egister<br>immediate<br>th register<br>t by immediate<br>t by register<br>ediate<br>er | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | FINI | | | | Table 3.3 | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external | nmediate egister immediate th register t by immediate t by register ediate er end | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | [10] | | | | List the difference of R | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist | nmediate egister immediate th register t by immediate t by register ediate er end | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | [10] | | | | Table 3.3 | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist | nmediate egister immediate th register t by immediate t by register ediate er end | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | [10] | | | | List the difference of R | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist | nmediate egister immediate th register t by immediate t by register ediate er end | Syntax #immedia Rm Rm, LSL Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm | [10] | | | | Table 3.3 Table 3.7 Table 3.7 | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external extension of ARM 13, R14 and R15 regist CRS | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs | [10] | | | | List the difference of REGISTE | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist CRS urpose registers hold eith | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR | #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs #shift_imm Rs with the | | CO4 | | | Table 3.3 Table 3.3 REGISTE General-p letter r pr | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist ERS urpose registers hold eith refixed to the register nur | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROX | #shift_imm Rs | [10] | CO4 | | | Table 3.3 Table 3.3 REGISTE General-p letter r pr | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist ERS urpose registers hold eith refixed to the register nur | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROX | #shift_imm Rs | | CO4 | | | Table 3.3 Table 3.3 REGISTE General-p letter r pr | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist CRS urpose registers hold eith | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROX | #shift_imm Rs | | CO4 | | | Table 3.3 Table 3.3 REGISTE General-p letter r pr | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist ERS urpose registers hold eith refixed to the register nur | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROX | #shift_imm Rs | | CO4 | | | Table 3.3 Table 3.3 REGISTE General-p letter r pr | Barrel shift operation N shift operations Immediate Register Logical shift left by in Logical shift right by Logical shift right wit Arithmetic shift right Arithmetic shift right Rotate right by imme Rotate right by regist Rotate right with external registers of ARN 13, R14 and R15 regist ERS urpose registers hold eith refixed to the register nur | nmediate egister immediate th register t by immediate t by register ediate er end M CORTEX – M3 a sters. | Syntax #immedia Rm Rm, LSL Rm, LSR Rm, LSR Rm, ASR Rm, ASR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROR Rm, ROX | #shift_imm Rs | | CO4 | | | | used when executing applications. The processor can operate in seven different modes, | | | | |---|---------------------------------------------------------------------------------------------------------------------------------------|------------|-----|------------| | | which we will introduce shortly. All the registers shown are 32 bits in size. | | | | | | There are up to 18 active registers: 16 data registers and 2 processor status registers. The | | | | | | data registers are visible to the programmer as r0 to r15. | | | | | | The ARM processor has three registers assigned to a particular task or special function: | | | | | | <i>r13</i> , <i>r14</i> , and <i>r15</i> . They are frequently given different labels to differentiate them from the other registers. | | | | | | other registers. | [4] | | | | | | | | | | | r0 | | | | | | r1 | | | | | | r2 | | | | | | <i>r</i> 3 | | | | | | r4 | | | | | | <i>r</i> 5 | | | | | | <i>r</i> 6 | | | | | | <i>r</i> 7 | | | | | | <u>r8</u> | | | | | | <u>r9</u> | | | | | | r10 | | | | | | <u>r11</u> | | | | | | r12 | | | | | | | | | | | | r13 sp | | | | | | <u>r14 lr</u> | | | | | | r15 pc | | | | | | | | | | | | cpsr | | | | | | - | | | | | | | | | | | | | | | | | | Figure 2.2 Registers available in <i>user</i> mode. | | | | | | | | | | | | In Figure 2.2, the shaded registers identify the assigned special-purpose registers: | | | | | | Designation will be traditionally used as the steels pointer (++) and stones the head of the steels | | | | | ľ | Register $r13$ is traditionally used as the stack pointer $(sp)$ and stores the head of the stack in the current processor made | | | | | | in the current processor mode. | [3] | | | | | Register $r14$ is called the link register $(lr)$ and is where the core puts the return address | | | | | | whenever it calls a subroutine. | | | | | | Register $r15$ is the program counter $(pc)$ and contains the address of the next instruction | | | | | | to be fetched by the processor. | | | | | | | | | | | | Depending upon the context, registers $r13$ and $r14$ can also be used as general-purpose | | | | | | registers, which can be particularly useful since these registers are banked during a processor | | | | | | mode change. However, it is dangerous to use $r13$ as a general register when the processor | | | | | | is running any form of operating system because operating systems often assume that $r13$ | | | | | | always points to a valid stack frame. In ARM state the registers $r0$ to $r13$ are $orthogonal$ —any instruction that you can apply | | | | | | to $r0$ you can equally well apply to any of the other registers. However, there are instructions | | | | | | that treat $r14$ and $r15$ in a special way. | | | | | | In addition to the 16 data registers, there are two program status registers: <i>cpsr</i> and <i>spsr</i> | | | | | | (the current and saved program status registers, respectively). | | | | | | The register file contains all the registers available to a programmer. Which registers are | | | | | | visible to the programmer depend upon the current mode of the processor. | | | | | | Explain the following ARM instructions with an example with pre and post | [10] | | | | | execution conditions: | | CO5 | L2 | | | a) SUBS r1,r1,#1 | | | | | _ | | · <u> </u> | _ | · <u> </u> | The SUBS instruction is useful for decrementing loop counters. In this example we subtract the immediate value one from the value one stored in register r1. The result value zero is written to register r1. The cpsr is updated with the ZC flags being set. [3] cpsr = nzcvqiFt USER PRE r1 = 0x00000001POST cpsr = nZCvqiFt USER r1 = 0x00000000b) RSB r0,r1,#0 This reverse subtract instruction (RSB) subtracts r1 from the constant value #0, writing the result to r0. You can use this instruction to negate numbers. [3] PRE r0 = 0x00000000r1 = 0x00000077RSB r0, r1, #0 ; Rd = 0x0 - r1**POST** r0 = -r1 = 0xffffff89c) BIC r0,r1,r2 This example shows a more complicated logical instruction called BIC, which carrie a logical bit clear. [4] r1 = 0b1111PRE r2 = 0b0101BIC r0, r1, r2 POST r0 = 0b1010This is equivalent to Rd = Rn AND NOT(N)In this example, register r2 contains a binary pattern where every binary 1 in r2 clears a corresponding bit location in register r1. This instruction is particularly useful when clearing status bits and is frequently used to change interrupt masks in the cpsr. The logical instructions update the cpsr flags only if the S suffix is present. These instructions can use barrel-shifted second operands in the same way as the arithmetic instructions.