

UNIT 3EMBEDDED FIRMWARE DESIGN

## 1. Embedded Firmware design approaches :-

The firmware design approaches for embedded product is purely dependent on the complexity of the functions to be performed, the speed of operation required, etc.

\* Two basic approaches are used for Embedded firmware design.

(i) Conventional Procedural Based Firmware Design (or)  
Super Loop Based Approach.

(ii) Embedded Operating System (OS) Based Designs.

(i) The Super Loop Based Approach :-

\* The Super loop based firmware development approach is adopted for applications that are not time critical and where the response time is not so important.

\* In this the code is executed task by task, The tasks listed at the top of the program code is executed first and the tasks just below the top are executed after completing the first task.

\* The tasks are running inside an infinite loop, the only way to come out of the loop is either a hardware reset or an interrupt assertion.

\* Hardware reset brings the program execution back to the main loop.

\* Interrupt request suspends the task execution temporarily, and it restarts the task execution from the point where it got interrupted.

\* It doesn't require an operating system,

\* In this design, the priorities are fixed and the order in which the tasks to be

executed are also fixed.

- \* This type of design is deployed in low-cost embedded products and products where response time is not time critical.
- \* For example, reading/writing data to and from a card using a card reader requires a sequence of operations like clocking the pinhole of card, authenticating the operation, reading/writing, etc..
- \* A typical example for a superloop based product is an electronic video game - TV containing keypad and display unit.

Drawbacks :-

- \* Any failure in any part of a single task will affect the total system.
- \* If the program hangs up at some while executing a task, it will require h/w and s/w watchdog timer (WDT), may incur additional h/w cost and firmware overheads.

#### (ii) The Embedded Operating Systems (OS) Based Approach :-

- \* The operating systems (OS) based approach contains operating systems, which can be either a general purpose operating system (GPoS) or a Real Time operating system (RTOS).  
Ex:- Personal Digital Assistant (PDA's), Handheld/portable device & point of sale.
- \* RTOS based design approach is employed in embedded products demanding real time response.
- \* It responsible for performing pre-emptive multitasking, Schedulers for scheduling tasks, multiple threads etc.  
Ex:- windows CE, pSOS, VxWorks, ThreadX, Microc/OS-II, Embedded Linux, Symbian etc ..

## 2. Embedded Firmware Development Languages :-

- (i) Assembly language based development.
- (ii) High Level language based development.
- (iii) Mixing Assembly and High Level language.

### (i) Assembly language based development :-

- \* 'Assembly language' is the human readable notation of 'machine language', whereas 'machine language' is a processor understandable language.
- \* Assembly language programming is the task of writing processor specific machine code in mnemonic form, converting the mnemonics into actual processor instructions (machine language) and associated data using an assembler.
- \* Each line of an assembly language program is split into four fields as given

LABEL      OPCODE      OPERAND      COMMENTS .

- \* A 'LABEL' is an optional field, is commonly used for representing a memory location, address of a program, sub-routine, code pointers etc.
- \* The opcode tells the processor/controller what to do and the operands provide the data and information required to perform the actions specified by the opcode.
- \* The assembly language programs written in assembly code is saved as .asm (Assembly file) file or an .src (source) file.
- \* The following figure shows the assembly language to machine language conversion process.
- \* Translation of assembly code to machine code is performed by assembler.



Library file creation and usage :- Libraries are specially formatted, ordered collections of object modules that may be used by the linker at a later time.

Linker and Locator :- Linker and Locator is another software utility responsible for linking the various object modules in a multi-module project and assigning absolute address to each module.

Object to hex file converter :- This is the final stage in the conversion of Assembly language (mnemonics) to machine understandable language.

### Advantages :-

- \* Efficient Code Memory and Data Memory usage (Memory optimisation) :- Since the developer is well versed with the target processor architecture and memory organisation, optimised code can be written for performing operations.
- \* High performance :- Optimised code not only improves the code memory usage but also improves the total system performance.

- \* Low Level Hardware Access :- Most of the code for low level programming like accessing external device specific registers from the operating system kernel, device drivers, and low level interrupt routines etc.
- \* Code Reverse Engineering :- Reverse engineering is the process of understanding the technology behind a product by extracting the information from a finished product.

### Drawbacks :-

- \* High Development Time :- Assembly language is much harder to program than high level languages. The developer must pay attention to more details and must have thorough knowledge of the architecture, memory organisation and register details of the target processor in use.
- \* Developer Dependency :- There is no common written rule for developing assembly language based applications whereas all high level languages instruct certain set of rules for application development.
- \* Non-portable :- The applications written in assembly instruction are valid only for that particular family of processors.

### (ii) High Level Language Based Development :-

- \* High level language (c, c++ or java) with a supported cross compiler for the target processor can be used for embedded firmware development.
- \* The various steps involved in high level language based embedded firmware development is shown in figure.
- \* The cross-compilers for different high level languages for the same target processor are different.
- \* It should be noted that each high level language should have a cross-compiler for converting the high level source code into the target processor machine code.



Fig:- High level language to machine language conversion process.

### \* Advantages :-

- Reduced Development Time :- Developer requires less or little knowledge on the internal hardware details and architecture of the target processor/controller.
- Developer Independence :- The syntax used by most of the high level languages are universal and a program written in the high level language can easily be understood by a second person knowing the syntax of the language.
- Portability :- An application written in high level language for a particular target processor can easily be converted to another target processor/controller/application.

\* Limitation :- Some Cross-Compilers available for high level languages may not be so efficient in generating optimized target processor specific instruction.



(iii) Mixing Assembly and High level language :-

- \* certain embedded firmware development situations may demand the mixing of high level language with Assembly and vice versa.
- \* high level language and assembly languages are usually mixed in three ways; namely
  - a) Mixing Assembly language with high level language
  - b) Mixing High level language with Assembly
  - c) In-line Assembly programming.

