

ATRIA INSTITUTE OF TECHNOLOGY (Affiliated To Visvesvaraya Technological University, Belgaum) Anandanagar, Bangalore-24

# **DEPARTMENT OF ELECTRONICS AND COMMUNICATION**

# **EMBEDDED SYSTEMS LAB MANUAL**

SIXTH SEMESTER

**SUBJECT CODE: 18ECL66** 

2020-2021



### ATRIA INSTITUTE OF TECHNOLOGY (Affiliated To Visvesvaraya Technological University, Belgaum) Anandanagar, Bangalore-24

# DEPARTMENT OF ELECTRONICS AND COMMUNICATION

# EMBEDDED SYSTEMS LAB MANUAL

The Embedded Systems Laboratory Manual pertaining VI semester ECE has been prepared as per VTU syllabus and all the experiments are designed, tested and verified according to the experiment list.

This manual typically contains practical/lab sessions related to Embedded systems, implemented using LPC1768 kit and Keil Software in assembly level programming and embedded C programming language covering various aspects related to the subject for better understanding. Students are advised to thoroughly go through this manual as it provides them practical insights.

Good Luck

| SI No                | INDEA                                                                                             | Daga No  |
|----------------------|---------------------------------------------------------------------------------------------------|----------|
| <b>SI. INU.</b><br>1 | Tvaille<br>Embedded I ab Syllabus                                                                 | rage No. |
| 1                    | Enlocaded Lab Syllabus                                                                            | <u> </u> |
| 2                    | Introduction to AKM Cortex M5 Processor                                                           | 0        |
| 3                    | Taskrisslanssifications of LDC1769                                                                | 9        |
| 4                    |                                                                                                   | 10       |
|                      | raki a                                                                                            |          |
| 1                    | ALP to multiply two 16 bit binary numbers.                                                        | 26       |
| 2                    | ALP to find the sum of first 10 integers.                                                         | 27       |
| 3                    | ALP to find the number of 0's and 1's in a 32 bit data.                                           | 28       |
| 4                    | ALP to determine the given 16 bit number is ODD or EVEN.                                          | 30       |
| 5                    | ALP to write data in RAM.                                                                         | 32       |
|                      | PART B                                                                                            |          |
| 6                    | Interface a simple Switch and display its status through Relay, Buzzer and LED.                   | 35       |
| 7                    | Interface a Stepper motor and rotate it in clockwise and anti-clockwise direction.                | 37       |
| 8                    | Display the Hex digits 0 to F on a 7-segment LED interface, with an appropriate delay in between. | 40       |
| 9                    | Interface a DAC and generate Triangular and Square waveforms.                                     | 42       |
| 10                   | Display Hello World message using Internal UART.                                                  | 46       |
| 11                   | Demonstrate the use of an external interrupt to toggle an LED On/Off.                             | 51       |
| 12                   | Using the Internal PWM module of ARM controller generate PWM and vary its duty cycle.             | 55       |
| 13                   | Interface and Control a DC Motor.                                                                 | 59       |
| 14                   | Interface a 4×4 keyboard and display the key code on an LCD.                                      | 62       |
| 15                   | Measure Ambient temperature using a sensor and SPI ADC IC.                                        | 68       |
| 16                   | Interface 12 bit internal ADC to convert the analog to digital and display the same on LCD.       | 76       |

#### **DEPARTMENT VISION & MISSION**

#### VISION

To become a pioneer in developing competent professionals with societal and ethical values through transformational learning and interdisciplinary research in the field of Electronics and Communication Engineering.

#### MISSION

The department of Electronics and Communication is committed to:

M1: Offer quality technical education through experiential learning to produce competent engineering professionals.

M2: Encourage a culture of innovation and multidisciplinary research in collaboration with industries/universities.

**M3**: Develop interpersonal, intrapersonal, entrepreneurial and communication skills among students to enhance their employability.

**M4**: Create a congenial environment for the faculty and students to achieve their desired goals and to serve society by upholding ethical values.

#### EMBEDDED SYSTEM LAB SYLLABUS

 Sub Code:
 18ECL66

 Hrs/Week:
 03

 IA Marks:
 40

**Exam Hours**: 03 Hrs Exam **Marks**: 60 Marks

#### PART-A:

(Conduct the following experiments on an ARM CORTEX M3 evaluation board to learn ALP and using evaluation version of Embedded 'C' &Keil Uvision-4tool/compiler.)

1. ALP to multiply two 16 bit binary numbers.

2. ALP to find the sum of first 10 integers.

3. ALP to find the number of 0's and 1's in a 32 bit data.

4. ALP to determine the given 16 bit number is ODD or EVEN.

5. ALP to write data in RAM.

#### PART-B:

(Conduct the following experiments on an ARM CORTEX M3evaluation board using evaluation version of Embedded 'C' &Keil Uvision-4tool/compiler.)

6. Display "Hello World" message using Internal UART.

7. Interface and Control a DC Motor.

8. Interface a Stepper motor and rotate it in clockwise and anti-clockwisedirection.

9. Interface a DAC and generate Triangular and Square waveforms.

10. Interface a 4x4 keyboard and display the key code on an LCD.

11. Deonstrate the use of an external interrupt to toggle an LED On/Off.

12.Display the Hex digits 0 to F on a 7-segment LED interface, with an appropriate delay in between.

13. Measure Ambient temperature using a sensor and SPI ADC IC. **Beyond Syllabus:** 

i).Using the Internal PWM module of ARM controller generate PWM and vary itsduty cycle.

ii).Interface a simple Switch and display its status through Relay, Buzzer andLED.

#### **Conduction of Practical Examination:**

One question from PART A and One question from PART-B experiments to be asked in the practical examination.

#### **INTRODUCTION TO ARM Cortex M3 PROCESSOR**

#### **Introduction**

The ARM Cortex-M3 is a general purpose 32-bit microprocessor, which offers high performance and very low power consumption. The Cortex-M3 offers many new features, including a Thumb-2 instruction set, low interrupt latency, hardware divide, interruptible/continuable multiple load and store instructions, automatic state save and restore for interrupts, tightly integrated interrupt controller with Wake-up Interrupt Controller and multiple core buses capable of simultaneous accesses.

Pipeline techniques are employed so that all parts of the processing and memory systems can operate continuously. Typically, while one instruction is being executed, its successor is being decoded, and a third instruction is being fetched from memory.

The processor has a Harvard architecture, which means that it has a separate instruction bus and data bus. This allows instructions and data accesses to take place at the same time, and as a result of this, the performance of the processor increases because data accesses do not affect the instruction pipeline. This feature results in multiple bus interfaces on Cortex-M3, each with optimized usage and the ability to be used simultaneously. However, the instruction and data buses share the same memory space (a unified memory system). In other words, you cannot get 8 GB of memory space just because you have separate bus interfaces. A simplified block diagram of the Cortex-m3 architecture is shown below



It is worthwhile highlighting that the Cortex-M3 processor is not the first ARM processor to be used to create generic micro controllers. The venerable ARM7 processor has been very successful in this market, The Cortex-M3 processor builds on the success of the ARM7 processor to deliver devices that are significantly easier to program and debug and yet deliver a higher processing capability.

#### **Background of ARM architecture**

ARM was formed in 1990 as Advanced RISC Machines Ltd., a joint venture of Apple Computer, Acorn Computer Group, and VLSI Technology. In 1991, ARM introduced the ARM6 processor family, and VLSI

became the initial licensee. Subsequently, additional companies, including Texas Instruments, NEC, Sharp, and ST Microelectronics, licensed the ARM processor designs, extending the applications of ARM processors into mobile phones, computer hard disks, personal digital assistants (PDAs), home entertainment systems, and many other consumer products.

Nowadays, ARM partners ship in excess of 2 billion ARM processors each year. Unlike many semiconductor companies, ARM does not manufacture processors or sell the chips directly. Instead, ARM licenses the processor designs to business partners, including a majority of the world's leading semiconductor companies. Based on the ARM low-cost and power-efficient processor designs, these partners create their processors, micro controllers, and system-on-chip solutions. This business model is commonly called intellectual property (IP) licensing.

#### Architecture versions

Over the years, ARM has continued to develop new processors and system blocks. These include the popular ARM7TDMI processor and, more recently, the ARM1176TZ (F)-S processor, which is used in high-end applications such as smart phones. The evolution of features and enhancements to the processors over time has led to successive versions of the ARM architecture. Note that architecture version numbers are independent from processor names. For example, the ARM7TDMI processor is based on the ARMv4T architecture (the *T* is for *Thumb* instruction mode support).

The ARMv5E architecture was introduced with the ARM9E processor families, including the ARM926E-S and ARM946E-S processors. This architecture added "Enhanced" Digital Signal Processing (DSP) instructions for multimedia applications. With the arrival of the ARM11 processor family, the architecture was extended to the ARMv6. New features in this architecture included memory system features and Single Instruction–Multiple Data (SIMD) instructions. Processors based on the ARMv6 architecture include the ARM1136J (F)-S, the ARM1156T2 (F)-S, and the ARM1176JZ (F)-S.

Over the past several years, ARM extended its product portfolio by diversifying its CPU development, which resulted in the architecture version 7 or v7. In this version, the architecture design is divided into three profiles:

- > The *A profile* is designed for high-performance open application platforms.
- > The *R profile* is designed for high-end embedded systems in which real-time performance is needed.
- > The *M profile* is designed for deeply embedded micro controller-type systems.

Bit more details on these profiles

*A Profile (ARMv7-A)*: Application processors which are designed to handle complex applications such as high-end embedded operating systems (OSs) (e.g., Symbian, Linux, and Windows Embedded). These processors requiring the highest processing power, virtual memory system support with memory management units (MMUs), and, optionally, enhanced Java support and a secure program execution environment. Example products include high-end mobile phones and electronic wallets for financial transactions.

*R Profile (ARMv7-R)*: Real-time, high-performance processors targeted primarily at the higher end of the real-time market, those applications, such as high-end breaking systems and hard drive controllers, in which high processing power and high reliability are essential and for which low latency is important.

*M* Profile (ARMv7-M): Processors targeting low-cost applications in which processing efficiency is important and cost, power consumption, low interrupt latency, and ease of use are critical, as well as industrial control applications, including real-time control systems. The Cortex processor families are the first products developed on architecture v7, and the Cortex- M3 processor is based on one profile of the v7 architecture, called ARM v7-M, an architecture specification for micro controller products.

Below figure shows the development stages of ARM versions



#### Architecture

The Thumb-2 technology extended the Thumb Instruction Set Architecture (ISA) into a highly efficient and powerful instruction set that delivers significant benefits in terms of ease of use, code size, and performance. The extended instruction set in Thumb-2 is a super set of the previous 16-bit Thumb instruction set, with additional 16-bit instructions alongside 32-bit instructions. It allows more complex operations to be carried out in the Thumb state, thus allowing higher efficiency by reducing the number of states switching between ARM state and Thumb state.

Focused on small memory system devices such as micro controllers and reducing the size of the processor, the Cortex-M3 supports only the Thumb-2 (and traditional Thumb) instruction set. Instead of using ARM instructions for some operations, as in traditional ARM processors, it uses the Thumb-2 instruction set for all operations. As a result, the Cortex-M3 processor is not backward compatible with traditional ARM processors.

Nevertheless, the Cortex-M3 processor can execute almost all the 16-bit Thumb instructions, including all 16bit Thumb instructions supported on ARM7 family processors, making application porting easy. With support for both 16-bit and 32-bit instructions in the Thumb-2 instruction set, there is no need to switch the processor between Thumb state (16-bit instructions) and ARM state (32-bit instructions). For example, in ARM7 or ARM9 family processors, you might need to switch to ARM state if you want to carry out complex calculations or a large number of conditional operations and good performance is needed, whereas in the Cortex-M3 processor, you can mix 32-bit instructions with 16-bit instructions without switching state, getting high code density and high performance with no extra complexity.

The Thumb-2 instruction set is a very important feature of the ARMv7 architecture. Compared with the instructions supported on ARM7 family processors (ARMv4T architecture), the Cortex-M3 processor instruction set has a large number of new features. For the first time, hardware divide instruction is available on an ARM processor, and a number of multiply instructions are also available on the Cortex-M3 processor to improve data-crunching performance. The Cortex-M3 processor also supports unaligned data accesses, a feature previously available only in high-end processors.

#### **Applications of Cortex M3 processors**

- Low-cost micro controllers:
- AutomotiveIndustry
- Data communications
- Industrial control applications
- Consumer products:



#### The Cortex-M3 Processor versus Cortex-M3-Based Micro Controllers

The Cortex-M3 processor is the central processing unit (CPU) of a micro controller chip. In addition, a number of other components are required for the whole Cortex-M3 processor-based micro controller. After chip manufacturers license the Cortex-M3 processor, they can put the Cortex-M3 processor in their silicon designs, adding memory, peripherals, input/output (I/O), and other features. Cortex-M3 processor-based chips from different manufacturers will have different memory sizes, types, peripherals, and features.

#### **INTRODUCTION TO MICRO CONTROLLER LPC1768**

#### Architectural Overview

The LPC1768FBD100 is an ARM Cortex-M3 based micro controller for embedded applications requiring a high level of integration and low power dissipation. The ARM Cortex-M3 is a next generation core that offers system enhancements such as modernized debug features and a higher level of support block integration. LPC1768 operate up to 100 MHz CPU frequency.

The peripheral complement of the LPC1768 includes up to 512 kilo bytes of flash memory, up to 64KB of data memory, Ethernet MAC, a USB interface that can be configured as either Host, Device, or OTG, 8 channel general purpose DMA controller, 4 UARTs, 2 CAN channels, 2 SSP controllers, SPI interface, 3 I2C interfaces, 2-input plus 2-output I2S interface, 8 channel 12-bit ADC, 10-bit DAC, motor control PWM, Quadrature Encoder interface, 4 general purpose timers, 6-output general purpose PWM, ultra-low power RTC with separate battery supply, and up to 70 general purpose I/O pins.

The LPC1768 use a multi layer AHB(Advanced High Performance Bus) matrix to connect the ARM Cortex-M3 buses and other bus masters to peripherals in a flexible manner that optimizes performance by allowing peripherals that are on different slaves ports of the matrix to be accessed simultaneously by different bus masters.

#### **On-chip flash memory system**

The LPC1768 contains up to 512 KB of on-chip flash memory. A flash memory accelerator maximizes performance for use with the two fast AHB Lite buses. This memory may be used for both code and data storage. Programming of the flash memory may be accomplished in several ways. It may be programmed In System via the serial port. The application program may also erase and/or program the flash while the application is running, allowing a great degree of flexibility for data storage field firmware upgrades, etc.

#### **On-chip Static RAM**

The LPC1768 contains up to 64 KB of on-chip static RAM memory. Up to 32 KB of SRAM, accessible by the CPU and all three DMA controllers are on a higher-speed bus. Devices containing more than 32 KB SRAM have two additional 16 KB SRAM blocks, each situated on separate slave ports on the AHB multilayer matrix. This architecture allows the possibility for CPU and DMA accesses to be separated in such a way that there are few or no delays for the bus masters.

#### **Block Diagram of LPC1768**



#### A brief description of the blocks:

#### Nested vector interrupt controller

The NVIC is an integral part of the Cortex-M3. The tight coupling to the CPU allows for low interrupt latency and efficient processing of late arriving interrupts.

#### Features

- > Controls system exceptions and peripheral interrupts
- > In the LPC1768, the NVIC supports 33 vectored interrupts
- > 32 programmable interrupt priority levels, with hardware priority level masking
- Relocatable vector table
- Non-Maskable Interrupt (NMI)
- Software interrupt generation

#### Interrupt sources

Each peripheral device has one interrupt line connected to the NVIC but may have several interrupt flags. Individual interrupt flags may also represent more than one interrupt source.

Any pin on Port 0 and Port 2 (total of 42 pins) regardless of the selected function, can be programmed to generate an interrupt on a rising edge, a falling edge, or both.

#### General purpose DMA controller

The GPDMA (General Purpose Direct Memory Access) is an AMBA AHB (Advanced Micro controller Bus Architecture Advance high performance bus) compliant peripheral allowing selected peripherals to have DMA support.