a) Mixing Assembly with High level language :-

(Eg: Assembly language with 'c')

\* Mixing 'c' and assembly is little complicated in the sense - the programmer must be aware of how parameters are passed from the 'c' routine to Assembly and values are returned from Assembly routine to 'c' and how 'Assembly - routine' is invoked from the 'c' code.

b) Mixing High level language with Assembly :-

(Eg: 'c' with Assembly language)

Mixing the code written in a high level language like 'c' and Assembly language is useful in the following scenarios:

- (i) The source code is already available in Assembly language and a routine written in a high level language like 'c' needs to be included to the existing code.
- (ii) The entire source code is planned in Assembly code for various reasons like optimised code, optimal performance, efficient code memory etc.

(iii) To include built in library functions written in 'c' language provided by the cross compiler.

④ Inline Assembly,

- \* Inline assembly is another technique for inserting target processor/controller specific Assembly instructions at any location of a source code written in high level language 'c'.
  - \* This avoids the delay in calling an assembly routine from a 'c' code.
  - \* Special keywords are used to indicate the start and end of Assembly instructions.
-

## ISR CONCEPT :-

- \* Interrupt means event, which invites the attention of processor for some action on the hardware or software event.
- 1. When a device or port is ready, a device or port generates an interrupt or when it completes the assigned action, it generates an interrupt. This interrupt is called hardware interrupt.
- 2. When software run-time exception condition is detected, either processor h/w or a s/w instruction generates an interrupt. This interrupt is called software interrupt or trap or exception.
- \* In response to the interrupt, the routine or programs, which is running at present gets interrupted and an ISR is executed.

## Features of ISR :-

1. An ISR call due to interrupt executes an event. Event can occur at any moment and event occurrences are asynchronous.
2. ISR call is event-based diversion from the current sequence of instructions to the another sequence of instructions. This sequence of instructions executes till the return instruction.
3. Event can be a device or port event or s/w computational exceptional condition detected by h/w or detected by program, which throws the exception.
4. An event can be signalled by S/w interrupt instruction SWI used by device driving functions create(), open(), etc.
5. An interrupt service mechanism exists in a system to call the ISRs from multiple sources.
6. Diversion to ISR may or may not take place on finishing the execution of any instruction in the presently running routine.

## INTERRUPT SOURCES :-

- \* Hardware sources can be from internal device or external peripherals, which interrupt the ongoing routine and thereby cause diversion to Corresponding ISR.
- \* Software sources for interrupt are related to
  - (i) processor detecting computational error for an illegal op-code during execution or
  - (ii) execution of an SWI instruction to cause processor-interrupt of ongoing routine .

\* There may be some other special types of Sources provided in the system also

### 1. Hardware Interrupt Related to Internal Device :-

There are no of h/w interrupt sources which can interrupt an ongoing program. These are processor or microcontroller or internal device h/w specific

Ex:- parallel port, UART serial received port 3. Synchronous receiver byte completion, ADC start of conversion, ADC end, etc

### 2. Hardware Interrupt Related to External Devices -1 :-

There can be external hardware interrupt source for interrupting an ongoing program that also provides the ISR address or vector address or interrupt-type information through the data bus.

Ex:- INTR in 8086 and 80X86.

### 3. Hardware Interrupt Related to External Devices -2 :-

External hardware-interrupt with their ISR vector address are processor or microcontroller-specific interrupt of an ongoing program. External interrupt source does not send interrupt-type or ISR address-related information.

Ex:- Non-maskable pin, within first few clock cycles unmaskable declarable pin but otherwise maskable, Maskable pin [In 8086 INTO & ZN03]

4. Software Error-Related Hardware interrupt :- There can be the software-error related interrupt generated by processor hardware. Each processor has a specific instruction set. It is designed for that set only.

\* An illegal code (instruction in the s/w) is an instruction, which does not correspond to any instruction in this set. Whenever the processor fetches illegal code, an interrupt occurs in certain processors. The error-related interrupts are also called hardware-generated software traps (or software exceptions).

Ex:- Division by zero detection (or trap) by hardware, over-flow by h/w, under flow by h/w, Illegal op code by h/w.

5. Software Instructions-Related Interrupt Sources :- A program can also handle specific computational errors or run-time conditions or signaling some conditions. Processors provide for software instructions related to the traps, signals or exceptions.

- (i) There are certain software instructions for interrupting and then diverting to the ISR also called the signal handler. They are used for signalling to another routine from an ongoing routine or task or thread.
- (ii) Software instructions are also used for trapping some run-time error conditions and executing exceptional handles on catching the exceptions.

### INTERRUPT SERVICING (HANDLING) MECHANISM :-

- \* Each system has an interrupt servicing (handling) mechanisms.
  - \* The OS also provides for mechanisms for interrupt-handling.
- (i) Interrupt vector :-
- \* Interrupt vector is a memory address to which the processor vectors.
  - \* The processor transfers the program counter to the interrupt vector new address on an interrupt.
  - \* Using this address, the processor services that interrupt by executing corresponding ISR.

→ Vectoring is as per the provisions in interrupt-handling mechanisms.

The various mechanisms are as follows:

#### Processor Vectoring to the ISR-VECTADDR :-

- \* On an interrupt, a processor vectors to a new address, ISR-VECTADDR.
  - \* It means that the PC (Program Counter), which has the instruction address of next instruction, saves that address on stack or in some CPU register, called link register and the processor loads the ISR-VECTADDR into the PC.
  - \* The stack pointer register of CPU provides the saved address to enable return from the ISR using the stack.
- A processor provides for one of the following ways of using the ISR-VECTADDR based addressing mechanisms.

#### Processor Vector Address

1. A system has internal devices like the on-chip timer and A/D converter. In a given microcontroller, each internal device interrupt source or source-group has a separate ISR-VECTADDR address. Each external interrupt-pin has separate ISR-VECTADDR.
2. In 80x86 processor architecture, a software instruction, for example, INT n explicitly also defines the type of interrupt and the type defines the ISR-VECTADDR. This mechanism results in the handling of n number of exception handling routines or ISRs for n interrupt types.
3. In ARM processor architecture, the software instruction SWI does not explicitly define the type of interrupt for generating different vector addresses and instead there is a common ISR-VECTADDR for each exception or signal or trap generated using SWI instruction.

## A group of Interrupt sources having Common Vector Address :-

(7)

A source group in the hardware may have the same ISR-VECTADDR.

There are two types of handling mechanisms in microcontroller hardware. The processor-handling mechanism provides for fetching into the PC either

(i) the ISR instruction at the ISR-VECTADDR or

(ii) the ISR address from the bytes at the ISR-VECTADDR.

Interrupt Vector Table :- System software designer must provide for specifying the bytes at each ISR-VECTADDR address.

- The bytes are for either ISR short code or jump instruction to the ISR first instruction
- or ISR short code with call to the full code of the ISR or for fetching the bytes for finding the ISR address.

## Classification of Interrupt :-

There are three types of interrupt sources in a system

1. Non-maskable : Examples are RAM parity error in a PC and error interrupts like division by zero. These must be serviced.
2. Maskable : maskable interrupts are those for which service may be temporarily disable to let high priority ISRs be executed first uninterrupted.
3. Non-maskable only when defined so within few clock cycles after reset:  
for example, an external interrupt pin, XIRQ interrupt, in 68HC11.  
XIRQ is non-maskable only when defined so within few clock cycles after 68HC11 is reset.

## MULTIPLE INTERRUPTS :-

Multiple Interrupt Calls :- when there are multiple interrupt sources, each occurrence of interrupt from a source (or source group) is identifiable from a bit in the status register and/or in the IPR (interrupt-pending register)

\* There can be interrupt service calls in succession till higher priority interrupt sources activate in succession. Then return from high priority ISR is to lower priority pending ISR.

Let us understand two processor interrupt service mechanisms for the case of multiple interrupts.

1. Certain processors do not provide for in-between routine diversion to higher priority interrupt and presume that all interrupts or interrupt of priority greater than the presently running routine are masked till the end of the routine.
2. Certain processors permit in-between routine diversion to higher priority interrupts. These processors provide, in order to prevent diversion in-between, a mechanism as follows: There is provisioning for masking of all interrupt by a primary level bit. These processors also provision selective diversion by provisioning for masking the interrupt service selectively by secondary-level bits.

Hardware Assigned priorities :- There is assigned priority order by hardware