The GPDMA enables peripheral-to-memory, memory-to-peripheral, peripheral-to-peripheral, and memory-tomemory transactions. The source and destination areas can each be either a memory region or a peripheral, and can be accessed through the AHB master. The GPDMA controller allows data transfers between the USB and Ethernet controllers and the various on-chip SRAM areas. The supported APB peripherals are SSP0/1, all UARTs, the I2S-bus interface, the ADC, and the DAC. Two match signals for each timer can be used to trigger DMA transfers.

#### **Function Configuration block**

The selected pins of the micro controller to have more than one function. Configuration registers control the multiplexers to allow connection between the pin and the on-chip peripherals. Peripherals should be connected to the appropriate pins prior to being activated and prior to any related interrupt(s) being enabled.

Activity of any enabled peripheral function that is not mapped to a related pin should be considered undefined. Most pins can also be configured as open-drain outputs or to have a pull-up, pull-down, or no resistor enabled.

#### Fast general purpose parallel I/O

Device pins that are not connected to a specific peripheral function are controlled by the GPIO registers. Pins may be dynamically configured as inputs or outputs. Separate registers allow setting or clearing any number of outputs simultaneously. The value of the output register may be read back as well as the current state of the port pins.

#### **USB** interface

The Universal Serial Bus (USB) is a 4-wire bus that supports communication between a host and one or more (up to 127) peripherals. The host controller allocates the USB bandwidth to attached devices through a tokenbased protocol. The bus supports hot plugging and dynamic configuration of the devices. All transactions are initiated by the host controller.

The USB interface includes a device, Host, and OTG controller with on-chip PHY for device and Host functions. The OTG switching protocol is supported through the use of an external controller.

**USB device controller** enables 12 Mbit/s data exchange with a USB Host controller. It consists of a register interface, serial interface engine, endpoint buffer memory, and a DMA controller. The serial interface engine decodes the USB data stream and writes data to the appropriate endpoint buffer. The status of a completed USB transfer or error condition is indicated via status registers. An interrupt is also generated if enabled. When enabled, the DMA controller transfers data between the endpoint buffer and the on-chip SRAM.

#### 12-bit ADC

The LPC1768 contain a single 12-bit successive approximation ADC with eight channels and DMA support. **10-bit DAC** 

The DAC allows to generate a variable analog output. The maximum output value of the DAC is VREFP. **UART's** 

The LPC1768 contain four UART's. In addition to standard transmit and receive data lines, UART1 also provides a full modem control handshake interface and support for RS-485/9-bit mode allowing both software address detection and automatic address detection using 9-bit mode.

The UART's include a fractional baud rate generator. Standard baud rates such as 115200 Baud can be achieved with any crystal frequency above 2 MHz

#### SPI serial I/O controller

The LPC1768 contain one SPI controller. SPI is a full duplex serial interface designed to handle multiple masters and slaves connected to a given bus. Only a single master and a single slave can communicate on the interface during a given data transfer. During a data transfer the master always sends 8 bits to 16 bits of data to the slave, and the slave always sends 8 bits to 16 bits of data to the master.

#### SSP serial I/O controller

The LPC1768 contain two SSP controllers. The SSP controller is capable of operation on a SPI, 4-wire SSI, or Micro wire bus. It can interact with multiple masters and slaves on the bus. Only a single master and a single slave can communicate on the bus during a given data transfer. The SSP supports full duplex transfers, with frames of 4 bits to 16 bits of data flowing from the master to the slave and from the slave to the master. In practice, often only one of these data flows carries meaningful data.

#### I2C-bus serial I/O controllers

The LPC1768 each contain three I2C-bus controllers. The I2C-bus is bidirectional for inter-IC control using only two wires: a Serial Clock line (SCL) and a Serial DAta line (SDA). Each device is recognized by a unique address and can operate as either a receiver-only device or a transmitter with the capability to both receive and send information (such as memory). Transmitters and/or receivers can operate in either master or slave mode, depending on whether the chip has to initiate a data transfer or is only addressed. The I2C is a multi-master bus and can be controlled by more than one bus master connected to it.

#### General purpose 32-bit timers/external event counters

The LPC1768 include four 32-bit timer/counters. The timer/counter is designed to count cycles of the system derived clock or an externally-supplied clock. It can optionally generate interrupts, generate timed DMA requests, or perform other actions at specified timer values, based on four match registers. Each timer/counter also includes two capture inputs to trap the timer value when an input signal transitions, optionally generating an interrupt.

#### Pulse width modulator

The PWM is based on the standard Timer block and inherits all of its features, although only the PWM function is pinned out on the LPC1768. The Timer is designed to count cycles of the system derived clock and optionally switch pins, generate interrupts or perform other actions when specified timer values occur, based on seven match registers. The PWM function is in addition to these features, and is based on match register events.

#### Watchdog timer

The purpose of the watchdog is to reset the micro controller within a reasonable amount of time if it enters an

erroneous state. When enabled, the watchdog will generate a system reset if the user program fails to 'feed' (or reload) the watchdog within a predetermined amount of time.

#### **RTC and backup registers**

The RTC is a set of counters for measuring time when system power is on, and optionally when it is off. The RTC on the LPC1768 is designed to have extremely low power consumption, i.e. less than 1 uA. The RTC will typically run from the main chip power supply, conserving battery power while the rest of the device is powered up. When operating from a battery, the RTC will continue working down to 2.1 V. Battery power can be provided from a standard 3 V Lithium button cell.

An ultra-low power 32 kHz oscillator will provide a 1 Hz clock to the time counting portion of the RTC, moving most of the power consumption out of the time counting function.

#### **Clocking and Power Control**

#### **Crystal oscillators**

The LPC1768 include three independent oscillators. These are the main oscillator, the IRC oscillator, and the RTC oscillator. Each oscillator can be used for more than one purpose as required in a particular application. Any of the three clock sources can be chosen by software to drive the main PLL and ultimately the CPU.

Following reset, the LPC1768 will operate from the Internal RC oscillator until switched by software. This allows systems to operate without any external crystal and the boot loader code to operate at a known frequency.

#### **Power control**

The LPC1768 support a variety of power control features. There are four special modes of processor power reduction: Sleep mode, Deep-sleep mode, Power-down mode, and Deep power-down mode. The CPU clock rate may also be controlled as needed by changing clock sources, reconfiguring PLL values, and/or altering the CPU clock divider value. This allows a trade-off of power versus processing speed based on application requirements. In addition, Peripheral Power Control allows shutting down the clocks to individual on-chip peripherals, allowing fine tuning of power consumption by eliminating all dynamic power use in any peripherals that are not required for the application. Each of the peripherals has its own clock divider which provides even better power control.

Integrated PMU (Power Management Unit) automatically adjust internal regulators to minimize power consumption during Sleep, Deep sleep, Power-down, and Deep power- down modes.

The LPC1768 also implement a separate power domain to allow turning off power to the bulk of the device while maintaining operation of the RTC and a small set of registers for storing data during any of the power-down modes.

Clock generation block diagram for LPC1768 is shown below



#### System Control Reset

Reset has four sources on the LPC1768: the RESET pin, the Watchdog reset, power-on reset (POR), and the Brown-Out Detection (BOD) circuit.

The RESET pin is a Schmitt trigger input pin. Assertion of chip Reset by any source, once the operating voltage attains a usable level, causes the RSTOUT pin to go LOW. Once reset is de-asserted, or, in case of a BOD- triggered reset, once the voltage rises above the BOD threshold, the RSTOUT pin goes HIGH. In other words RSTOUT is high when the controller is in its active state.

#### **Emulation and debugging**

Debug and trace functions are integrated into the ARM Cortex-M3. Serial wire debug and trace functions are supported in addition to a standard JTAG debug and parallel trace functions. The ARM Cortex-M3 is configured to support up to eight breakpoints and four watch points.

**Note:** For further details on Controller blocks refer the User manual of LPC176x/5x – UM10360 available at <u>www.nxp.com</u>

#### **TECHNICAL SPECIFICATIONS of LPC1768**

#### Specifications of LPC1768:

- ARM Cortex-M3 processor runs up to 100 MHz frequency.
- > ARM Cortex-M3 built-in Nested Vectored Interrupt Controller (NVIC).
- ➢ Up to 512kB on-chip flash program memory with In-System Programming (ISP) and In-Application Programming (IAP) capabilities. The combination of an enhanced flash memory accelerator and location of the flash memory on the CPU local code/data bus provides high code performance from flash.
- > Up to 64kB on-chip SRAM includes:
  - Up to 32kB of SRAM on the CPU with local code/data bus for high-performance CPU access.
  - Up to two 16kB SRAM blocks with separate access paths for higher throughput. These SRAM

blocks may be used for Ethernet, USB, and DMA memory, as well as for general purpose instruction and data storage.

- Eight channel General Purpose DMA controller (GPDMA) on the AHB multilayer matrix that can be used with the SSP, I2S, UART, the Analog-to-Digital and Digital-to-Analog converter peripherals, timer match signals, GPIO, and for memory-to-memory transfers.
- Serial interfaces:

- Ethernet MAC with RMII interface and dedicated DMA controller.

- USB 2.0 full-speed controller that can be configured for either device, Host, or OTG operation with an on-chip PHY for device and Host functions and a dedicated DMA controller.

- Four UART's with fractional baud rate generation, internal FIFO, IrDA, and DMA support. One UART has modem control I/O and RS-485/EIA-485 support.

- Two-channel CAN controller.

- Two SSP controllers with FIFO and multi-protocol capabilities. The SSP interfaces can be used with the GPDMA controller.

- SPI controller with synchronous, serial, full duplex communication and programmable data length. SPI is included as a legacy peripheral and can be used instead of SSP0.

- Three enhanced I2C-bus interfaces, one with an open-drain output supporting the full I2C

specification and Fast mode plus with data rates of 1Mbit/s, two with standard port pins. Enhancements include multiple address recognition and monitor mode.

- I2S (Inter-IC Sound) interface for digital audio input or output, with fractional rate control. The I2S interface can be used with the GPDMA. The I2S interface supports 3- wire data transmit and receive or 4-wire combined transmit and receive connections, as well as master clock output.

> Other peripherals:

 - 70 General Purpose I/O (GPIO) pins with configurable pull-up/down resistors, open drain mode, and repeater mode. All GPIOs are located on an AHB bus for fast access, and support Cortex-M3 bit-banding. GPIOs can be accessed by the General Purpose DMA Controller. Any pin of

ports 0 and 2 can be used to generate an interrupt. - 12-bit Analog-to-Digital Converter (ADC) with input multiplexing among eight pins, conversion rates up to 200 kHz, and multiple result registers. The 12-bit ADC can be used with the GPDMA controller.

- 10-bit Digital-to-Analog Converter (DAC) with dedicated conversion timer and DMA support.

- Four general purpose timers/counters, with a total of eight capture inputs and ten compare outputs. Each timer block has an external count input. Specific timer events can be selected to generate DMA requests.

- One motor control PWM with support for three-phase motor control.
- Quadrature encoder interface that can monitor one external quadrature encoder.
- One standard PWM/timer block with external count input.

- Real-Time Clock (RTC) with a separate power domain. The RTC is clocked by a dedicated RTC oscillator. The RTC block includes 20 bytes of battery-powered backup registers, allowing system status to be stored when the rest of the chip is powered off. Battery power can be supplied from a standard 3 V Lithium button cell. The RTC will continue working when the battery voltage drops to as

low as 2.1 V. An RTC interrupt can wake up the CPU from any reduced power mode.

- Watchdog Timer (WDT). The WDT can be clocked from the internal RC oscillator, the RTC oscillator, or the APB clock.

- Cortex-M3 system tick timer, including an external clock input option.

- Repetitive interrupt timer provides programmable and repeating timed interrupts.

- > Standard JTAG test/debug interface as well as Serial Wire Debug and Serial Wire Trace Port options.
- > Emulation trace module supports real-time trace.
- > Four reduced power modes: Sleep, Deep-sleep, Power-down, and Deep power-down.
- Single 3.3 V power supply (2.4 V to 3.6 V). Temperature range of -40 °C to 85 °C.
- Four external interrupt inputs configurable as edge/level sensitive. All pins on PORT0 and PORT2 can be used as edge sensitive interrupt sources.
- > Non Maskable Interrupt (NMI) input.
- Clock output function that can reflect the main oscillator clock, IRC clock, RTC clock, CPU clock, or the USB clock.
- The Wake-up Interrupt Controller (WIC) allows the CPU to automatically wake up from any priority interrupt that can occur while the clocks are stopped in deep sleep, Power-down, and Deep powerdown modes
- Processor wake-up from Power-down mode via any interrupt able to operate during Power-down mode (includes external interrupts, RTC interrupt, USB activity, Ethernet wake-up interrupt, CAN bus activity, PORT0/2 pin interrupt, and NMI).
- > Each peripheral has its own clock divider for further power savings.
- > Brownout detect with separate threshold for interrupt and forced reset.
- > On-chip Power-On Reset (POR).
- > On-chip crystal oscillator with an operating range of 1 MHz to 25 MHz.
- > 4 MHz internal RC oscillator trimmed to 1% accuracy that can optionally be used as a system clock.
- An on-chip PLL allows CPU operation up to the maximum CPU rate without the need for a high-frequency crystal. May be run from the main oscillator, the internal RC oscillator, or the RTC oscillator.
- A second, dedicated PLL may be used for the USB interface in order to allow added flexibility for the Main PLL settings.
- Versatile pin function selection feature allows many possibilities for using on-chip peripheral functions.

# PART A (Assembly Level Programming-ARM Cortex M3) Software : Keil µvision 4

### Software Handling Procedure:

1.Double click on  $\mu$ vision 4 icon in the desktop.



| 💟 µVision4           | -         |                                             | BASING AREA READ IN |                      |
|----------------------|-----------|---------------------------------------------|---------------------|----------------------|
| File Edit View       | Project   | Flash Debug Peripherals Tools SVCS V        | Vindow Help         |                      |
| D 📬 🗑 👰              | Ne        | w μVision Project                           |                     |                      |
| 1 400 (M) (M) 400    | Ne        | w Multi-Project Workspace                   |                     |                      |
|                      | Op        | pen Project                                 |                     |                      |
| Project              | Sa        | ve Project in µVision4 format               |                     |                      |
|                      | Clo       | ose Project                                 |                     |                      |
|                      |           | C.                                          |                     |                      |
|                      | EX        | port                                        |                     |                      |
|                      | Ma        | anage                                       |                     |                      |
|                      | Se        | lect Device for Target                      |                     |                      |
|                      | Re        | move Item                                   |                     |                      |
|                      | NOp       | ptions Alt+F7                               |                     |                      |
|                      | CI        | aan tarnate                                 |                     |                      |
|                      |           | uld target                                  |                     |                      |
|                      |           | while all target files                      |                     |                      |
|                      |           | teb Puild                                   |                     |                      |
|                      | d Tra     | avelata (tri) 57                            |                     |                      |
|                      |           | ansiate Ctri+F7                             |                     |                      |
|                      | mag Sto   | op bulla                                    |                     |                      |
|                      | 1 0       | D:\ARMEMB\lap_prgs_2021\writedataRam.uvproj |                     |                      |
|                      | 2 0       | D:\ARMEMB\lap_prgs_2021\oddeven.uvproj      |                     |                      |
|                      | 3 0       | D:\ARMEMB\lap_prgs_2021\oneszeros.uvproj    |                     |                      |
|                      | 4 0       | D:\ARMEMB\lap_prgs_2021\multiply16.uvproj   |                     |                      |
|                      | 5 0       | D:\ARMEMB\lap_prgs_2021\p5.uvproj           |                     |                      |
|                      | 6 [       | D:\ARMEMB\lap_prgs_2021\p6.uvproj           |                     |                      |
|                      | 7 0       | D:\ARMEMB\embLabPrg\p6.uvproj               |                     |                      |
| 🛅 Pr 🌍 Bo   {        | 8 (       | C:\Users\User\Desktop\p5.uvproj             |                     |                      |
| Build Output         | 9 (       | C:\Users\User\Desktop\p4.uvproj             |                     | a 🖬                  |
|                      | 10        | C:\Keil\ARM\Examples\Blinky\Blinky.uvproj   |                     | *                    |
|                      | _         |                                             | 1                   |                      |
|                      |           |                                             |                     | Ψ.                   |
| ٠                    |           |                                             |                     | •                    |
| Create a new µVision | n project |                                             |                     | CAP NUM SCRL OVR R/W |
|                      | 6         | ) 🖸 ڬ 🗖                                     |                     | 3:31 PM<br>5/30/2021 |

### 2. Select "New µvision Project" from project in the menu bar.

3. Browse and create a new project in the required location.

| 🛛 µVision4            |                       |                     | and instant and    | Barry Harrison Street |                                      |
|-----------------------|-----------------------|---------------------|--------------------|-----------------------|--------------------------------------|
| Create New Project    | rise links from       |                     |                    |                       |                                      |
| 🔿 🗢 🔳 Desktop         | •                     |                     | ✓ 4 Search Desktop | a 🖉 🔍 🔍 🔍 🗢 🔿 🖉       |                                      |
|                       |                       |                     |                    |                       |                                      |
| Organize 🔻 New fo     | lder                  |                     | 58 <b>~ 6</b>      |                       |                                      |
| ☆ Favorites           | Libraries             | Objects             |                    |                       |                                      |
| E Desktop             | Regroup 🔣             | 🍌 practice programs |                    |                       |                                      |
| \rm Downloads         | 🔋 🔡 User              | 🍌 printout_june8th  |                    |                       |                                      |
| 📃 Recent Places       | Computer              | 鷆 ResultDigit       |                    |                       |                                      |
| OneDrive              | 📬 Network             | 퉬 Seshu projects    |                    |                       |                                      |
|                       | 📗 activity            | 🍌 studentDetails    |                    |                       |                                      |
| 🥽 Libraries           | 🍌 Keerthana           | 闄 studentTestPapers |                    |                       |                                      |
| Documents             | 📕 LabFinalExamTT      | 📙 vlsiLab           |                    |                       |                                      |
| J Music               | 🔒 Listings            |                     |                    |                       |                                      |
| Dieturor              |                       |                     |                    |                       |                                      |
| File name: der        | mo                    |                     | •                  |                       |                                      |
| Save as type: Pro     | ject Files (*.uvproj) |                     | •                  |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
| Hide Folders          |                       |                     | Save Cancel        |                       |                                      |
|                       |                       |                     |                    | J                     |                                      |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
| 🖻 Pr 🧑 Во   {} Fu   ( |                       |                     |                    |                       |                                      |
| Suild Output          |                       |                     |                    |                       | <b>д</b> (Г                          |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
|                       |                       |                     |                    |                       |                                      |
| (                     |                       |                     |                    |                       | •                                    |
|                       |                       |                     |                    |                       | CAP NUM SCRL OVR R                   |
| 🤊 📋 🤇                 | ) 🔘                   | 📕 🗖                 | 🖉 🔿 🔣 🚿            |                       | 🍕 🛜 🔐 🏴il 🧞 🛱 🌒 3:33 PM<br>5/30/2021 |

4. Select the target device(here,LPC1768 from NXP) from the list or type the exact name of the device. Press OK.



C:\Users\User\Desktop\demo.uvproj - µVision4 File Edit View Project Flash Debug Peripherals Tools SVCS Window Help □ 🚔 😹 🔉 ち む む | つ ひ | ↔ → | 巻 巻 巻 数 | 連 連 川 版 | 🦉 🚽 🗟 🥙 🍳 💿 💿 🔗 👧 🗐 🔍 🤌 🖭 🞬 🥪 🔜 🙀 Target 1 🗟 🔊 📥 📥 🔅 Project **4** 🖃 🛅 Target 1 -🔆 Options for Group 'Source Group 1'... Alt+F7 Add New Item to Group 'Source Group 1'.. Add Existing Files to Group 'Source Group 1'... Add Group. Remove Group 'Source Group 1' and its Files Anage Project Items... Open File Open List File Open Map File Open Build Log Rebuild all target files Build target F7 Translate File Stop build Show Include File Dependencies Build Output **4** Add a new Item to Group Simulation D D 🍇 🗿 🔐 🖿 💷 🧞 📴 🚯 3:39 PM 🔼 🖾 🖉 🚫 🔣 🚿 **1** e 0 7. Select Asm file and give name of the file with .s extension and press ADD. 23 C:\Users\User\Desktop\demo.uvproj - µVision4 File Edit View Project Flash Debug Peripherals Tools SVCS Window Help □ 🎽 😹 🕼 | み ね 🟝 | つ ひ | ← → | 巻 巻 巻 巻 数 | 窪 津 止 ル | 🙆 🕞 🗟 🥙 🍭 🌼 ः 🔗 👧 🔳 🔹 🤌 🏝 🕮 🧼 🔜 🔤 🖬 Target 1 토 🔊 📥 📥 💩 👜 Project **4** E Target 1 X Add New Item to Group 'Source Group 1' Create a new assembler source file and add it to the project. C File (.c) C++ File (.cpp) A Asm File (.s) h Header File (.h) Text File (.txt) 🐖 Image File (.\*) User Code Template Type: Asm File (.s) Name: location C: Users User Desktop Add Close Help ፪ Pr... (③Bo... | {} Fu... | 0., Te... Build Output **4** Simulation CAR NUM SCR D D 3:40 PM (2) e 🧸 🗿 🔐 🖿 Jal 🧞 🛱 🌗

6.In the project window, right click on source and select Add new item to group "source group 1".

| 8. Type the program in the editor space and say | ve. |
|-------------------------------------------------|-----|
|-------------------------------------------------|-----|



Check for errors and warnings in the bottom window.

10.If no error, Select "Build" icon from tool bar or from menu bar.

| C:\Users\User\Desktop\demo.uvpro | oj - µvision4     |                                | A Designation of a second second second |             |               |                          |
|----------------------------------|-------------------|--------------------------------|-----------------------------------------|-------------|---------------|--------------------------|
| File Edit View Project Flash     | Debug Peripherals | Tools SVCS Window Help         |                                         |             |               |                          |
| 🗋 🗋 🔂 🖉 🛛 🖧 🔤 📽                  | ? ⊱   ← ⇒   ?     | - 魯 魯 徴   津 津 川 川   🍅          | 💌 🗟 🥠                                   | 0 🖉 🖉 🖉 🖉   |               |                          |
| 🛛 🍪 🕮 🥔 🔜 🛛 🙀 🛛 Target           | 1                 | * 🔒 🗟 🗇 🎰                      |                                         |             |               |                          |
| Project 🔛 Build (F7) 4 🗵         | demo.s            |                                |                                         |             |               | <b>▼</b> ×               |
| Build target files               | 1 ;ALP            | TO MULTIPLY TWO 16 BIT NUMBERS |                                         |             |               |                          |
| 🖻 🔄 Source Group 1               | 2 1               | AREA Reset, DATA, READONLY     |                                         |             |               |                          |
| demo.s                           | 3                 | EXPORTVectors                  |                                         |             |               |                          |
|                                  | 5 -vec            | DCD 0X20001000                 |                                         |             |               |                          |
|                                  | 6                 | DCD Reset Handler;             |                                         |             |               |                          |
|                                  | 7                 |                                |                                         |             |               |                          |
|                                  | 8 1               | AREA MULTIPLY, CODE, READONLY  |                                         |             |               |                          |
|                                  | 9 ENTR            | VPOPT Peset Handler            |                                         |             |               |                          |
|                                  | 11 Reset          | Handler                        |                                         |             |               |                          |
|                                  | 12 1              | IOV r0, #num1                  |                                         |             |               |                          |
|                                  | 13 1              | IOV r1, #num2                  |                                         |             |               |                          |
|                                  | 14 1              | UL r2,r0,r1                    |                                         |             |               |                          |
|                                  | 15                | DR r3,=product                 |                                         |             |               |                          |
|                                  | 17 stop           | B stop                         |                                         |             |               |                          |
|                                  | 18                |                                |                                         |             |               |                          |
|                                  | 19 1              | REA DATA2, DATA, READWRITE     |                                         |             |               |                          |
|                                  | 20 num1           | EQU OXFFFF ;maximum valur of   | 16 bit number                           |             |               |                          |
|                                  | 21 num2           | EQU OXFFFF                     |                                         |             |               |                          |
|                                  | 22 prod           | IND                            |                                         |             |               |                          |
|                                  | 24                |                                |                                         |             |               |                          |
|                                  |                   |                                |                                         |             |               |                          |
|                                  |                   |                                |                                         |             |               |                          |
|                                  |                   |                                |                                         |             |               |                          |
|                                  |                   | m                              |                                         |             |               |                          |
|                                  | 1                 |                                |                                         |             |               |                          |
| Build Output                     |                   |                                |                                         |             |               | 4 🖾                      |
| demo.s(19): warning: A158        | 1W: Added 2 but   | es of padding at address 0v12  |                                         |             |               | ^                        |
| "demo.s" - 0 Error(s), 1 V       | Warning(s).       | co of padding at address owir  |                                         |             |               |                          |
| 4                                |                   |                                |                                         |             |               | *                        |
| S                                |                   |                                |                                         | Cinculation | 1-24 64       |                          |
| build target mes                 | -                 |                                |                                         | simulation  | 224 CI CAP    | 2.45 DM                  |
|                                  | 2 🥹               | 占 🔟 🖉 🚺                        | <b>1</b>                                |             | 🧸 🗿 🕾 🖿 🗤 🧤 🛱 | ()) 3:45 PM<br>5/30/2021 |

### 11.Start the debug session from Menu bar.

| C:\Users\User\Desktop\demo.uvp | roj - µVision4                        |                                         |            |
|--------------------------------|---------------------------------------|-----------------------------------------|------------|
| File Edit View Project Flash   | Debug Peripherals Tools SVCS Window   | N Help                                  |            |
| 🗋 🖬 🖉 🕷 🖉 🕹 🛍 🔤                | Start/Stop Debug Session Ctrl+F5      | ■   / / / / / / / / / / / / / / / / / / |            |
| 🛛 🕸 🖾 🥔 🔜 🛛 💥 🛛 Targe          | Reset CPU                             |                                         |            |
| Project 🎗 🖬                    | Run F5                                | 5                                       | <b>▼</b> × |
| 🖃 🚔 Target 1                   | Stop                                  | BIT NUMBERS                             |            |
| Source Group 1                 | ₹ <sup>1</sup> } Step F11             | READONLY                                |            |
| demo.s                         | 🚯 Step Over F10                       |                                         |            |
|                                | {} Step Out Ctrl+F11                  |                                         |            |
|                                | →{} Run to Cursor Line Ctrl+F10       |                                         |            |
|                                | A Show Next Statement                 | E, READONLY                             |            |
|                                | Breaknoints (trl+B                    | a                                       |            |
|                                | Insert/Remove Breaknoint              |                                         |            |
|                                | Enable/Disable Breakpoint     Ctrl+F9 |                                         |            |
|                                | Disable All Breakpoints               |                                         |            |
|                                | Kill All Breakpoints Ctrl+Shift+F9    |                                         |            |
|                                |                                       |                                         |            |
|                                | OS Support                            | P                                       |            |
|                                | Execution Profiling                   | 'EADWRITE                               |            |
|                                | Memory Map                            | ximum valur of 16 bit number            |            |
|                                | Inline Assembly                       |                                         |            |
|                                | Function Editor (Open Ini File)       |                                         |            |
|                                |                                       |                                         |            |
|                                |                                       |                                         |            |
|                                |                                       |                                         |            |
| E Pr 🚷 Bo {} Fu 0, Te          | •                                     | III.                                    | •          |
| Build Output                   |                                       |                                         | <b>4 </b>  |
| assembling demo.s              |                                       |                                         | *          |
| demo.s(19): warning: A158      | 1W: Added 2 bytes of padding at       | address 0x12                            |            |
| Geno.5 - 0 Error(8), 1         | maining (5) .                         |                                         | -          |
| <                              |                                       |                                         | 4          |
| Enter or leave a debug session |                                       | Simulation L:24 C:1 CAP NUM SC          | RL OVR R/W |
|                                | 0 🙆 🛃 🔟                               |                                         | 5/30/2021  |

12.PressOK

Department of ECE, Atria IT

| C:\Users\User\[ | Desktop\demo.uvp | rproj - µVision4                                                                              | - 0 ×                |
|-----------------|------------------|-----------------------------------------------------------------------------------------------|----------------------|
| File Edit View  | Project Flash    | n Debug Peripherals Tools SVCS Window Help                                                    |                      |
| 🗋 🖬 😹 🥔         | X 🗅 🛍   1        | 🤊 (2) (4 (2)) 🥐 (2) (2) (2) (2) (2) (2) (2) (2) (2) (2)                                       |                      |
| 👫   🗉 🚳         | 0° 10 10 10      |                                                                                               |                      |
| Registers       | <b>д </b> 🖬      | 3 Disassembly                                                                                 | F 📧                  |
| Register        | Value            | 12: MOV r0, #num1                                                                             | *                    |
| - Core          |                  | COX0000008 F64F70FF MOVW r0,#0xFFFF                                                           |                      |
| R0              | 0x00000000       | 13: MOV r1, #num2                                                                             |                      |
|                 | 0x00000000       | 0x000000C F64F71FF MOVW r1,#0xFFFF                                                            |                      |
| R2              | 0x00000000       | 14: MUL r2,r0,r1                                                                              |                      |
|                 | 0x00000000       | 0x00000010 FB00F201 MUL r2,r0,r1                                                              |                      |
| R4              | 0x0000000        | 15: LDK F3,=product                                                                           |                      |
| R5              | 0x0000000        |                                                                                               |                      |
|                 | 0x0000000        |                                                                                               | -                    |
| R7              | 0x0000000        |                                                                                               | •                    |
|                 | 0x0000000        |                                                                                               |                      |
| R9              | 0×0000000        | demo.s                                                                                        | • •                  |
| R10             | 0x00000000       | 5 DCD 0X20001000                                                                              | *                    |
| R11             | 0x00000000       | 6 DCD Reset_Handler;                                                                          |                      |
| RIZ DIA (CD)    | 0x00000000       | 7                                                                                             |                      |
| R13 (SP)        | 0x20001000       | 8 AREA MULTIPLY, CODE, READONLY                                                               |                      |
| R 14 (LR)       | UXFFFFFFFF       | 9 ENTRY                                                                                       |                      |
|                 | 0x00000000       | 10 EXPORT Reset_Handler                                                                       |                      |
| E kron          | 0x01000000       | 11 Reset_Handler                                                                              | =                    |
| E System        |                  | 12 MOV r0, #num1                                                                              |                      |
| E Internal      |                  | 13 MOV r1, #num2                                                                              |                      |
| Mode            | Thread           | 14 MUL r2, r0, r1                                                                             |                      |
| Privilege       | Privileged       | 15 LDR r5, =product                                                                           |                      |
| Stack           | MSP              |                                                                                               |                      |
| States          | 0                |                                                                                               |                      |
| Sec             | 0.00000000       | 19 APEA DATA PEADWEITE                                                                        | -                    |
| Project Re      | nisters          | I ANDR DRIK, DRIK, NERMINIE                                                                   | Þ                    |
| Command         | gisters          | I G Call Stark + Locals                                                                       | л 🖂                  |
| *** Currently   | rused: 36 Bu     |                                                                                               |                      |
| Currents        | y usea. So by    | Vane Location/Value Type                                                                      |                      |
| <               |                  | b.                                                                                            |                      |
| >               |                  |                                                                                               |                      |
| ASSIGN Break    | Disable Break    | akEnable BreakKill BreakList BreakSet BreakAccess COVERAGE 🛛 🕼 Call Stack + Locals 🗔 Memory 1 |                      |
|                 |                  | Simulation 11: 0.0000000 sec L:12 C:1 CAP NU                                                  | M SCRL OVR R/W       |
|                 | e                | 🖸 🚯 🛃 🔯 🦉 🧭 🔣 🚿                                                                               | 3:48 PM<br>5/30/2021 |

13.Press function key F11 or select "step" option under Debug menu for single step execution and verify the output in register window/Memory window/xPSR.

#### **1.ALP TO MULTIPLY TWO 16 BIT NUMBERS**

AREA Reset, DATA, READONLY EXPORT \_\_Vectors Vectors DCD 0X20001000 DCD Reset\_Handler;

AREA MULTIPLY, CODE, READONLY ENTRY EXPORT Reset\_Handler Reset\_Handler MOV r0,#num1 MOV r1,#num2 MUL r2,r0,r1 LDR r3,=product STR r2,[r3] stop B stop

AREA DATA2, DATA, READWRITE num1 EQU 0XFFFF ;maximum value of 16 bit number num2 EQU 0XFFFF product DCD 0X0 END

Result: (0xFFFF) x(0xFFFF) =0xFFFE0001 in the product memory location.

# EMBEDDED SYSTEMS LAB MANUAL

| 🔣 C:\Users\Us | er\Desktop\demo.uvp                               | roj - µVision4                                                                                          |                      |
|---------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------|
| File Edit V   | iew Project Flash                                 | Debug Peripherals Tools SVCS Window Help                                                                |                      |
| D 🐸 🖬         | 🧭 🕹 🐒 😽                                           | 9 ℃ ← → 1 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2                                                           |                      |
| 👫 🗄 📀         | { <del>}</del> } { <del>}</del> { <del>}</del> {} |                                                                                                         |                      |
| Registers     | џ 🔛                                               | Disassembly                                                                                             | Ф 🖂                  |
| Register      | Value                                             | 16: STR r2,[r3]                                                                                         | ~                    |
| Core          |                                                   | 17: stop B stop                                                                                         |                      |
| R0            | 0x0000FFFF                                        | → 0x0000018 E7FE B 0x0000018                                                                            |                      |
| B2            | 0xEEEE0001                                        | 0x000001A 0000 DCW 0x0000                                                                               |                      |
| R3            | 0x1000000                                         | 0x000001C 0000 DCW 0x0000                                                                               |                      |
|               | 0x0000000                                         | 0x0000001E 1000 DCW 0x1000                                                                              |                      |
| R5            | 0x0000000                                         | 0x0000022 0000 MOVS r0.r0                                                                               |                      |
| 87            | 0x00000000                                        | 0 m 00000024 0000 M0775 m m                                                                             | -                    |
|               | 0x00000000                                        |                                                                                                         |                      |
|               | 0x0000000                                         | 📩 demo.s                                                                                                | ▼ ×                  |
| R10           | 0x00000000                                        | 5 DCD 0X20001000                                                                                        | ~                    |
| B12           | 0x0000000                                         | 6 DCD Reset_Handler;                                                                                    |                      |
| R13 (S        | P) 0x20001000                                     | 8 ADEA MILITIDIY CODE READONLY                                                                          |                      |
| R14 (L        | R) OxFFFFFFFF                                     | 9 ENTRY                                                                                                 |                      |
| R15 (P        | C) 0x00000018                                     | 10 EXPORT Reset_Handler                                                                                 |                      |
| + xPSR        | 0x01000000                                        | 11 Reset Handler                                                                                        | =                    |
| ± System      |                                                   | 12 MOV r0, #numl                                                                                        | -                    |
| internal      |                                                   | 14 MUL r2.r0.r1                                                                                         |                      |
| Mode          | Thread                                            | 15 LDR r3, =product                                                                                     |                      |
| Privileg      | e Privileged                                      | 16 STR r2, [r3]                                                                                         |                      |
| States        | 13                                                | 17 stop B stop                                                                                          |                      |
| Sec           | 0.00000108                                        | 19 ARFA DATA2, DATA, READWRITE                                                                          | -                    |
| 📧 Project 🔛   | Registers                                         | 4 <u> </u>                                                                                              | F.                   |
| Command       |                                                   | a 🖬 Memory 2                                                                                            | <b>4 </b>            |
| *** Curren    | tly used: 36 B                                    | ytes (0%)                                                                                               |                      |
| 4             |                                                   |                                                                                                         |                      |
| >             |                                                   |                                                                                                         | 00 00 +              |
| ASSIGN Bre    | akDisable Brea                                    | KEnable BreakKill BreakList BreakSet BreakAccess COVERAGE 🛛 🚱 Call Stack + Locals 🗐 Memory 1 🗐 Memory 2 |                      |
|               |                                                   | Simulation t1: 0.00000108 sec L17 C1 CAP NUM                                                            | SCRL OVR R/W         |
| <b>1</b>      |                                                   | 🖸 🔞 🛃 🖾 🔘 🔣 🚿                                                                                           | 3:57 PM<br>5/30/2021 |

#### 2.ALP TO FIND THE SUM OF FIRST 10 INTEGERS

AREA Reset, DATA, READONLY EXPORT \_\_Vectors \_\_Vectors DCD 0X20001000 DCD Reset\_Handler;

AREA SUM, CODE, READONLY ENTRY EXPORT Reset\_Handler Reset\_Handler MOV r3,#10 MOV r0,#0 MOV r0,#0 MOV r1,#1 11 ADD r0,r0,r1 ADD r1,r1,#1 SUBS r3,#1 BNE 11 LDR r4, =RESULT STR r0, [r4]

XSS B XSS

AREA DATA2, DATA, READWRITE

#### RESULT DCD 0X0 END

;Mark the end

Result:

1+2+3+.....+10=55d=37H.(At RESULT Memory Location)

|                                    | pigs_corr (psid          | (ind)         | prisione                                 |               |             |           |     |                                                             |    |
|------------------------------------|--------------------------|---------------|------------------------------------------|---------------|-------------|-----------|-----|-------------------------------------------------------------|----|
| File Edit View F                   | roject Flash             | Debug         | Peripherals Tools S                      | VCS Window He | lp          |           |     |                                                             |    |
| 🗋 📬 🖬 🕔 📄                          | 8 🕰 🖪 🕴                  |               | 19 19 19 (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 微量 運用用        | //🛓 🔛       |           | -   |                                                             |    |
| 않 🛛 🗉 🚳 🖓                          | 0.0.40                   | ⇒  [          | • 🖾 🖬 🖬 🔊                                | • 💷 • 🔜 • 🔳   | • 💷 • 🔝 •   | * -       |     |                                                             |    |
| Registers                          |                          | P 🖸           | Disassembly                              |               |             |           |     |                                                             | 3  |
| Register                           | Value                    |               | 0x0000001E 4C01                          | LDR           | r4,[pc,#4]  | ; @0x0000 | 002 | 24                                                          | •  |
| Core                               |                          |               | 21:                                      | STR r0, [r4]  |             |           |     |                                                             |    |
| R0                                 | 0x00000037               |               | 22:                                      | STR           | r0 [r4 #0x0 | 11        |     |                                                             |    |
| R1                                 | 0x0000000B               |               | 23: XSS                                  | B XSS         | 207(217)000 |           |     |                                                             |    |
| R2<br>P2                           | 0x00000000               |               | 0x00000022 E7FE                          | в             | 0x00000022  |           |     |                                                             |    |
| RJ RA                              | 0×10000000               |               | 0x00000024 0000                          | DCW           | 0x0000      |           |     |                                                             |    |
| R5                                 | 0x00000000               |               | 0x00000026 1000                          | DCW           | 0x1000      |           |     |                                                             |    |
| R6                                 | 0x00000000               |               | 0x00000028 0000                          | MOVS          | r0,r0       |           |     |                                                             |    |
| R7                                 | 0x00000000               |               | 0x0000002A 0000                          | MOVS          | r0,r0       |           |     |                                                             |    |
| R8                                 | 0x00000000               | _             | 0x0000002C 0000                          | MOVS          | r0,r0       |           |     |                                                             |    |
| R9                                 | 0×00000000               |               | 0x00000030 0000                          | MOVS          | r0.r0       |           |     |                                                             | Ξ. |
| R10                                | 0x00000000               |               | 0x00000032 0000                          | MOVS          | r0, r0      |           |     |                                                             | -  |
| R12                                | 0x0000000                |               | <                                        |               |             |           |     | F                                                           |    |
| R13 (SP)                           | 0x20001000               |               |                                          |               |             |           |     | _ ~                                                         |    |
| R14 (LR)                           | 0xFFFFFFFF               |               | iii pols                                 |               |             |           |     |                                                             | -  |
| D16 (00)                           | 0.00000000               | <u> </u>      | 23 XSS                                   | B XSS         |             |           |     | [‡                                                          | 4  |
| Project   ERegist                  | ers                      |               | ] • [                                    |               |             |           | _   |                                                             | 4  |
| Command                            |                          |               |                                          |               |             | ф.        |     | Memory 3 🗣 📔                                                | 3  |
| Running with Co<br>Load "D:\\ARM&B | de Size Li<br>MB\\lap pr | mit:<br>gs 20 | 32K<br>)21\\p5.axf"                      |               |             |           | ^   | Address: 0x10000000                                         | -  |
|                                    | -                        |               |                                          |               |             |           |     | 0x10000000: 37 00 00 00 00 00 00 00 00 00 00 00 00 00       | 1  |
| *** Restricted                     | Version wi               | th 32         | 768 Byte Code Siz                        | e Limit       |             |           |     | 0x10000017: 00 00 00 00 00 00 00 00 00 00 00 00 00          |    |
| *** Currently u                    | sed: 44 By               | tes (         | (0%)                                     |               |             |           |     | 0x1000002E: 00 00 00 00 00 00 00 00 00 00 00 00 00          |    |
|                                    |                          |               |                                          |               |             |           |     | 0x10000045: 00 00 00 00 00 00 00 00 00 00 00 00 00          |    |
|                                    |                          |               |                                          |               |             |           |     |                                                             |    |
|                                    |                          |               |                                          |               |             |           |     |                                                             |    |
|                                    |                          |               |                                          |               |             |           |     | 0x100000A1: 00 00 00 00 00 00 00 00 00 00 00 00 00          |    |
|                                    |                          |               |                                          |               |             |           | -   | 0x100000B8: 00 00 00 00 00 00 00 00 00 00 00 00 00          |    |
| <                                  |                          |               |                                          |               |             | Þ         |     | 0x100000CF: 00 00 00 00 00 00 00 00 00 00 00 00 00          |    |
| >                                  |                          |               |                                          |               |             |           | -   |                                                             |    |
| ASSIGN BreakDis                    | able Break               | Enabl         | e BreakKill Break                        | List BreakSet | BreakAccess | COVERAGE  | T)  | Call Stack + Locals   Memory 1   Memory 3                   | _  |
|                                    |                          |               |                                          |               |             |           |     | Simulation t1: 0.00000567 sec L:23 C:1 CAP NUM SCRL OVR R/W | N  |
| <b>()</b>                          | 2                        | 0             | 놜 🔼                                      |               |             |           |     | 💆 😰 🖳 🏲 atl 🥡 🕼 402 PM 5/30/2021                            |    |

#### 3.ALP TO FIND THE 1'S AND 0' IN THE GIVEN 32 BIT DATA.

AREA Reset, DATA, READONLY EXPORT \_\_Vectors

Vectors

DCD 0X20001000 DCD Reset\_Handler;

AREA onezero, CODE, READONLY num EQU 15

#### ENTRY

EXPORT Reset\_Handler Reset\_Handler MOV r0,#num MOV r1,#0 MOV r2,#0 MOV r3,#32 loop LSRS r0,r0,#1 BCS 11 ADD r2,#1 B 12 11 ADD r1,#1 12 SUBS r3,#1 BNE loop LDR r5,=ones LDR r6,=zeros STR r1,[r5] STR r2,[r6] stop B stop

AREA DATA1, DATA, READWRITE ones DCB 0X0 zeros DCB 0X0 END

Result: If num=15d $\rightarrow$  no of 1's=4 and No.of 0's=28d=1Ch.

# EMBEDDED SYSTEMS LAB MANUAL

| D:\ARM&EMB\lap      | _prgs_2021\oneszeros.u | uvproj - µVision4                                                                             |                              |                      |
|---------------------|------------------------|-----------------------------------------------------------------------------------------------|------------------------------|----------------------|
| File Edit View      | Project Flash Debug    | ıg Peripherals Tools SVCS Window Help                                                         |                              |                      |
| D 💕 🖬 🖉             | 8 in 🛍 🔊 e             | - ( - + ) 参 悠 悠 泉 淳 淳 順 版 🖉 🕢 🗟 🖉 💽 • • 🔗 🌒 🖬 • 🔧                                             |                              |                      |
| 87 🗉 📀 🖓            | } (} (} () √)          |                                                                                               |                              |                      |
| Registers           | ¢                      | 4 🖸 Disassembly                                                                               |                              | <b>д </b>            |
| Register            | Value                  | ▲ ■0x0000002C 4E02 LDR r6,[pc,#8] ; @0x00000038                                               |                              | *                    |
| Core                |                        | 2/: SIR F1,[F5]                                                                               |                              |                      |
| RO                  | 0x0000000              | 28: STR r2. [r6]                                                                              |                              |                      |
| R1                  | 0x0000004              | 0x00000030 6032 STR r2, [r6, #0x00]                                                           |                              |                      |
| RZ<br>B2            | 0x0000001C             | 29: stop B stop                                                                               |                              |                      |
| R/                  | 0x00000000             | ■ 0x00000032 E7FE B 0x00000032                                                                |                              |                      |
| R5                  | 0x10000000             | 0x0000034 0000 DCW 0x0000                                                                     |                              |                      |
| R6                  | 0x10000001             | 0x0000036 1000 DCW 0x1000                                                                     |                              |                      |
| R7                  | 0x0000000              | 0x0000038 0001 DCW 0x0001                                                                     |                              |                      |
|                     | 0x0000000              |                                                                                               |                              | _                    |
| R9                  | 0x0000000              |                                                                                               |                              |                      |
| R10                 | 0×0000000              |                                                                                               |                              | •                    |
| R11                 | 0x0000000              |                                                                                               |                              |                      |
| RIZ<br>D12 (CD)     | 0x0000000              | 📩 oneszeros.s                                                                                 |                              | <b>▼</b> ×           |
| R13 (3F)            | 0x20001000             | 23 12 SUBS r3.#1                                                                              |                              |                      |
| B15 (PC)            | 0x00000032             | 24 BNE LOOD                                                                                   |                              |                      |
| ±−xPSR              | 0x61000000             | 25 LDR r5,=ones                                                                               |                              |                      |
| Banked              |                        | 26 LDR r6,=zeros                                                                              |                              |                      |
|                     |                        | 27 STR r1, [r5]                                                                               |                              |                      |
| E Internal          |                        | 28 STR r2, [r6]                                                                               |                              |                      |
| Mode                | Thread                 | 29 stop B stop                                                                                |                              | -                    |
| Privilege           | Privileged             |                                                                                               |                              |                      |
| Stack               | MSP                    | V 31 AKEA DAIAI, DAIA, KEADWRITE                                                              |                              | Ψ.                   |
| 🛅 Project   🧮 Regis | ters                   | · · · · · · · · · · · · · · · · · · ·                                                         |                              | •                    |
| Command             |                        | a 🛛 Memory 2                                                                                  |                              | <b>џ </b>            |
| Running with C      | ode Size Limit:        | 32K Address: Dx1000000                                                                        |                              |                      |
| Load "D:\\ARM&      | EMB\\lap_prgs_20       | 021\\oneszeros.axf"                                                                           |                              | <u> </u>             |
| the Destricted      | Version with 23        | 0x10000000: 04 1C 00 00 00 00 00 00 00 00 00 00 00 00 00                                      | 00 00 00 00 00 00 00 00 00 0 | 00 00 00 00          |
| 4                   | . VEISION WICH 32      | 0x10000017: 00 00 00 00 00 00 00 00 00 00 00 00 00                                            | 00 00 00 00 00 00 00 00 00 0 | 10 00 00 00          |
|                     |                        |                                                                                               |                              |                      |
| 2                   |                        |                                                                                               |                              | 000000               |
| ASSIGN BreakDi      | sabie BreakEnabl       | The Dreakhill DreakList DreakSet BreakAccess COVERAGE Call Stack + Locals   Memory 1 Memory 2 |                              |                      |
|                     |                        | Simulation t1:0                                                                               | 1.00002833 sec L:29 C:1 CAP  | NUM SCRL OVR R/W     |
|                     | 6 0                    |                                                                                               | 🧸 👔 🐏 🖬 🧞 🛱                  | 4:10 PM<br>5/30/2021 |

#### 4. ALP TO FIND WHETHER THE GIVEN 16 BIT NUMBER IS ODD OR EVEN

AREA Reset, DATA, READONLY EXPORT \_\_Vectors

Vectors

DCD 0X20001000 DCD Reset Handler;

AREA oddeven, CODE, READONLY

res EQU 'o' resu EQU 'e'

#### ENTRY

EXPORT Reset\_Handler Reset\_Handler LDR r1,=num LDR r0,[r1] RORS r0,#1 BCS 11 MOV r2,#resu B 12 11 MOV r2,#res 12 LDR r3,=result STR r2,[r3] stop B stop

AREA data, DATA, READWRITE num DCW 16 result DCB 0X0 END

# EMBEDDED SYSTEMS LAB MANUAL

# Result:

num=16d.Hence it is EVEN

| D:\ARM&EMB\la     | p_prgs_2021\odd   | deven.uvproj - µVision4                                                                        |                          |
|-------------------|-------------------|------------------------------------------------------------------------------------------------|--------------------------|
| File Edit View    | Project Flash     | Debug Peripherais Tools SVCS Window Help                                                       |                          |
| 🗋 🗋 🐸 🖉           | 3 🖧 🔼             | ◇ ♥ ◇ → 教教教 連連ル版 💩 🔍 🖳 🕸 🔍 🕄 🖉 🖉 🖉 🖉 🖉                                                         |                          |
| 🎥 🖹 🖹 🚳 🛛 🕻       | 9 <b>()</b> () () |                                                                                                |                          |
| Registers         | <b>4 </b>         | Disassembly                                                                                    | <b>4 </b>                |
| Register          | Value             | 25: stop B stop                                                                                | *                        |
| Core              |                   |                                                                                                |                          |
| RO                | 0x00000000        |                                                                                                | *                        |
| R1                | 0x1000000         |                                                                                                | •                        |
| R2                | 0x00000065        |                                                                                                |                          |
| R3                | 0x10000002        | * oddeven.s                                                                                    | <b>▼</b> X               |
| R4                | 0~0000000         | 10 res EQU 'o'                                                                                 | *                        |
| B6                | 0x00000000        | 11 resu EQU 'e'                                                                                |                          |
|                   | 0x00000000        | 12                                                                                             |                          |
| R8                | 0x00000000        | 13 ENTRY                                                                                       |                          |
|                   | 0x00000000        | 14 EAFORT RESELANDER                                                                           |                          |
| R10               | 0x00000000        |                                                                                                |                          |
| R11               | 0x00000000        |                                                                                                |                          |
| R12               | 0x00000000        | 18 RORS r0, #1                                                                                 |                          |
| R13 (SP)          | 0x20001000        | 19 BCS 11                                                                                      |                          |
| R14 (LR)          | UxFFFFFFFF        | 20 MOV r2, #resu                                                                               |                          |
| R IS (PC)         | 0x0000020         | 21 B 12                                                                                        |                          |
| E XFon            | UX41000000        | 22 11 MOV r2, #res                                                                             | =                        |
| + System          |                   | 23 12 LDR r3,=result                                                                           |                          |
| E Internal        |                   | 24 STR r2, [r3]                                                                                |                          |
| Mode              | Thread            | 25 stop B stop                                                                                 |                          |
| Privilege         | Privileged        |                                                                                                |                          |
| Stack             | MSP               | 2/ AREA GEG, DATA, READWRITE                                                                   |                          |
| States            | 21                | 29 result DCB 0X0                                                                              |                          |
| Sec               | 0.00000175        | 30 END                                                                                         | -                        |
| 🔃 Project   🧱 Reg | isters            |                                                                                                | •                        |
| Command           |                   | a 🕼 Memory 2                                                                                   | <b>4 </b>                |
| *** Destricte     | d Version W       | the 22768 Butte Code Size Limit                                                                |                          |
| 4                 | a version w.      |                                                                                                |                          |
| >                 |                   | 0x1000046:                                                                                     |                          |
| ASSIGN BreakD     | isable Brea       | kEnable BreakKill BreakList BreakAccess COVERAGE 🛛 🚱 Call Stack + Locals 🖾 Memory 1 🛄 Memory 2 |                          |
|                   |                   | Simulation t1: 0.0000175 sec L25 C1 CAP NU                                                     | UM SCRL OVR R/W          |
|                   | e                 | 🖸 🔞 📙 🚾 🖉 🚫 🔣 🎻 👘 🔺 👘                                                                          | (→) 4:16 PM<br>5/30/2021 |

#### 5. ALP TO MOVE A BLOCK OF DATA FROM CODE TO RAM MEMORY

#### Method1:

AREA Reset, DATA, READONLY EXPORT \_\_Vectors \_\_Vectors DCD 0X20001000 DCD Reset\_Handler;

AREA writedata, CODE, READONLY src DCD 0x11,0X22,0X33,0X44,0X55 ENTRY EXPORT Reset\_Handler Reset\_Handler LDR r0,=src LDR r1,=dst MOV r2,#5 11 LDR r3,[r0],#4 STR r3,[r1],#4 SUBS r2,#1 BNE 11

stop B stop

AREA data, DATA,READWRITE dst DCD 0X0 END

#### Method 2:

;ALP TO MOVE A BLOCK OF DATA FROM CODE TO RAM MEMORY-USING LDM and STM INSTRUCTIONS(MULTIPLE DATA TRANSFER)

AREA Reset, DATA, READONLY EXPORT \_\_Vectors Vectors

DCD 0X20001000 DCD Reset\_Handler;

AREA writedata, CODE, READONLY src DCD 0x11,0X22,0X33,0X44,0X55 ENTRY EXPORT Reset\_Handler Reset Handler

Department of ECE, Atria IT

LDR r0,=src LDR r1,=dst MOV r2,#5 11 LDMIA r0!, {r4-r8} STMIA r1!, {r4-r8} SUBS r2,#1 **BNE 11** stop B stop AREA data, DATA, READWRITE dst DCD 0X0 END **Result:** INPUT: 00000011h,00000022h,00000033h,00000044h,00000055h. OUTPUT at dst : 00000011h,00000022h,00000033h,00000044h,00000055h. 💟 D:\ARM&EMB\lap\_prgs\_2021\writedataRam.uvproj - µVision4 - 0 File Edit View Project Flash Debug Peripherals Tools SVCS Window Help 🗋 🚰 🗿 👗 🔤 🚨 🧑 🖭 🔶 💌 🥐 熟 熟 製 連 連 進 版 🌌 토 🗟 🥐 📵 🗕 🔍 🔗 🍓 🔳 🔦 🛛 🖬 Disassembly Registers ф 🖡 11 LDMIA r0!,{r4-r8} 1024 E8B001F0 LDM r0!,{r4-r8} STMIA r1!,{r4-r8} 1028 F8A101F0 STM r1!,{r4-r8} 16: 11 Register Value Core 17: - R0 0x0000001C 0x00000028 E8A101F0 STM 0x10000014 - R1 R2 0x00000004 🛓 writedataRam.s - R3 0x00000000 **▼** X - R4 0x00000011 R5 0x00000022 8 AREA writedata, CODE, READONLY - R6 0x00000033 src DCD 0x11,0X22,0X33,0X44,0X55 q - R7 0x00000044 ENTRY 10 R8 0x00000055 11 EXPORT Reset\_Handler - R9 0x00000000 12 Reset\_Handler R10 0x00000000 LDR r0,=src 13 R11 0x00000000 14 LDR r1,=dst -R12 0x00000000 15 MOV r2,#5 R13 (... 0x20001000 16 LDMIA r0!, {r4-r8} 11 R14 (. **OxFFFFFFFF** 17 STMIA r1!, {r4-r8} 18 SUBS r2,#1 ÷ xPSR 0x21000000 BNE 11 19 ÷. Banked 20 ÷... System 21 stop B stop Internal 22 Mode Thread 23 Privilege Privileged AREA data, DATA, READWRITE 24 MSP Stack 25 dst DCD 0X0 States 21 26 END 0.00000175 Sec 🔟 Project | 🚟 Registers Command **p** 🛐 **4** Memory 2

\*\*\* Currently used: 64 Bytes (0%) Address: 0x1000000 Call Stack + Locals Memory 1 Memory 2 ASSIGN BreakDisable BreakEnable BreakKill BreakList BreakSet BreakAccess COVERAGE Simulation t1: 0.00000175 sec L:16 C:1 CAP NUM SCRL OVR R/W 4:20 PM e یل M Y EC 0 🗸 🗿 🚰 🖿 al 🧞 🛱 👀 5/30/2021

1

# PART B

(INTERACING HARDWARE WITH LPC 1768 MICROCONTROLLER) SOFTWARE: Keil µVision 4, Flash Magic Language: Embedded C

# Exp.No:1: (Beyond Syllabus-Practice session):

Interface a simple Switch and display its status through Relay, Buzzer and LED. **Connection details:** 



### Algorithm:

- 1. Configure PORT 1 and PORT 2 as GPIO.
- 2. Configure the direction of Port 2 as input and Port 1 as output .
- 3. Read the status of the switch.
- 4. If the switch is pressed, turn on LED, Relay and Buzzer else turn them off.
- 5. Repeat from step 3 unconditionally.

#### **Program:**

```
#include<LPC17xx.h>
#define switch 11
#define LED 19
#define relay 28
#define buzzer 27
int main(void)
{
LPC_PINCON->PINSEL3=0x00000000;
LPC_GPIO2->FIODIR=0x00000000;
LPC_GPIO1->FIODIR=0xFFFFFFF;
LPC_GPIO1->FIODIR=0xFFFFFFF;
while(1)
{
if (!((LPC_GPIO2->FIOPIN>>switch)& 0x1))
{
LPC_GPIO1->FIOPIN=(1<<LED)|(1<<relay)|(1<<buzzer);
}</pre>
```
```
}
else
{
LPC_GPIO1->FIOPIN=(0<<LED)|(0<<relay)|(0<<buzzer);
}
}</pre>
```

}

# Exp.No:2

Interface a Stepper motor and rotate it in clockwise and anti-clockwise direction.

## **Connection Details:**

#### LPC1768 TRAINER KIT



- 1. Configure the Port 0 and Port 2 as GPIO.
- 2. Configure the Port 2 in input direction and Port 0 in output direction.
- 3. Read the status of the switch 1. If it is pressed, set the direction as 0 for clock wise rotation.
- 4. Else read the status of switch 2. If it is pressed, set the direction as 1 for anticlock wise rotation.
- 5. If the direction is 0, send the data to energize the stepper motor coils in a sequence A-B-C-D else in D-C-B-A sequence.
- 6. Insert an appropriate delay between energizing two consecutive coils.
- 7. Repeat from steps 3 unconditionally.

## **Program:**

```
#include<lpc17xx.h>
#define SW1 11
#define SW2 12
void delay(unsigned int x)
{
    unsignedinti,j;
    for(i=0;i<x;i++)
    {
    for(j=0;j<90000;j++);
    }
}
int main(void)</pre>
```

```
{
unsignedint direct;
LPC PINCON->PINSEL0=0X0000000;
LPC PINCON->PINSEL1=0X0000000;
LPC PINCON->PINSEL4=0X0000000;
LPC GPIO0->FIODIR=0xFFFFFFF;
LPC GPIO2->FIODIR=0X0000000;
LPC GPIO0->FIOCLR=0X00078000;// CLEAR P0.15 TO p0.18
while(1)
 {
if(!((LPC GPIO2->FIOPIN>>SW1)& 0X1))
ł
while(!((LPC GPIO2->FIOPIN>>SW1) & 0X1));
direct=1;
}
else if(!((LPC GPIO2->FIOPIN>>SW2) & 0X1))
while(!((LPC GPIO2->FIOPIN>>SW2) & 0X1));
direct=0;
if(direct==1)
LPC GPIO0->FIOPIN=0X00008000;
delay(15);
LPC GPIO0->FIOPIN=0X00010000;
delay(15);
LPC GPIO0->FIOPIN=0X00020000;
delay(15);
LPC GPIO0->FIOPIN=0X00040000;
delay(15);
}
else
LPC GPIO0->FIOPIN=0X00040000;
delay(15);
LPC GPIO0->FIOPIN=0X00020000;
delay(15);
LPC GPIO0->FIOPIN=0X00010000;
delay(15);
LPC GPIO0->FIOPIN=0x00008000;
```

# delay(15); }

}

## **Connection Details:**



# ALGORITHM:

- 1. Configure port 0 and Port 4 as GPIO.
- 2. Configure the direction of Port 0 and Port 4 as output.
- 3. Create a look up table containing 7 segment equivalent code for the digits 0 to 9 and hexa digits A to F.
- 4. Select the display unit. Send logic 1 to Port line P0.2 for display unit 1 or to Port 4.28 for display unit 2.
- 5. Send each 7 segment equivalent code taken from look up table toPort 0.0 to Port line P0.7 with appropriate delay in between.
- 6. Clear the selected display before sending the next data to display and insert a delay.
- 7. Repeat from step 4.

# **PROGRAM:**

#include<lpc17xx.h>

```
void delay (unsigned int x)
 ł
unsignedinti,j;
for(i=0;i<x;i++)
for(j=0;j<90000;j++);
int main(void)
unsignedint k;
unsigned int a[]=\{0x104, 0x1E5, 0x094, 0x0c4, 0x0
                                               0x065,0x046,0x006,0xE4,
                                               0x004,0x064,0x024,0x004,
                                               0x116,0x104,0x016,0x36;
LPC PINCON->PINSEL0=0X000000;
LPC PINCON->PINSEL9=0X000000;
LPC GPIO0->FIODIR=0XFFFFFFF;
LPC GPIO4->FIODIR=0XFFFFFFF;
LPC GPIO0->FIOPIN=0X1F7;
LPC_GPIO4->FIOPIN=0X1000000;
while(1)
 ł
for(k=0;k<16;k++)
 ł
LPC GPIO0->FIOPIN=a[k];
delay(80);
LPC GPIO0->FIOPIN=0X1F7;
delay(80);
 }
 }
 }
```

# <u>Exp.No: 4</u>

Interface a DAC and generate Triangular and Square waveforms. Connection Details:



It is a string DAC consisting of  $2^N$  resistors in series where N = no. of bits LPC176x DAC has only 1 output pin, referred to as **AOUT**. The Analog voltage at the output of this pin is given as:

$$V_{AOUT} = \frac{VALUE * (V_{REFP} - V_{REFN})}{1024} + V_{REFN}$$

When we have  $V_{REFN} = 0$ , the equation boils down to:

$$V_{AOUT} = \frac{VALUE * V_{REFP}}{1024}$$

Where VALUE is the 10-bit digital value which is to be converted into its Analog counterpart and  $V_{REF}$  is the input reference voltage.

## Pins relating to LPC1768 DAC block:

Pin Description

AOUT (P0.26) Analog Output pin. Provides the converted Analog signal which is referenced to VSSA i.e. the Analog GND. Set Bits[21:20] in PINSEL1

register to "10" to enable this function.

# **DACR register Format: (32 bit register):**

D/A Converter Register (DACR - 0x4008 C000)

This read/write register includes the digital value to be converted to analog, and a bit thattrades off performance vs. power. Bits 5:0 are reserved for future, higher-resolution D/Aconverters.

| Bit   | Symbol | Value    | Description                                           | Reset |
|-------|--------|----------|-------------------------------------------------------|-------|
|       |        |          |                                                       | Value |
| 5:0   | -      | Reserved | User software should not write ones to reserved bits. | NA    |
|       |        |          | The value read from a reserved bit is not defined.    |       |
| 15:6  | VALUE  | 10 bit   | the voltage on the AOUT pin is VALUE × ((VREFP -      | 0     |
|       |        | data     | VREFN/1024) + $VREFN$ .                               |       |
| 16    | BIAS   | 0        | The settling time of the DAC is 1 µs max, and the     | 0     |
|       |        |          | maximum current is 700 $\mu$ A. This allows           |       |
|       |        |          | a maximum update rate of 1 MHz.                       |       |
| 31:17 | -      | Reserved | User software should not write ones to reserved bits. | NA    |
|       |        |          | The value read from a reserved bit is not defined.    |       |

# **ALGORITHM:**

## TRIANGULAR WAVEFORM:

- 1. Configure the Port 0.26 as second alternate function to carry the analog output by using the PINSEL1 register.
- 2. Initialize 10 bit digital dataas 0.
- 3. Send the digital data to the DACR[6:15].
- 4. Increment the digital data and check whether it is equal to  $1024_{10}$ .
- 5. If it is less than  $1024_{10}$ , repeat from step 3.
- 6. Else decrement the digital value and send to the DACR[6:15]
- 7. Check whether the digital data is greater than 0.
- 8. if yes, repeat from step 6 else repeat from step 3.

# **PROGRAM FOR TRIANGULAR WAVEFORM:**

```
#include<lpc17xx.h>
#define p0_26 21
#define ddata 6
uint32_tdacv = 0x0;
```

```
int main()
{
    SystemInit();
    LPC_PINCON -> PINSEL1 = (1<<p0_26);
    while(1)
    {
        while(1)
        {
            dacv++;
            dacv++;
        }
    }
}</pre>
```

```
LPC_DAC->DACR=(dacv<<ddata);

if(dacv>=0x3FF)

{

break;

}

while(1)

{

dacv--;

LPC_DAC->DACR=(dacv<<ddata);

if(dacv<=0x0)

{

break;

}

}
```

# SQUARE WAVEFORM:

- 1. Configure the Port 0.26 as second alternate function to carry the analog output by using the PINSEL1 register.
- 2. Initialize 10 bit digital dataas 0.
- 3. Send the digital data to the DACR[6:15].
- 4. Insert the required delay.
- 5. Send the digital data equivalent to the required analog signal amplitude.( it should be less than 3.3v or 0x3ff).
- 6. Insert the same delay as used in step 4.
- 7. Repeat from step 2 unconditionally.

## Program:

```
#include<lpc17xx.h>
#define p0_26 21
#define ddata 6
uint32_tdacv = 0x0;
void delay(unsigned int x)
{
    unsignedinti,j;
    for (i=0;i<x;i++)
    {
}</pre>
```

```
for(j=0;j<9000;j++);
      }
}
int main()
{
     SystemInit();
     LPC_PINCON -> PINSEL1 = (1<<p0_26);
     while(1)
      {
           while(1)
            {
                 dacv = 0x0;
                 LPC_DAC->DACR=(dacv<<ddata);
                 delay (15);
           dacv = 0x3ff;
             LPC_DAC ->DACR =(dacv<<ddata);
           delay(15);
            }
      }
}
```

# <u>Exp.No:5:</u>

Display "Hello World" message using Internal UART. **Connection Details:** 



## **UART Registers:**

EGD

The below table shows the registers associated with LPC1768 UART.

| Register | Description                                                   |
|----------|---------------------------------------------------------------|
| RBR      | Contains the recently received Data                           |
| THR      | Contains the data to be transmitted                           |
| FCR      | FIFO Control Register                                         |
| LCR      | Controls the UART frame formatting(Number of Data Bits, Stop  |
|          | bits)                                                         |
| DLL      | Least Significant Byte of the UART baud rate generator value. |
| DLM      | Most Significant Byte of the UART baud rate generator value.  |

# UART Register formats or configuration:

## FCR (FIFO Control Register):

LPC1768 has inbuilt 16byte FIFO for Receiver/Transmitter. Thus it can store 16-bytes of data received on UART without overwriting. If the data is not read before the Queue(FIFO) is filled then the new data will be lost and the OVERRUN error bit will be set.

| FCK      |               |          |             |                  |                  |                |
|----------|---------------|----------|-------------|------------------|------------------|----------------|
| 31:8     | 7:6           | 5:4      | 3           | 2                | 1                | 0              |
| RESERVED | RX<br>TRIGGER | RESERVED | DMA<br>MODE | TX FIFO<br>RESET | RX FIFO<br>RESET | FIFO<br>ENABLE |

**Bit 0 – FIFO:**This bit is used to enable/disable the FIFO for thedata received/transmitted. FIFO is Disabled, 1--FIFO is Enabled for both Rx and Tx.

Bit 1 – RX\_FIFO: This is used to clear the 16-byte Rx FIFO.0-No impact.

0---

1-Clears the 16-byte Rx FIFO and the resets the FIFO pointer.

Bit 2 - Tx\_FIFO: This is used to clear the 16-byte Tx FIFO.

0-No impact.

1-Clears the 16-byte Tx FIFO and the resets the FIFO pointer.

Bit 3 – DMA\_MODE:

This is used for Enabling/Disabling DMA mode.

0--Disables the DMA.

1--Enables DMA only when the FIFO(bit-0) bit is SET.

**Bit 7:6 – Rx\_TRIGGER:**This bit is used to select the number of bytes of the receiver data to be written so as to enable the interrupt/DMA.

00-- Trigger level 0 (1 character or 0x01)

01-- Trigger level 1 (4 characters or 0x04)

10-- Trigger level 2 (8 characters or 0x08)

11-- Trigger level 3 (14 characters or 0x0E)

# LCR (Line Control Register):

This register is used for defining the UART frame format ie. Number of Data bits, STOP bits etc.

Format:

| 31:8     | 7    | 6       | 5:4    | 3      | 2        | 1:0         |
|----------|------|---------|--------|--------|----------|-------------|
| Reserved | DLAB | Break   | Parity | Parity | Stop Bit | Word Length |
|          |      | COntrol | Select | Enable | Select   | Select      |

Bit 1:0 : Word Length Select: These two bits are used to select the character length

00-- 5-bit character length

01-- 6-bit character length

10-- 7-bit character length

11-- 8-bit character length

Bit 2 – Stop Bit Selection: This bit is used to select the number (1/2) of stop bits

0-- 1 Stop bit

1-- 2 Stop Bits

Bit 3 – Parity Enable: This bit is used to Enable or Disable the Parity generation and checking.

0-- Disable parity generation and checking.

1-- Enable parity generation and checking.

Bit 5:4 – Parity Selection: These two bits will be used to select the type of parity.

00-- Odd parity. Number of 1s in the transmitted character and the attached parity bit will be odd.

01-- Even Parity. Number of 1s in the transmitted character and the attached parity bit will be even.

- 10-- Forced "1" stick parity.
- 11-- Forced "0" stick parity

## Bit 6 – Break Control:0-- Disable break transmission.

1-- Enable break transmission. Output pin UARTn TXD is forced to logic 0

## Bit 8 – DLAB: Divisor Latch Access Bit:

This bit is used to enable the access to divisor latch.

0-- Disable access to divisor latch

1-- Enable access to divisor latch

#### LSR (Line Status Register):

The is a read-only register that provides status information of the UART TX and RX blocks.

LSR Format:

| 31:8     | 7    | 6    | 5    | 4  | 3  | 2  | 1  | 0   |
|----------|------|------|------|----|----|----|----|-----|
| Reserved | RXFE | TEMT | THRE | BI | FE | PE | OE | RDR |

#### Bit 0 – RDR: Receive Data Ready

This bit will be set when there is a received data in RBR register. This bit will be automatically cleared when RBR is empty.

0-- The UARTn receiver FIFO is empty.

1-- The UARTn receiver FIFO is not empty.

#### **Bit 1 – OE: Overrun Error**

The overrun error condition is set when the UART Rx FIFO is full and a new character is received. In this case, the UARTn RBR FIFO will not be overwritten and the character in the UARTn RSR will be lost. 0-- No overrun

1 Deeffer eren m

1-- Buffer over run

#### **Bit 2 – PE: Parity Error**

This bit is set when the receiver detects a error in the Parity.

0-- No Parity Error

1-- Parity Error

## **Bit 3 – FE: Framing Error**

This bit is set when there is error in the STOP bit(LOGIC 0)

0-- No Framing Error

1-- Framing Error

## Bit 4 – BI: Break Interrupt

This bit is set when the RXDn is held in the spacing state (all zeroes) for one full character transmission

0-- No Break interrupt

1-- Break Interrupt detected.

## Bit 5 – THRE: Transmitter Holding Register Empty

THRE is set immediately upon detection of an empty THR. It is automatically cleared when the THR is written.

0-- THR register is Empty

1-- THR has valid data to be transmitted

## **Bit 6 – TEMT: Transmitter Empty**

TEMT is set when both UnTHR and UnTSR are empty; TEMT is cleared when any of them contain valid data.

0-- THR and/or the TSR contains valid data.

1-- THR and the TSR are empty.

## Bit 7 – RXFE: Error in Rx FIFO

This bit is set when the received data is affected by Framing Error/Parity Error/Break Error.

0-- RBR contains no UARTn RX errors.

1-- RBR contains at least one RX error.

**TER (Transmitter Enable register):** This register is used to Enable/Disable the transmission **TER** Format:

| 31:8     | 7    | 6-0      |
|----------|------|----------|
| Reserved | TXEN | Reserved |

Bit 7 – TXEN: Trsnamitter Enable

When this bit is 1, the data written to the THR is output on the TXD pin. If this bit is cleared to 0 while a character is being sent, the transmission of that character is completed, but no further characters are sent until this bit is set again. In other words, a 0 in this bit blocks the transfer of characters. •Note: By default this bit will be set after Reset.

## **Baudrate Calculation**

LPC1768 generates the baud rate depending on the values of DLM, DLL.

## Baudrate = PCLK/ (16 \* (( 256 \* DLM) + DLL) \* (1+ DivAddVal/MulVal))

where, DLM=0, DLL= , (DivaddVal/MulVal)=0.

## **Steps for Configuring UART0**

Below are the steps for configuring the UARTO.

1. Configure the P0.2 and P0.3 as first alternate function UART0 function using PINSEL0 register.

2.Configure the FCR for enabling the FIFO and Reset both the Rx/Tx FIFO.

- 3. Configure LCR for 8-data bits, 1 Stop bit, Disable Parity and Enable DLAB.
- 4. Calculate the DLM, DLL values for required baudrate from PCLK.
- 6. Update the DLM, DLL with the calculated values (i.e DLM=0; DLL=163).

7. Finally clear DLAB to disable the access to DLM,DLL.

After this the UART will be ready to Transmit/Receive Data at the specified baudrate, by sending the string character by character.

```
Program:
```

```
#include<lpc17xx.h>
void U0Write( char txdata)
{
while(!(LPC UART0->LSR & 0x20));
LPC UART0->THR=txdata;
}
void initUART0(void)
{
LPC PINCON->PINSEL0 = (1 << 4) | (1 << 6);
LPC UART0->LCR=0x83;
LPC UART0->DLL=163;
LPC UART0->DLM=0;
LPC UART0->FCR =0x7;
LPC UART0->FDR=0x0;
LPC UARTO->LCR = 0x03;
}
int main(void)
{
```

```
charmsg[]= "Hello World";
int i=0;
initUART0();
```

```
for(i=0;msg[i];i++)
```

```
{
U0Write(msg[i]);
```

```
}
}
```

# Exp.No:6:

Demonstrate the use of an external interrupt to toggle an LED On/Off. Connection details:

#### LPC1768 TRAINER KIT



## **Description:**

| LPC17    | 68 has four ex | ternal interrupt | s EINT0-EINT3 |
|----------|----------------|------------------|---------------|
| Port Pin | PINSEL_FUNC_0  | PINSEL_FUNC_1    | PINSEL_FUNC_2 |
| P2.10    | GPIO           | EINT0            | NMI           |
| P2.11    | GPIO           | EINT1            | I2STX_CLK     |
| P2_12    | GPIO           | EINT2            | I2STX_WS      |
| P2.13    | GPIO           | EINT3            | I2STX_SDA     |

#### LPC1768 External Interrupts



## Note:

• since the two general purpose switches have been connected with port lines P2.11 and P2.12, only two interrupts EINT1 and EINT2 have been used in this experiment.

• By pressing the switch, the corresponding interrupt signal will be generated.

# **EINT Registers:**

Below table shows the registers associated with LPC1768 external interrupts.

| Register | Description                                               |
|----------|-----------------------------------------------------------|
| PINSELx  | To configure the pins as External Interrupts              |
| EXTINT   | External Interrupt Flag Register contains interrupt flags |
|          | for EINT0,EINT1, EINT2 & EINT3.                           |
| EXTMODE  | External Interrupt Mode register(Level/Edge Triggered)    |
| EXTPOLAR | External Interrupt Polarity(Falling/Rising Edge, Active   |
|          | Low/High)                                                 |

## EXTINT Format:

| 31:4     | 3     | 2     | 1     | 0     |
|----------|-------|-------|-------|-------|
| RESERVED | EINT3 | EINT2 | EINT1 | EINT0 |

EINTx: Bits will be set whenever the interrupt is detected on the particular interrupt pin.If the interrupts are enabled then the control goes to ISR.

Writing one to specific bit will clear the corresponding interrupt.

EXTMODE Format:

|    | 31:4    |    | 3       |    | 2       |    | 1       |    | 0       |  |
|----|---------|----|---------|----|---------|----|---------|----|---------|--|
| RI | ESERVED | ΕŻ | KTMODE3 | ΕZ | KTMODE2 | ΕZ | KTMODE1 | ΕZ | KTMODE0 |  |

EXTMODEx: This bits is used to select whether the EINTx pin is level or edge Triggered.

0: EINTx is Level Triggered.

1: EINTx is Edge Triggered.

EXTPOLAR Format:

| 31:4     | 3         | 2         | 1         | 0         |
|----------|-----------|-----------|-----------|-----------|
| RESERVED | EXTPOLAR3 | EXTPOLAR2 | EXTPOLAR1 | EXTPOLAR0 |

EXTPOLARx: This bits is used to select polarity(LOW/HIGH,FALLING/RISING) of the EINTx interrupt depending on the EXTMODE register.

0: EINTx is Active Low or Falling Edge (depending on EXTMODEx).

1: EINTx is Active High or Rising Edge (depending on EXTMODEx).

# **ALGORITHM:**

1. Configure the pins p2.11 AND p2.12 as external interrupts in PINSELx register.

- 2. Clear any pending interrupts in EXTINT.
- 3. Configure the EINTx as Edge/Level triggered in EXTMODE register.
- 4. Select the polarity(Falling/Rising Edge, Active Low/High) of the interrupt in EXTPOLAR register.
- 5. Finally enable the interrupts by calling NVIC\_EnableIRQ() with IRQ number.

6. Define ISR1 to toggle the status of LED 1 for EINT1 and ISR2 to toggle the status of LED2 for EINT2.

# **PROGRAM:**

#include <lpc17xx.h>

```
#define PINSEL EINT1 22 // interrupt 1
#define PINSEL EINT2 24 // interrupt 2
#define LED1
                   25 // led at p1.25
#define LED2
                   26 // led at p1.26
#define SBIT EINT1
                      1 //extint bit 1
#define SBIT EINT2
                      2 //extint bit 2
#define SBIT_EXTMODE1_1
                                 //extint mode bit 1
#define SBIT_EXTMODE2_2
                                 //extint mode bit 2
#define SBIT EXTPOLAR1 1 //extint polarity mode bit 1
#define SBIT EXTPOLAR2 2 //extint polarity mode bit 2
void EINT1 IRQHandler(void)
  LPC SC->EXTINT = (1<<SBIT EINT1); /* Clear Interrupt Flag */
  LPC GPIO1->FIOPIN ^= (1<< LED1); /* Toggle the LED1 everytime INTR1 is generated */
}
void EINT2 IRQHandler(void)
```

```
LPC_SC->EXTINT = (1<<SBIT_EINT2); /* Clear Interrupt Flag */
LPC_GPIO1->FIOPIN ^= (1<< LED2); /* Toggle the LED2 everytime INTR2 is generated */
}
```

int main()
{
SystemInit();

```
LPC SC->EXTINT = (1<<SBIT EINT1) | (1<<SBIT EINT2); /* Clear Pending interrupts */
  LPC PINCON->PINSEL4 = (1<<PINSEL EINT1) | (1<<PINSEL EINT2); /* Configure
P2 11,P2 12 as EINT1/2 */
  LPC SC->EXTMODE = (1 \leq \text{SBIT EXTMODE1}) | (1 \leq \text{SBIT EXTMODE2});
/* Configure EINTx as Edge Triggered*/
  LPC SC->EXTPOLAR = (1<<SBIT EXTPOLAR1)| (1<<SBIT EXTPOLAR2); /* Configure
EINTx as Falling Edge */
                                                          /* Configure LED pins as OUTPUT */
  LPC GPIO1->FIODIR = (1 \leq LED1) | (1 \leq LED2);
  LPC GPIO1->FIOPIN = 0x00;
NVIC EnableIRQ(EINT1 IRQn); /* Enable the EINT1,EINT2 interrupts */
NVIC EnableIRQ(EINT2 IRQn);
while(1)
  {
   // Do nothing
  ļ
}
```

•

## Exp.No:7 (Beyond Syllabus)

Using the Internal PWM module of ARM controller generate PWM and vary itsduty cycle. **Connection Details:** 



LPC1768 has 6 PWM output pins which can be used as 6-Single edged or 3-Double edged. There as seven match registers to support these 6 PWM output signals. Below block diagram shows the PWM pins and the associated Match(Duty Cycle) registers.

PWM channel 1(Port Line P2.0) has been connected to the PWM output point in a trainer Kit.So configure the P2.0 as a first alternate function to carry the PWM channel 1output using PINSEL4 register.

# LPC1768 PWM Registers

The below table shows the registers associated with LPC1768 PWM Module.

| Register | Description                                                                                      |
|----------|--------------------------------------------------------------------------------------------------|
| ID       | Interrupt Register: The IR can be read to identify which of eight possible interrupt sources are |
| ш        | pending. Writing Logic-1 will clear the corresponding interrupt.                                 |
| TCD      | Timer Control Register: The TCR is used to control the Timer Counter                             |
| ICK      | functions(enable/disable/reset).                                                                 |
| тс       | Timer Counter: The 32-bit TC is incremented every PR+1 cycles of PCLK. The TC is controlled      |
| IC       | through the TCR.                                                                                 |
| PR       | Prescalar Register: This is used to specify the Prescalar value for incrementing the TC.         |
| DC       | Prescale Counter: The 32-bit PC is a counter which is incremented to the value stored in PR.     |
| rC       | When the value in PR is reached, the TC is incremented.                                          |
| MCP      | Match Control Register: The MCR is used to control the reseting of TC and generating of          |
| MCK      | interrupt whenever a Match occurs.                                                               |
| MR0      | Match Register: This register hold the max cycle Time(Ton+Toff).                                 |
| MR1-     | Match Registers: These registers holds the Match value(PWM Duty) for corresponding PWM           |
| MR6      | channels(PWM1-PWM6).                                                                             |
| DCD      | PWM Control Register: PWM Control Register. Enables PWM outputs and selects PWM channel          |
| PCK      | types as either single edge or double edge controlled.                                           |
| LER      | Load Enable Register: Enables use of new PWM values once the match occurs.                       |

#### **Register Configuration**

The below table shows the registers associated with LPC1768 PWM.

|          | -          | -        |               | 0              |
|----------|------------|----------|---------------|----------------|
| 31:4     | 3          | 2        | 1             | 0              |
| Reserved | PWM Enable | Reserved | Counter Reset | Counter Enable |

#### **Bit 0 – Counter Enable**

This bit is used to Enable or Disable the PWM Timer and PWM Prescalar Counters

0- Disable the Counters

1- Enable the Counter incrementing.

#### Bit 1 – Counter reset

This bit is used to clear the PWM Timer and PWM Prescalar Counter values.

0- Do not Clear.

1- The PWM Timer Counter and the PWM Prescale Counter are synchronously reset on the next positive edge of PCLK.

#### Bit 3 – PWM Enable

Used to Enable or Disable the PWM Block.

0- PWM Disabled

1- PWM Enabled

#### MCR

| 31:21    | 20      | 19      | 18      | - 5       | 4       | 3       | 2              | 1              |
|----------|---------|---------|---------|-----------|---------|---------|----------------|----------------|
| Reserved | PWMMR6S | PWMMR6R | PWMMR6I | - PWMMR1S | PWMMR1R | PWMMR1I | <b>PWMMR0S</b> | <b>PWMMR0R</b> |

#### PWMMRxI

This bit is used to Enable or Disable the PWM interrupts when the PWMTC matches PWMMRx (x:0-6)

0- Disable the PWM Match interrupt

1- Enable the PWM Match interrupt.

#### PWMMRxR

This bit is used to Reset PWMTC whenever it Matches PWMRx(x:0-6)

0- Do not Clear.

1- Reset the PWMTC counter value whenever it matches PWMRx.

#### **PWMMRxS**

This bit is used to Stop the PWMTC, PWMPC whenever the PWMTC matches PWMMRx(x:0-6).

0- Disable the PWM stop o match feature

1- Enable the PWM Stop feature. This will stop the PWM whenever the PWMTC reaches the Match register value.

#### PCR

31:15 14-9 8-7 6-2 1-0

## Unused PWMENA6-PWMENA1 Unused PWMSEL6-PWMSEL2 Unused

#### PWMSELx

This bit is used to select the single edged and double edge mode form PWMx (x:2-6)

0- Single Edge mode for PWMx

1- Double Edge Mode for PWMx.

#### PWMENAx

This bit is used to enable/disable the PWM output for PWMx(x:1-6)

0- PWMx Disable.

1- PWMx Enabled.

#### LER

31-7 6 5 4 3 2 1 0 Unused LEN6 LEN5 LEN4 LEN3 LEN2 LEN1 LEN0

#### Unused LEN6 LEN5 LEN4 LEN3 LEN

#### LENx

This bit is used Enable/Disable the loading of new Match value whenever the PWMTC is reset(x:0-6) PWMTC will be continously incrementing whenever it reaches the PWMMRO, timer will be reset depeding on PWMTCR configuration. Once the Timer is reset the New Match values will be loaded from MR0-MR6 depending on bits set in this register.

0- Disable the loading of new Match Values

1- Load the new Match values from MRx when the timer is reset.

#### **PWM Working**

The TC is continuously incremented and once it matches the MR1(Duty Cycle) the PWM pin is pulled Low. TC still continues to increment and once it reaches the Cycle time(Ton+Toff) the PWM module does the following things:

- Reset the TC value.
- Pull the PWM pin High.
- Loads the new Match register values.

#### **Steps to Configure PWM**

- 1. Configure the GPIO pins for PWM operation in respective PINSEL register.
- 2. Configure TCR to enable the Counter for incrementing the TC, and Enable the PWM block.
- 3. Set the required pre-scalar value in PR. In our case it will be zero.
- 4. Configure MCR to reset the TC whenever it matches MR0.
- 5. Update the Cycle time in MR0. Here, it will be 100.
- 6. Load the Duty cycles for required PWM1 channel in respective match register MR1.
- 7. Enable the bits in LER register to load and latch the new match values.
- 8. Enable the pwm channel 1 in PCR register.

#### **PROGRAM:**

```
#include<lpc17xx.h>
void delay(unsigned int k)
{
    unsignedinti,j;
    for(i=0;i<k;i++)
    for(j=0;j<60000;j++);
    }
#define SBIT_CNTEN 0
#define SBIT_PWMEN 2
#define SBIT_PWMR0R 1</pre>
```

```
#define SBIT PWMENA1 9
#define PWM 10
int main()
{
int dc;
SystemInit();
LPC_PINCON->PINSEL4=(1<<PWM_1);
LPC PWM1->TCR=(1<<SBIT CNTEN)|(1<<SBIT PWMEN);
LPC PWM1->PR=0x00;
LPC PWM1->MCR=(1<<SBIT PWMMR0R);
LPC PWM1->MR0=100;
LPC PWM1->PCR=(1<<SBIT PWMENA1);
while(1)
{
for(dc=0;dc<100;dc++)
ł
LPC_PWM1->MR1=dc;
delay(5);
for(dc=100;dc>0;dc--)
LPC PWM1->MR1=dc;
delay(5);
}
```

# EXP.NO:8:

Interface and Control a DC Motor. Connection details:



- Use all the register configuration as used in PWM experiment .
- Use PWM channel 3(P2.2) instead of PWM channel 1(P2.0).

# <u>Algorithm:</u>

## Steps to Configure PWM

- 1. Configure the GPIO pins for PWM operation in respective PINSEL register.
- 2. Configure TCR to enable the Counter for incrementing the TC, and Enable the PWM block.
- 3. Set the required pre-scalar value in PR. In our case it will be zero.
- 4. Configure MCR to reset the TC whenever it matches MR0.
- 5. Update the Cycle time in MR0. Here, it will be 100.
- 6. Load the Duty cycles for required PWM3 channel in respective match register MR3.
- 7. Enable the bits in LER register to load and latch the new match values.
- 8. Enable the pwm channel 1 in PCR register.

# steps to control the speed of DC motor:

# After configuring the PWM module,

1. Read the status of the switch 1. For each press, decrease the MR3 by 10. check whether it is greater than 0.Else assume MR3 is always zero for further continuous press of Switch 1.

2. Read the status of the switch 2. For each press, increase the MR3 by 10. Check whether it is less than 100.Else assume MR3 is always 99 for further continuous press of Switch 2.

# **PROGRAM:**

```
#include<lpc17xx.h>
#define cnten 0
#define pwnen 2
#define P2 2
                 4
#define MROR 1
#define pwnch3 11
#define SW1 11
#define SW2 12
void delay(unsigned int k)
ł
unsignedintx.y;
for(x=0:x<k:x++)
for(y=0;y<90000;y++);
int main (void)
ł
inti=100;
LPC PINCON->PINSEL4=(1 \leq 2);
LPC PWM1->TCR=(1 < \text{cnten}) | (1 < \text{pwnen});
LPC PWM1->MCR=(1<<MROR);
LPC PWM1->PCR=(1<<pwnch3);
LPC PWM1->PR=0x0;
LPC PWM1->MR0=100;
while(1)
{
LPC PWM1->MR3=i;
delay(5);
if(!((LPC GPIO2->FIOPIN>>SW1)&0X1))
{
while(!((LPC GPIO2->FIOPIN>>SW1)&0X1));
i=i-10;
if(i<=0)
i=0;
else if(!((LPC GPIO2->FIOPIN>>SW2)&0X1))
while(!((LPC GPIO2->FIOPIN>>SW2)&0X1));
i=i+10;
if(i>100)
i=99:
```

}
}

## Exp.No: 9:

Interface a 4x4 keyboard and display the key code on an LCD. **Connection Details:** 



#### **Program:**

#include "lpc17xx.h"
#include "lcd.h"

| #define COL1     | 0    |                                                                  |
|------------------|------|------------------------------------------------------------------|
| #define COL2     | 1    |                                                                  |
| #define COL3     | 4    |                                                                  |
| #define COL4     | 8    |                                                                  |
| #define ROW1     |      | 9                                                                |
| #define ROW2     |      | 10                                                               |
| #define ROW3     |      | 14                                                               |
| #define ROW4     |      | 15                                                               |
| #define COLMASK  |      | ((1< <col1) col2)="" col3)="" col4))<="" td=""  (1<<=""></col1)> |
| #define ROWMASK  | -    | ((1< <row1) row2)="" row3)="" row4))<="" td=""  (1<<=""></row1)> |
| #define KEY_CTRL | _DIR | LPC_GPIO1->FIODIR                                                |

#define KEY\_CTRL\_CLR LPC\_GPIO1->FIOCLR #define KEY\_CTRL\_PIN LPC\_GPIO1->FIOPIN

```
temp=(data) & COLMASK;
```

```
KEY_CTRL_CLR |= COLMASK;
KEY_CTRL_SET |= temp;
}
```

```
int main (void)
{
unsigned char key, i;
unsigned char rval[] = \{0x77, 0x07, 0x0d\};
unsigned char keyPadMatrix[] =
{
  '4','8','B','F',
  '3','7','A','E',
  '2','6','0','D',
  '1','5','9','C'
};
SystemInit();
init lcd();
 KEY CTRL DIR = COLMASK; //Set COLs as Outputs
 KEY CTRL DIR &= ~(ROWMASK); // Set ROW lines as Inputs
 lcd putstring16(0,"Press HEX Keys..");// 1st line display
 lcd_putstring16(1,"Key Pressed = ");// 2<sup>nd</sup> line display
while (1)
{
key = 0;
for(i = 0; i < 4; i + +)
  ł
    // turn on COL output one by one
               col write(rval[i]);
    // read rows - break when key press detected
if (!(KEY CTRL PIN & (1<<ROW1)))
```

## break;

```
key++;
if (!(KEY CTRL_PIN & (1<<ROW2)))
break;
kev++:
if (!(KEY_CTRL_PIN & (1<<ROW3)))
break;
key++;
             if (!(KEY CTRL PIN & (1<<ROW4)))
break;
key++;
  }
       if (key == 0x10)
             lcd putstring16(1,"Key Pressed = ");
       else
              {
                    lcd gotoxy(1,14);
                    lcd putchar(keyPadMatrix[key]);
              }
 }
}
```

## LCD code:-

#include "lpc17xx.h" #include "lcd.h" voidLcd CmdWrite(unsigned char cmd); voidLcd DataWrite(unsigned char dat); #define LCDRS 9 #define LCDRW 10 #define LCDEN 11 #define LCD D4 19 #define LCD D5 20 #define LCD D6 21 #define LCD D7 22 #define LcdData LPC GPIO0->FIOPIN #define LcdControl LPC GPIO0->FIOPIN #define LcdDataDirn LPC GPIO0->FIODIR #define LcdCtrlDirn LPC GPIO0->FIODIR #define LCD ctrlMask ((1<<LCDRS)|(1<<LCDRW)|(1<<LCDEN))

```
#define LCD_dataMask ((1<<LCD_D4)|(1<<LCD_D5)|(1<<LCD_D6)|(1<<LCD_D7))
void delay(unsigned int count)
int j=0, i=0;
for (j=0;j<count;j++)
for (i=0;i<30;i++);
voidsendNibble(char nibble)
LcdData&=~(LCD dataMask);
                                       // Clear previous data
LcdData = (((nibble >> 0x00) \& 0x01) << LCD D4);
LcdData = (((nibble >> 0x01) \& 0x01) << LCD D5);
LcdData = (((nibble >> 0x02) \& 0x01) << LCD D6);
LcdData = (((nibble >> 0x03) \& 0x01) << LCD D7);
}
voidLcd CmdWrite(unsigned char cmd)
sendNibble((cmd>> 0x04) & 0x0F); //Send higher nibble
LcdControl&= \sim(1<<LCDRS); // Send LOW pulse on RS pin for selecting Command register
LcdControl&= ~(1<<LCDRW); // Send LOW pulse on RW pin for Write operation
LcdControl |= (1<<LCDEN); // Generate a High-to-low pulse on EN pin
delay(100):
LcdControl\& = ~(1 << LCDEN);
delay(10000);
sendNibble(cmd& 0x0F);
                             //Send Lower nibble
LcdControl&= ~(1<<LCDRS); // Send LOW pulse on RS pin for selecting Command register
LcdControl&= ~(1<<LCDRW); // Send LOW pulse on RW pin for Write operation
LcdControl |= (1<<LCDEN); // Generate a High-to-low pulse on EN pin
delay(100);
LcdControl\& = ~(1 << LCDEN);
delay(1000);
}
voidLcd DataWrite(unsigned char dat)
sendNibble((dat>> 0x04) & 0x0F); //Send higher nibble
LcdControl |= (1<<LCDRS); // Send HIGH pulse on RS pin for selecting data register
LcdControl&= ~(1<<LCDRW); // Send LOW pulse on RW pin for Write operation
LcdControl |= (1<<LCDEN); // Generate a High-to-low pulse on EN pin
delay(100);
LcdControl&=~(1<<LCDEN);
```

```
sendNibble(dat& 0x0F);
                              //Send Lower nibble
LcdControl |= (1<<LCDRS); // Send HIGH pulse on RS pin for selecting data register
LcdControl&= ~(1<<LCDRW); // Send LOW pulse on RW pin for Write operation
LcdControl |= (1<<LCDEN); // Generate a High-to-low pulse on EN pin
delay(100);
LcdControl\& = ~(1 << LCDEN);
delay(1000);
voidled clear(void)
Lcd CmdWrite(0x01);
intlcd gotoxy( unsigned char x, unsigned char y)
unsigned char retval = TRUE;
if( (x > 1) \&\& (y > 15) )
retval = FALSE;
 }
else
if( x == 0 ) Lcd CmdWrite( 0x80 + y );
       else if( x==1 ) Lcd CmdWrite( 0xC0 + y );
returnretval;
voidled putchar( unsigned char c )
Lcd DataWrite( c );
voidlcd_putstring( char *string )
while (* string != ' 0')
lcd_putchar( *string );
string++;
 }
void lcd putstring16( unsigned char line, char *string )
unsigned char len = 16;
```

delay(1000);

```
lcd_gotoxy( line, 0 );
while(*string != '\0' &&len--)
{
lcd_putchar( *string );
string++;
}
}
voidinit_lcd( void )
{
LcdDataDirn |= LCD_dataMask; // Configure all the LCD pins as output
LcdCtrlDirn |= LCD_ctrlMask;
```

// Initialize Lcd in 4-bit mode Lcd\_CmdWrite(0x03); delay(2000); Lcd\_CmdWrite(0x03); delay(1000); Lcd\_CmdWrite(0x03); delay(100); Lcd\_CmdWrite(0x2); Lcd\_CmdWrite(0x28); Lcd\_CmdWrite(0x08); Lcd\_CmdWrite(0x06); Lcd\_CmdWrite(0x01); delay(1); // display on

}

#### <u>Exp.No:10:</u>

Measure Ambient temperature using a sensor and SPI ADC IC.

#### Serial Peripheral Interface (SPI)

Serial Peripheral Interface (SPI) is an interface bus commonly used to send data between microcontrollers and small peripherals such as shift registers, sensors, and SD cards. It uses separate clock and data lines, along with a select line to choose the device.

ADC (Analog to Digital Converter):

The Microchip Technology Inc. MCP3202 is a successive approximation 12-bit Analog-to-Digital (A/D) Converter with on-board sample and hold circuitry. The MCP3202 is programmable to provide a single pseudo-differential input pair or dual single-ended inputs. Differential Nonlinearity (DNL) is specified at ±1 LSB, and Integral Nonlinearity (INL) is offered in ±1 LSB (MCP3202-B) and ±2 LSB (MCP3202-C) versions. Communication with the device is done using a simple serial interface compatible with the SPI protocol. The device is capable of conversion rates of up to 100ksps at 5V and 50ksps at 2.7V.The MCP3202 is a Dual Channel 12-Bit A/D Converter with SPI Serial Interface By Microchip . In this tutorial i will interface this ADC using lpc1768 microcontroller using SPI Protocol in mode(0,0) . Maximum clock rate supported by MCP3202 is 1.8 MHz.

Fsample= 100 KSPS

Fclk = 18\*Fsample

#### **Configuring SPI Control Register :**

|                                                                               |            | Name                              | Function                                                  |      |       |            |
|-------------------------------------------------------------------------------|------------|-----------------------------------|-----------------------------------------------------------|------|-------|------------|
| CS/SHDN 1 8 V <sub>DD</sub> /V <sub>REF</sub><br>CH0 2 6 7 CLK<br>CH1 3 9 6 D |            | V <sub>DD</sub> /V <sub>REF</sub> | +2.7V to 5.5V Power Supply and<br>Reference Voltage Input |      |       |            |
|                                                                               |            | CH0                               | Channel 0 Analog Input                                    |      |       |            |
|                                                                               |            | CH1                               | Channel 1 Analog Input                                    |      |       |            |
| V <sub>ss</sub> 4                                                             |            | CLK                               | Serial Clock                                              |      |       |            |
|                                                                               |            | D <sub>IN</sub>                   | Serial Data In                                            |      |       |            |
|                                                                               |            | D <sub>OUT</sub>                  | Serial Data Out                                           |      |       |            |
|                                                                               |            | CS/SHDN                           | Chip Select/Shutdown Input                                |      |       |            |
| Sorial                                                                        | Parinharal | inter                             | rface allows                                              | high | speed | synchronou |

communication betweenlpc1768microcontrollers.



first we need to send start bit, it is last bit of first byte we are going to send to ADC and then we have to select Configuration modes.there are two modes single ended and pseudo differential mode here choose single ended mode. MSBF bit choses order of format of byte either MSB first or LSB first herechoose MSB bit first format so MSBF=1.ransferingSecondbyte=0xA0forchannel0and Secondbyte=0xE0 for channel 1. ADC will return B11 to B8 of data in the lower nibble of byte so we need to perform some mathematical manipulation. after that we need to send any byte to receive third byte of data.



Pin Assignment with LPC1768:

|             | SPI - ADC | LPC1768 Lines |
|-------------|-----------|---------------|
|             | CS        | P0.28         |
| MCP<br>3202 | CLK       | P0.27         |
|             | Dout      | P3.26         |

| Din | P3.25 | CS 1 CS/SHDN Vdd/Vrof 8<br>2 CH0 CLK<br>4 Vss Din 5 DIN<br>MCP3202 |
|-----|-------|--------------------------------------------------------------------|
|-----|-------|--------------------------------------------------------------------|

#### **ALGORITHM:**

#### PROGRAM:

#include <LPC17xx.H> #include <stdint.h> #include <stdio.h> #include "delay.h" #include "spi\_manul.h" #include "lcd.h" #define pulse val 2 main() { unsignedintspi rsv=0; float vin; charbuf[20]; SystemInit (); lcd init(); lcd str("SPI 3202-b"); delay(60000);delay(60000); while(1) { lcd clr(); lcd cmd(0x80); spi\_rsv = spi\_data1(15); vin = ((spi rsv & 0xfff) \* (3.3)) / 4096;sprintf(buf,"Temp: %0.2f degC",(vin\*100) ); lcd str(buf); delay(50000); delay(50000); } }

```
SPI ADC data fetching program:-
#include <LPC17xx.H>
#include "delay.h"
#define pulse val 2
#define CLK 1<<27
#define
             CS
                    1<<28
#define DDOUT 26
#define
             DOUT 1<<25
#define
             DIN
                    1<<26
#define spi stst 0
unsignedintspi data(char sel)
{
charclks = 4;
LPC GPIO0->FIODIR |= CS|CLK;
LPC GPIO3->FIODIR = DOUT;
LPC GPIO0->FIOSET = CS|CLK;
LPC GPIO3->FIOCLR
                          = DOUT:
nop delay(100);
#if spi stst
if (LPC GPIO3->FIOPIN & DIN)
 {
return 'P';
 }
#endif
 LPC GPIO0->FIOCLR = CS;
      nop delay(pulse val);
while(clks)
 {
       LPC GPIO0->FIOCLR = CLK;
      nop delay(pulse val);
       LPC GPIO3->FIOPIN = (sel \& 1) << DDOUT;
      sel = sel >> 1;
       LPC GPIO0->FIOSET = CLK;
      nop delay(pulse val);
      clks--;
 }
  LPC GPIO0->FIOCLR = CLK;
      nop delay(pulse val);
if (!( LPC GPIO3->FIOPIN & DIN ) )
 ł
return 'U';
 }
             clks = 12;
```
```
while(clks)
  ł
clks--;
      LPC GPIO0->FIOCLR = CLK;
      nop delay(pulse val);
      LPC GPIO0->FIOSET = CLK;
      nop delay(pulse val);
 }
      nop delay(pulse val);
if (!( LPC GPIO3->FIOPIN & DIN ) )
 ł
return 'U';
 }
return 'Z';
unsignedint spi data1(char sel)
{
unsignedintspi reg=0;
charclks = 12;
LPC GPIO0->FIODIR |= CS|CLK;
LPC GPIO3->FIODIR = DOUT;
LPC GPIO0->FIOSET = CS|CLK;
LPC GPIO3->FIOSET
                         = DOUT;
LPC_GPIO3->FIOPIN
                         = DIN;
nop delay(100);
LPC GPIO0->FIOCLR = CS;
//start condi
LPC GPIO0->FIOCLR = CLK;
LPC GPIO3->FIOSET
                         = DOUT:
nop delay(pulse val);
LPC GPIO0->FIOSET = CLK;
nop delay(5);
//single mode
LPC GPIO0->FIOCLR = CLK;
LPC GPIO3->FIOSET
                         = DOUT;
nop delay(pulse val);
LPC GPIO0->FIOSET = CLK;
nop delay(5);
//chanl 1
LPC GPIO0->FIOCLR = CLK;
 LPC GPIO3->FIOSET
                         = DOUT;
```

```
nop delay(pulse val);
 LPC GPIO0->FIOSET = CLK;
nop delay(5);
 //msb first
 LPC GPIO0->FIOCLR = CLK;
 LPC GPIO3->FIOSET
                          = DOUT;
nop delay(pulse val);
 LPC GPIO0->FIOSET = CLK;
nop delay(5);
 //smpling
// LPC GPIO0->FIOCLR = CLK;
// nop delay(pulse val);
// LPC_GPIO0->FIOSET = CLK;
// nop_delay(2);
 //null bit
 LPC GPIO0->FIOCLR = CLK;
nop delay(pulse val);
LPC GPIO0->FIOSET = CLK;
// while ( (LPC GPIO3->FIOPIN & DIN ) == DIN );
// if( !( LPC GPIO3->FIOPIN & DIN ) );
// {
//
    return 'U';
// }
nop delay(5);
      clks = 12;
      while(clks)
       ł
        LPC GPIO0->FIOCLR = CLK;
nop delay(pulse val);
 LPC GPIO0->FIOSET = CLK;
if( ( LPC GPIO3->FIOPIN & DIN ) )
spi reg \mid = 1 \ll (clks-1);
 }
else
 {
      spi reg = spi reg;
 }
clks--;
nop delay(5);
nop delay(1);
returnspi reg;
}
```

Department of ECE, Atria IT

### LCD display program:-

```
#include <LPC17xx.H>
#include "delay.h"
#define RRW (7<<9)
#define DATA L (15<<19)
voidled pin(void)
ł
 LPC GPIO0->FIODIR \mid = RRW|DATA L;
}
voidled cmd(unsigned char cmd)
ł
       LPC GPIO0->FIOPIN =( ( ( \text{ cmd} \& 0xf0 ) >> 4) << 19 ) | (1 << 11);
       delay(200);
       LPC GPIO0->FIOPIN =( ( ( \text{ cmd} \& 0xf0 ) >> 4 ) << 19 );
       LPC GPIO0->FIOCLR \mid = RRW|DATA L;
       delay(10);
       LPC GPIO0->FIOPIN = ( ( ( \text{ cmd} \& 0xf ) ) << 19 ) | (1<<11);
       delay(200);
       LPC GPIO0->FIOPIN = ((( \operatorname{cmd\&} 0xf)) << 19);
}
voidled data(unsigned char cmd)
LPC GPIO0->FIOPIN =(1<<9) ( ( \operatorname{cmd} \& 0xf0 )>> 4) << 19 ) (1<<11);
       delay(200);
       LPC GPIO0->FIOPIN =( ( ( \text{ cmd} \& 0xf0 ) >> 4 ) << 19 );
       LPC GPIO0->FIOCLR |= RRW|DATA L;
       delay(10);
       LPC GPIO0->FIOPIN = (1 \le 9) (( ( cmd& 0xf )) \le 19) | (1 << 11);
       delay(200);
       LPC GPIO0->FIOPIN = ((( \operatorname{cmd\&} 0xf)) << 19);
voidled init(void)
ł
lcd pin();
lcd cmd(0x03);
delay(3000);
lcd cmd(0x03);
```

Department of ECE, Atria IT

```
delay(1000);
lcd_cmd(0x03);
delay(100);
lcd cmd(0x2);
lcd\_cmd(0x28);
lcd cmd(0x0e);
lcd\_cmd(0x06);
lcd cmd(0x01);
delay(1);
}
voidlcd_str(char *lstr)
{
while(*lstr)
  ł
lcd data(*lstr);
       lstr++;
 }
}
voidled clr(void)
{
       lcd cmd(0x03);
delay(10);
lcd_cmd(0x2);
lcd cmd(0x28);
lcd cmd(0x0e);
lcd cmd(0x06);
lcd cmd(0x01);
delay(10);
}
```

## Exp.No:11: (Beyond syllabus)

Interface 12 bit internal ADC to convert the analog to digital and display the same on LCD. Connection Details:



## **ALGORITHM:**

### **Steps for Configuring ADC**

- 1. Configure the GPIO pin for ADC function using PINSEL register.
- 2. Enable the CLock to ADC module.
- 3. Deselect all the channels and Power on the internal ADC module by setting ADCR.PDN bit.
- 4. Select the Particular channel for A/D conversion by setting the corresponding bits in ADCR.SEL
- 5. Set the ADCR.START bit for starting the A/D conversion for selected channel.
- 6. Wait for the conversion to complete, ADGR.DONE bit will be set once conversion is over.
- 7. Read the 12-bit A/D value from ADGR.RESULT.
- 8. Use it for further processing or just display on LCD.

## **PROGRAM:**

```
#include "lpc17xx.h"
#include "lcd.h"
#define VREF
               3.3 //Reference Voltage at VREFP pin, given VREFN = 0V(GND)
#define ADC CLK EN (1<<12)
#define SEL AD0 2 (1<<2) //Select Channel AD0.2
#define CLKDIV 1 //ADC clock-divider (ADC CLOCK=PCLK/CLKDIV+1) = 12.5Mhz
(a) 25Mhz PCLK
                (1<<21) //setting it to 0 will power it down
#define PWRUP
#define START CNV (1 \le 24) / 001 for starting the conversion immediately
#define ADC_DONE (1U<<31) //define it as unsigned value or compiler will throw #61-D
warning
#define ADCR SETUP SCM ((CLKDIV<<8) | PWRUP)
Init ADC()
{
// Convert Port pin 0.25 to function as AD0.2
 LPC SC->PCONP |= ADC CLK EN; //Enable ADC clock
     LPC ADC->ADCR = ADCR SETUP SCM | SEL AD0 2;
     LPC PINCON->PINSEL1 \models (1<<18); //select AD0.2 for P0.25
}
unsignedintRead ADC()
ł
unsignedinti=0;
LPC ADC->ADCR |= START CNV; //Start new Conversion
          while((LPC ADC->ADDR2 & ADC DONE) == 0); //Wait untill conversion is
finished
          i = (LPC ADC \rightarrow ADDR2 \rightarrow 4) \& 0xFFF; //12 bit Mask to extract result
}
Display ADC()
unsignedintadc value = 0;
charbuf[4] = \{5\};
float voltage = 0.0;
     adc value = Read ADC();
     sprintf((char *)buf, "%3d", adc value);
                                          // display 3 decima place
```

```
lcd_putstring16(0,"ADC VAL = 000 "); //1st line display
     lcd putstring16(1,"Voltage 00 V"); //2nd line display
     lcd gotoxy(0,10);
     lcd putstring(buf);
     voltage = (adc value * 3.3) / 4095;
     lcd gotoxy(1,8);
     sprintf(buf, "%3.2f", voltage);
     lcd putstring(buf);
}
int main (void)
{
init lcd();
Init ADC();
lcd_putstring16(0,"** MICROLAB **");
lcd putstring16(1,"** INSTRUMENTS **");
delay(60000);
delay(60000);
delay(60000);
lcd_putstring16(0,"ADC Value.. ");
lcd _putstring16(1,"voltage.....");
while(1)
 {
     Display ADC();
     delay(100000);
}
}
```

# EMBEDDED SYSTEMS LAB MANUAL

#### **DEPARTMENT VISION & MISSION**

#### VISION

To become a pioneer in developing competent professionals with societal and ethical values through transformational learning and interdisciplinary research in the field of Electronics and Communication Engineering.

#### MISSION

The department of Electronics and Communication is committed to:

M1: Offer quality technical education through experiential learning to produce competent engineering professionals.

**M2**: Encourage a culture of innovation and multidisciplinary research in collaboration with industries/universities.

M3: Develop interpersonal, intrapersonal, entrepreneurial and communication skills among students to enhance their employability.

**M4**: Create a congenial environment for the faculty and students to achieve their desired goals and to serve society by upholding ethical values.