\* ARM7 provides for two types of external interrupt sources (Request), IRQs and FIQs (Fast interrupts)  
\* 8051 provides for priority order in order of interrupt vector address. Lower address has highest and higher has the lower priority.

\* Interrupt in 80x86 are assigned priority order according to interrupt-types. Interrupt of type '0' has highest priority and '220' has lowest assigned priority.

## Direct Memory Access :-

- \* The DMA is used to transfer data between hard disk system memory.
- \* When the I/O's are needed for large amount data from a peripheral device to the memory address in the system or large amount of data is to be transferred by the I/O's, the interrupt-based mechanism is not suitable.
- \* A DMA facilitates a multi-byte data set or a burst of data or a block of data transfer between the external device and system or between two systems.
- \* The device DMAC (DMA controller) data transfer occurs efficiently b/w the I/O device and system memory.
- \* The following fig. shows the interconnections using the DMAC. It also shows the buses and control signals b/w the processor, memory, DMAC and data-transfer-I/O device.



System buses not accessible by processor internal address and data bytes during acknowledge active.

Fig: The buses and control signals between the processor, memory, DMA controller and data-transferring I/O device.

- \* The DMAC sends a hold request to the CPU and the CPU acknowledges that if the system memory buses are free to use.
- \* Three modes are usually supported in DMA operations.
  - (i) Single transfer at a time and then release IO bus hold on the system bus after each transfer.
  - (ii) Burst transfer at a time and then release of the IO bus hold on the system bus. A burst may be of a few kilobytes.
  - (iii) Bulk transfer and then release of the IO bus hold on the system bus only after the transfer is completed

### Use of DMAC:-

Whenever a DMA request is made to the DMAC for the I/O's, the DMAC is first initialized. It is programmed for

- (i) Read or write
- (ii) mode (bytes, burst or bulk) of DMA transfer
- (iii) Total No of bytes to be transferred and
- (iv) starting memory address.

- \* whenever a DMA request by the external device is made to the DMAC, the CPU is requested the DMA transfer by DMAC at the start to initiate the DMA and at the end to notify the end of the DMA by DMAC
- \* A DMAC may also provide memory access to multiple channels.

## Device Driver programming:-

- \* A system has no of physical devices. A device may have multiple functions. Each device function requires a driver.
- \* Examples of multiple functions in a device are as follows.
  - (i) A timer device performs timing functions as well as counting functions. It also performs the delay function and periodic system calls.
  - (ii) A transceiver device transmit as well as receives.
  - (iii) voice-data-fax modem device has transmitting as well as receiving functions for voice, fax as well as data.
- \* The driver has following features
  - (i) The driver provides a software layer (Interface) between the application and actual device: when running an application, the device are used. A driver provides a routine that facilitates the use of a device function in the application.
  - (ii) The driver facilitates the use of a device by executing an ISR; Simple commands from a task or function can then drive the device. Once a driver function is available for writing the code, the application developer do not need to know anything about the mechanism, address, registers, bits and flags used by the device.

Ex:- For mailing system ~~by direct~~ <sup>layer</sup>  
Network interface card is used

Ex:- the system clock is to be set to tick every 10,000 us.

- \* Generic device driver functions in high level language are used in high level language programs. The functions are open, close, read, write, listen, accept etc.
  - \* Device driver ISR programming in assembly needs an understanding of the processor, system and I/O buses and the addresses of the device register in the specific hardware.
- Writing physical Device - Driving ISRs in a System
- Virtual Device Drivers
  - parallel port Drivers in a System
  - serial port drivers in a System
  - Device Drivers for Internal Programmable Timing Devices
  - Linux Internals as Device Drivers and Network functions.

## Programming in Embedded C :-

- \* Whenever the conventional 'c' language and its extensions are used for programming embedded systems, it is referred as 'Embedded c' program.
- \* Desktop application development using 'c' language for a particular OS platform.
- \* Desktop computers contains working memory in the range of Megabytes and storage memory in the range of Gigabytes.
- \* Embedded systems are limited in both storage and working memory resources.

## '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 as well as business package developments.
- \* The conventional 'c' language follows ANSI standard and it incorporates various library files for different operating systems.
- \* A platforms (Operating system) specific application, known as Compiler is used for the conversion of programs written in 'C' to the target processor specific binary files.
- \* Hence it is 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.
- \* 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).
- \* The standard ANSI 'C' library implementation is always tailored to the target processor/controller library files in Embedded 'C'.

Compiler vs 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.
- \* The development is platform specific.
- \* Compilers are generally termed as 'Native compilers'.
- \* 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.

(41)

\* In cross-platform development, the compiler running on a particular target processor/as 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 OS which is different from the current development environment OS.

- \* Example is Embedded system development with Intel/AMD.
- \* Keil 51 is an example of Cross-compiler

— — .

## EMBEDDED FIRMWARE DESIGN

### 1. Embedded firmware design approaches

The firmware design approaches for Embedded product is purely dependent on the Complexity of the functions to be performed, the Speed of operation required, etc.

\* Two basic approaches are used for Embedded firmware design.

(i) Conventional procedural Based firmware Design (or)

Super loop Based Approach.

(ii) Embedded Operating System (OS) Based Designs.

(i) The Super loop Based Approach

\* The Super loop based firmware development approach is adopted for applications that are not time critical and where the response time is not so important.

\* In this the code is executed task by task, the task listed at the top of the program code is executed first and the tasks just below the top are execute after completing the first task.

\* The tasks are running inside an infinite loop, the only way to come out of the loop is either a hardware reset or an interrupt assertion.

\* Hardware reset brings the program execution back to the main loop.

\* Interrupt request suspends the task execution temporarily and it requests the task execution from the point where it got interrupted.

\* It doesn't require an Operating System.

\* In this design, the priorities are fixed and the Order in which the tasks to be executed are also fixed.

- \* This type of design is deployed in low-cost embedded products and products where response time is not time critical.
- \* For example, reading/writing data to and from a card using a card reader requires a sequence of operations like checking the presence of card, authenticating the operation, reading/writing, etc.
- \* A typical example for a Super Loop based product is an electronic video game-toy containing keypad and display unit.

### Drawbacks

- \* Any failure in any part of a single task will affect the total system.
- \* If the program hangs up at some while executing a task, it will require HW and SW watchdog timer (WDTs), may cause additional HW cost and firmware overheads.

### (ii) The Embedded Operating System (os) Based Approach :-

- \* The operating system (os) based approach contains operating systems, which can be either a General/purpose operating system (GPOS) or a Real-time operating system (RTOS).
- \* The GPOS based system design is very similar to a conventional PC based applications development where the device contains an operating system (Windows/Linux).
- Eg:- Personal Digital Assistants (PDA's), Handheld/Portable devices & point of sales.
- \* RTOS based designs approach is employed in embedded products demanding real time response.
- \* It responsible for performing pre-emptive multitasking, scheduler for scheduling tasks, multiple threads etc.
- Eg:- Windows CE, psos, Vx Works, ThreadX, MicroC/OS-II, Embedded Linux, Symbian etc.

## Q. Embedded Firmware Development languages

- (i) Assembly language based Development
- (ii) High level language based Development
- (iii) Mixing Assembly and High level language

### (i) Assembly language based Development

- \* 'Assembly language' is the human readable notation of 'machine language', where as 'machine language' is a processor understandable language.
- \* Assembly language programming is the task of writing processor specific machine code in mnemonic form, converting the mnemonics into actual processor instructions (machine language) and associated data using an assembler.
- \* Each line of an assembly language programs is split into four fields as given as

| LABEL | OPCODE | OPERAND | COMMENTS |
|-------|--------|---------|----------|
|-------|--------|---------|----------|

- \* A 'LABEL' is an optional field, is commonly used for representing a memory location, address of a program, sub-routine, code portion etc.
- \* The opcode tells the processor / controller what to do and the operands provide the data and information required to perform the action specified by the opcode.
- \* The assembly language program written in assembly code is saved as .asm (Assembly file) file or an .src (source) file.
- \* The following figure shows the assembly language to machine language conversion process.
- \* Translation of assembly code to machine code is performed by assembler.



fig:- Assembly language to machine language conversion process

Library file creation using and Usage :- libraries are specially formatted, ordered programs collection of object modules that may be used by the linker at a later time.

Linker and Locator :- Linker and locator is another software utility responsible for linking the various object modules in a multi-module project and assigning absolute address to each module.

Object to hex file Converter :- This is the final stage in the conversion of Assembly language (mnemonics) to machine understandable language.

#### Advantages

- \* Efficient code Memory and data Memory usage (Memory optimisation) :- Since the developer is well versed with the target processor architecture and memory organisation, optimised code can be written for performing operations.
- \* High performance :- Optimised code not only improves the code memory usage but also improves the total system performance.
- \* Low level Hardware Access :- Most of the code for low level programming like accessing external device specific registers from the operating system kernel device drivers and low level interrupt routines etc.

\* Code Reverse Engineering :- Reverse Engineering is the process of understanding the technology behind a product by extracting the information from a finished product.

Drawbacks :-

- \* High Development Time :- Assembly language is much harder to program than high level languages. The developer must pay attention to more details and must have thorough knowledge of the architecture, memory organisation and register details of the target processor in use.
- \* Developer Dependency :- There is no common written rule for developing assembly language based applications whereas all high level languages instruct certain set of rules for application development.
- \* Non-Portable :- The applications written in assembly instructions are valid for that particular family of processor.

## (ii) High level language Based Development

- \* High level language (C, C++ or Java) with a supported cross compiler for the target processor can be used for Embedded firmware development.
- \* The various steps involved in high level language based Embedded firmware development is shown in figure.
- \* The cross-compilers for different high level languages for the same target processor are different.
- \* It should be noted that each high-level language should have a cross-compiler for converting the high-level source into the target processor machine code.



fig :- High level language to machine language conversion process.

### Advantages

- (i) Reduced Development Time :- Developer requires less or little knowledge on the internal hardware details and architecture of the target processor / controller.
- (ii) Developer Independence :- The syntax used by most of the high level languages are universal and a program written in the high level language can easily be understood by a second person knowing the syntax of the language.
- (iii) Portability :- An application written in high level language for a particular target processor can easily be converted to another target processor / control application.

Limitation :- Some Cross - Compilers available for high level languages may not be so efficient in generating optimised target processor specific instructions.

### (iii) Mixing Assembly and high level language

- \* Certain embedded firmware development situations may demand the mixing of high level language with Assembly and Vice Versa.
- \* High level language and assembly languages are usually mixed in three ways, namely

(a) Mixing Assembly language with High level language

(b) Mixing High level language with Assembly

(c) In-Line Assembly programming.

(a) Mixing Assembly language with High level language

(eg: Assembly language with 'c')

- \* Mixing 'c' and assembly is little complicated in the sense. The programmer must be aware of how parameters are passed from the 'c' routine to assembly and values are returned from assembly routine to 'c' and how 'Assembly - routine' is invoked from the 'c' code.

(b) Mixing high level language with Assembly

(eg: 'c' with assembly language)

Mixing the code written in a high level language like 'c' and assembly language is useful in the following scenarios:

(i) The source code is already available in assembly language and a routine written in a high level language like 'c' needs to be included to the ~~exist~~ existing code.

(ii) The entire source code is planned in Assembly code for various reasons like optimised code, optimal performance, efficient code memory etc.

(iii) To include built-in library functions written in 'c' language provided by the cross compiler.

### (c) In line assembly

- \* In line assembly is another technique for inserting target processor/controller specific Assembly instructions at any location of a source code written in high level language 'c'.
- \* This avoids the delay in calling an assembly routine from a 'c' code.
- \* Special keywords are used to indicate that the start and end of assembly instructions.

### ISR concept

- \* Interrupt means event, which invites the attention of processor for some action on the hardware or software event.
1. When a device or port is ready, a device or port generates an interrupt or when it completes the assigned action, it generates an interrupt. This interrupt is called hardware interrupt.
  2. When software run-time exception conditions is detected, either processor h/w or s/w instruction generates an interrupt. This interrupt is called Software interrupt or trap or exception.
- \* In response to the interrupt, the routine or program, which is running at present gets interrupted and an ISR is executed.

### Features of ISR

1. An ISR call due to interrupt executes an event. Event can occur at any moment and event occurrences are asynchronous.
2. ISR call is event-based diversion from the current sequence of instruction to the another sequence of instructions. This sequence of instructions executes till the return instruction.
3. Event can be a device or port event or s/w computational exceptional condition detected by h/w or detected by programs, which throws the exception.

4. An event can be signalled by SWI interrupt instruction SWI used in device driving functions create(), open(), etc.
5. An interrupt service mechanism exists in a system to call the ISR from multiple sources.
6. Diversion to ISR may or may not take place on finishing the execution of any instruction in the presently running routine.

### Interrupt Sources

- \* Hardware sources can be from internal devices or external peripherals, which interrupt the ongoing routine and thereby cause diversion to corresponding ISR.
- \* Software sources for interrupt are related to
  - (i) processor detecting computational error for an illegal op-code during execution or
  - (ii) execution of an SWI instruction to cause processor-interrupt of on going routine.
- \* There may be some other special types of sources provided in the system are

#### 1. Hardware Interrupts Related to Internal Devices

There are no. of H/w interrupt sources which can interrupt an on going program. These are processor or micro controller or internal devices h/w specific.

Eg:- Parallel port, UART serial receiver port, ADC start of conversion, ADC end, 3. synchronous receiver byte completion, Etc.

#### 2. Hardware Interrupts related to External Devices - I

There can be external hardware interrupt source for interrupting an on going program that also provides the ISR address or Vector address or interrupt-type information through the data bus.

Eg:- INTR in 8086 and 80X86.

### 3. Hardware interrupts Related to External Devices - 2

External hardware interrupts with their ISR vector address are process or microcontroller-specific interrupt of an on going program. External interruption - source does not send interrupt-type or ISR address-related information.

Ex:- Non-markable pin, within first few clock cycles Unmarkable declarable pin but otherwise markable, Markable pin [M-for] INT0&INT1]

### 4. Software Error - Related Hardware Interrupts

These can be the software-error related interrupts generated by processor hardware. Each processor has a specific instruction set. It is designed for that set only.

\* An illegal code (instruction in the SW) is an instruction, which does not correspond to any instruction in this set. Whenever the processor fetches illegal code, an interrupt occurs in certain processors. The error-related interrupts are also called hardware-generated software traps (or software exceptions).

Ex:- Division by zero detection (or trap) by hardware, over flow by b/w, Under flow by h/w, Illegal opcode by H/w.

### 5. Software Instruction - Related Interrupt Sources

A program can also handle specific computational errors or run-time conditions or signalling some conditions. Processors provide for software instructions related to the traps, signals or exceptions.

(i) There are certain software instructions for interrupting and then diverting to the ISR, also called the signal handler. These are used for signalling to another routine from an ongoing routine or task or thread.

(ii) Software instructions are also used for trapping some run-time error conditions and executing exceptional handlers on catching the exceptions.

## INTERRUPT SERVICING (HANDLING) MECHANISM

- \* Each system has an interrupt servicing (handling) Mechanism.
- \* The OS also provides for mechanism for interrupt handling.

### (i) Interrupt vector

- \* Interrupt Vector is a memory address to which the processor vectors.
  - \* The processor transfers the program counter to the interrupt vector new address on an interrupt.
  - \* Using this address, the processor services that interrupt by executing corresponding ISR.
  - \* Vectoring is as per the provisions in interrupt-handling mechanism.
- The various mechanisms are as follows:

#### Processor Vectors to the ISR - VECTADDR

- \* On an interrupt, a processor vectors to a new address, ISR-VECTADDR.
- \* It means that the PC (program Counter), which has the instruction address of next instruction, saves that address on stack or in some CPU register, called link register and the processor loads the ISR-VECTADDR into the PC.
- \* The stack pointer register of CPU provides the saved address to enable return from the ISR using the stack.

A processor provides for one of the following ways of using the ISR-VECTADDR based addressing mechanism.

#### Processor Vector Address

1. A system has internal devices like the on-chip timer and A/D converter.
- In a given micro controller, each internal device interrupt source or source-group has a separate ISR-VECTADDR address. Each external interrupt pin has separate ISR-VECTADDR.

2. In 8086 processor architecture, a software instruction, for example INT, explicitly also defines the type of interrupt and the type of defines the ISR-VECTADDR. This mechanism results in the handling of n no. of exception handling routine or ISRs for n interrupt types.

3. In ARM processor architecture, the software instruction SWI does not explicitly define the type of interrupt for generating different vector address and instead there by is a common ISR-VECTADDR for each exception or signal or trap generated using SWI instruction.

A group of interrupt sources having common Vector Address

A source group in the hardware may have the same ISR-VECTADDR. There are two types of handling mechanisms in processor hardware. The processor handling mechanism provides for fetching into the PC either.

- (i) The ISR instruction at the ISR-VECTADDR or
- (ii) The ISR address from the bytes at the ISR-VECTADDR.

Interrupt Vector Table :- System software designer must provide for specifying the bytes at each ISR-VECTADDR address.

\* The bytes are for either ISR short code or jump instruction to the ISR first instruction, or ISR short code with call to the full code of the ISR or for fetching the bytes for finding the ISR address.

Classification of Interrupt

There are three types of interrupt sources in a system.

1. Non-maskable : Examples are RAM parity error in a PC and error interrupts like division by zero. These must be serviced.
2. Maskable : Maskable interrupts are those for which service may be temporarily disable to let high priority ISRs be executed first uninterrupted.

3. Non-maskable only when defined so within few clock cycles after reset: For example, an external interrupt pin, XSRQ interrupt, in 68HC11. XSRQ interrupt is non-maskable only when defined so within few clock cycle after 68HC11 is reset.

## Multiple Interrupts

### Multiple Interrupt calls

When there are multiple interrupt sources, each occurrence of interrupt from a source (or source group) is identifiable from a bit in the status register and/or in the IPR (Interrupt-pending register).

- \* There can be interrupt service calls in succession case higher priority interrupt sources activate in succession. Then return from high priority ISR to lower priority pending ISR.

Let us understand two processor interrupt service mechanisms for the case of multiple interrupts.

1. Certain processors do not provide for in-between routine diversion to higher priority interrupts and presume that all interrupts of priority greater than the presently running routine are masked till the end of the routine.

2. Certain processors permit in-between routine diversion to higher priority interrupts. These processors provide, in order to prevent diversion in between, a mechanism as follows: There is provisioning for masking of all interrupts by a primary levels bit. These processors also provisions selective diversion by provisioning for masking the interrupt service selectively by secondary level bits.

## Hardware Assigned priorities

There is assigned priority order by hardware

- \* ARM7 provides for two types of external interrupt sources (request) IREQ and FIRQ (fast interrupt requests).
- \* 8051 provides for priority order in Order of interrupt Vector address. Lower address has highest and higher has the lower priority.
- \* Interrupts in 80x86 are assigned priority order according to interrupt-types. Interrupt of type '0' has highest priority and 225 has lowest assigned priority.

## Direct Memory Access

- \* The DMA is used to transfer data b/w hard disk system memory.
- \* When the I/O's are needed for large amount data from a peripheral device to the memory address in the system or large amount of data is to be transferred by the I/O's, the interrupt-based mechanism is not suitable.
- \* A DMA facilitates a multi-byte data set or a burst of data or a block of data transfer b/w the external device and system or b/w two systems.
- \* The Device DMAC (DMA controller) data transfer occurs efficiently b/w the I/O Devices and system memory.
- \* The following fig. shows the interconnections using the DMAC. It also shows the buses and control signals b/w the processor, memory, DMAC and data transferring I/O device.



System buses not accessible by processor internal address and data buses during acknowledge active.

fig: The buses and control signals between the processor, memory, DMA controller and data - transferring I/O device.

- \* The DMAC sends a hold request to the CPU and the CPU acknowledges that if the system memory buses are free to use.
- \* Three modes are usually supported in DMA operations.
  - (i) Single transfer at a time and then release I/O bus hold on the system bus after each transfer.
  - (ii) Burst transfer at a time and then release of the I/O bus hold on the system bus. A burst may be of a few kilobytes.
  - (iii) Bulk transfer and then release of the I/O bus hold on the system bus only after the transfer is completed.

## Use of DMA

Whenever a DMA request is made to the DMAC for the I/O's, the DMAC is first initialized. It is programmed for

- (i) read or write
- (ii) mode (bytes, burst or bulk) of DMA transfer
- (iii) Total No. of bytes to be transferred and
- (iv) starting memory address.

- \* Whenever a DMA request by the external device is made to the DMAC, the CPU is requested the DMA transfer by DMAC at the start to initiate the DMA and at the end to notify the end of the DMA by DMAC.
- \* A DMAC may also provide memory access to multiple channels.

## Device Driver programming

- \* A system has no. of physical devices, A device may have multiple functions. each device function requires a driver.
- \* Examples of multiple functions in a device are as follows.
  - (i) A timer device performs timing functions as well as counting functions. It also performs the delay function and periodic system calls.
  - (ii) A transceiver device transmits as well as receives.
  - (iii) Voice - data - fax modemu device has transmitting as well as receiving as functions for voice, fax as well as data.
- \* The drivers has following features
  - (i) The driver provides a software layer (interface) b/w the application and actual device: When running an application, the devices are used. A driver provides a routine that facilitates the use of a device function in the application.
  - Ex:- For mailing system b/w layers, Network interface card is used.

.. (ii) The driver facilitates the use of device by executing an ISR:

Simple commands from a task or function can then drive the device. Once a driver function is available for writing the codes, the application developer does not need to know anything about the mechanism, address, registers, bits and flags used by the device.

Ex:- The system clock is to be set to tick every 10,000μs.

- \* Generic device driver functions in high level language are used in high level language program. The functions are open, close, read, write, listen, accept etc.
- \* Device driver ISR programming in assembly needs an understanding of the processor, system and I/O buses and the addresses of the device register in the specific hardware.
  - Writing physical device - Driving ISRs in a system
  - Virtual Device drivers
  - Parallel port drivers in a system
  - Serial port drivers in a system
  - Device drivers for internal programmable timing devices.
  - Linux Internals as device drivers and Network functions.

### Programming in Embedded C

- \* Whenever the conventional 'c' language and its extensions are used for programming embedded systems, it is referred as "Embedded c" program.
- \* Desktop application development using 'c' language for a particular OS platform.
- \* Desktop computers contain working memory in the range of Megabytes and storage memory in the range of Gigabytes.
- \* Embedded systems are limited in which both storage and working memory resources.

## 'c' vs '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 as well as business packages developments.
- \* The conventional 'c' language follows ANSI standard and it incorporates various library files for different operating systems.
- \* A platform (os) specific application, known as Compiler is used for the conversion of program written in 'c' to the target processor specific binary files.
- \* Hence it is 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.
- \* The implementation of target processor/controller specific functions/instructions depends up on 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).
- \* The standard ANSI 'c' library implementation is always tailored to the target processor/controller library files in Embedded 'c'.

## Compiler Vs 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.
- \* The development is platform specific.
- \* Compilers are generally termed as 'Native Compilers'.
- \* 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 which 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 os which is different from the current development environment os.
- \* Example is Embedded system development with Intel / AMD.
- \* Kail 51 is an example of Cross - Compilers.