### MODEL ANSWER SUMMER- 18 EXAMINATION ### **Subject Title:** EMBEDDED SYSTEM **Important Instructions to examiners:** - Subject Code:- 17658 - 1) The answers should be examined by key words and not as word-to-word as given in the model answer scheme. - 2) The model answer and the answer written by candidate may vary but the examiner may try to assess the understanding level of the candidate. - 3) The language errors such as grammatical, spelling errors should not be given more Importance (Not applicable for subject English and Communication Skills. - 4) While assessing figures, examiner may give credit for principal components indicated in the figure. The figures drawn by candidate and model answer may vary. The examiner may give credit for any equivalent figure drawn. - 5) Credits may be given step wise for numerical problems. In some cases, the assumed constant values may vary and there may be some difference in the candidate's answers and model answer. - 6) In case of some questions credit may be given by judgement on part of examiner of relevant answer based on candidate's understanding. - 7) For programming language papers, credit may be given to any other program based on equivalent concept. | Q.<br>No. | Sub<br>Q.N. | Answer | Marking<br>Scheme | |-----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------| | Q.1 | a) | Attempt any <u>THREE</u> of the following; | 12-Total<br>Marks | | | i) | Draw internal RAM organisation of 89C5l microcontroller. Explain register banks in it. | 4 Marks | | | Ans: | The 89c51 has 128 byte internal RAM and divided into 3 parts/area. In first part: 32 bytes from addresses 00H to 1FH i.e. 32 registers organised in 4 banks. Each bank contains 8 registers (each of 8 bit) and available at each address. Registers are named as: | Labeled diagram 2 Marks Description of Registration bank 2 Marks | | | Bank 0 -R0, R1, R2, R3, R4, R5, R6, R7 | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | | Bank 1 –R0, R1, R2, R3, R4, R5, R6, R7 | | | | Bank 2 –R0, R1, R2, R3, R4, R5, R6, R7 | | | | Bank 3 –R0, R1, R2, R3, R4, R5, R6, R7 | | | | If register banks are not selected, it can be used as general purpose area. | | | | On reset Bank 0 is selected. | | | | RS1 and RS0 bits (D3 and D4) of PSW register are used to select the register bank. | | | | Note: Others parts of RAM not expected. | | | ii) | State the function of simulator, linker compiler and debugger. | 4 Marks | | Ans: | Simulator:- | Only one | | | 1. It is the software that functions like the hardware without actual hardware. | function o each: | | | 2. Allows simulation of peripherals and I/O devices. | 1 Mark | | | 3. Allows checking of software before the hardware is available to the user. | | | | Linker :- | | | | 1. Linker is used to link with the library and generation of executable file. | | | | 2. It is used for relocation process. | | | | 3. It is done during compilation also it can be done at run time by a relocating loader. | | | | 4. It is a program that takes one or more objects generated by compiler and combines them into a single executable program. | | | | Compiler :- | | | | It is program which converts high level language program to machine language. | | | | 2. It also indicates the syntax errors in the program if any. | | | | 3. It generates object file corresponding to the target device. | | | | Debugger:- | | | | 1. Debugger is used to find the error and it keeps the control over the system environment and ability to test or follow the execution of the program. | | | | 2. Debugger allows the user to load program in to the system memory, executes the | | | iii) | Describe parallel communication protocols. | | | | | |------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--|--| | Ans: | PCI stands for Peripheral Component Interconnect/Interface bus. It is popular for higher bandwidth processor independent which can function as peripheral bus. It is introduced by Intel in 90's.It is 32 bit local bus and extended up to 64 bit by processor it requires. It has high speed I/O subsystem performance. The PCI is designed to meet economically I/O requirement of modern system. It supports ten I/O devices and provides 3 types of synchronous parallel interface. It has two versions: 32 bit (33 MHz) 64 bit (66 MHz). The data transfer rate for synchronous is 132 mbps and for asynchronous it is 528 mbps. The PCI driver can access hardware automatically or by programmer can assign address. The automatic detection and assignment of addresses of various devices simplifies the addition and removal of the system peripheral. PCI is designed to support variety of microprocessor best configuration including single and multi-processing system. PCI-X:- It is an extension of PCI bus and supports 64 bit, 100MHz transfer. PCI – X is revised | | | | | | | | | | | | | iv) | to double the maximum clock speed to improve the data exchange transfer between processor and peripherals. The data exchange rate is 1.06 gbps. Draw a labelled interfacing diagram of ADC 0808 with 8951 microcontroller. | 4 Marks | | | | | Ans: | P1.0-1.7 D0-D7 | | | | | (Autonomous) (ISO/IEC - 27001 - 2005 Certified) Soft Real Time Statistical Guarantee .Dead line are mostly met. (Autonomous) (ISO/IEC - 27001 - 2005 Certified) #### **Networked:** These types of embedded systems are related to a network to access the resources. The connected network can be LAN, WAN or the internet. The connection can be any wired or wireless. This type of embedded system is the fastest growing area in embedded system applications. The embedded web server is a type of system wherein all embedded devices are connected to a web server and accessed and controlled by a web browser. ▶ Example for the LAN networked embedded system is a home security system wherein all sensors are connected and run on the protocol TCP/IP Embedded System #### **Mobile Embedded Systems:-** Mobile embedded systems are used in portable embedded devices like cell phones, mobiles, digital cameras, mp3 players and personal digital assistants, etc. The basic limitation of these devices is the other resources and limitation of memory. #### **Stand-alone:** This embedded systems do not require a host system like a computer, it works by itself. It takes the input from the input ports either analog or digital and processes, calculates and converts the data and gives the resulting data through the connected device-Which either controls, drives or displays the connected devices. Examples for the stand alone embedded systems are mp3 players, digital cameras, video game consoles, microwave ovens and temperature measurement systems. ### ii) Explain pre-emptive scheduling and round-robin scheduling algorithms in RTOS. #### 6 Marks #### **Ans:** Preemptive scheduling :- Preemptive scheduling ensures that every task will get CPU time for execution . The allotment of CPU time depends on the preemptive scheduling algorithm. It allows a process to be interrupted in the middle of its execution, taking the CPU away and allocating it to another process. The scheduling algorithm has high overhead. System is costly and complex in design. ### 3 Marks to each #### **Shortest Job first:-** Shortest Job first is the example of this preemptive scheduling. If a new process arrives with a CPU burst length less than the remaining time of the current executing process, pre-empt. This scheme is known as the Shortest-Remaining-Time-First (SRTF). #### **Priority scheduling in pre-emptive :-** A **preemptive** approach will pre-empt the CPU if the priority of the newly-arrived process is higher than the priority of the currently running process. (diagram) (Autonomous) (ISO/IEC - 27001 - 2005 Certified) #### **Round-robin scheduling:-** In the round robin algorithm, each process gets a small unit of CPU time (a time quantum), usually 10-100 milliseconds. After this time has elapsed, the process is pre empted and added to the end of the ready queue. If there are 'n' processes in the ready queue and the time quantum is 'q', then each process gets '1/n' of the CPU time in chunks of at most 'q' time units at once. No process waits more than '(n-1)q' time units. Performance of the round robin algorithm - q large then FCFS - q small then q must be greater than the context switch time; otherwise, the overhead is too high One rule of thumb is that 80% of the CPU bursts should be shorter than the time quantum #### OR In the round robin algorithm, the kernel allocates a certain amount of time for each task waiting in the queue . The time slice allocated to each task is called quantum. As shown in fig. if three tasks 1,2, 3 are waiting in the queue the CPU first executes task1 then task2 then task 3 and the again task1 in round robin algorithm each task waiting in the queue is given a fixed time slice . The kernel gives control to the next task if the current task has completed its work within the time slice or if the current task has completed it allocated time The kernel gives control to the next task if - a) the current task has completed within the time slice - b) the current task has no work to do - c) the current task has completed its allocated time slice | | | tasks are con | nsidered of | equal impor | tance . If | time critical | no priorities for operation are not owave oven has the Task3 Running | involved then | | |-----|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------|----------------------|----------------------------------------------------------------------|---------------|---------------------------------------------------------| | | | | Eig Rou | ind robin sched | duling algor | ithm | | | | | Q 2 | | Attempt an | y <u>FOUR</u> or | f the follow | ing: | | | | 16 Marks | | | a) | Compare R | RISC and C | ISC archit | ectures | with any fou | r points. | | 4 Marks | | | Ans: | | CIS | С | | | RISC | | One mark for | | | | Emphasis | on hardw | are | , | Emphasis o | on software | | each point | | | | Multiple in | nstruction | sizes and f | ormats | Instructions formats | of same set wit | th few | | | | | Less regis | sters | | | Uses more | registers | | | | | | More add | ressing m | odes | | Fewer addr | essing modes | | | | | | Extensive | use of mi | croprogran | nming | Complexity | Complexity in compiler | | | | | | Instructio | | arying amo | ount of | Instructions | take one cycle | time | | | | | Pipelining | is difficult | | | Pipelining is | s easy | | | | | <b>b</b> ) | Explain the | use of ass | embly lang | uage in ( | C language v | vith suitable exa | mple. | 4 Marks | | | Ans: | steps. It is n | nore convertes of 'c' land uage programmers syntates of 'c' land uage programmers syntates of the converted by the converted land to | ient than se<br>guage. This<br>am easily. | parate a | separate asse | e separate assemb<br>mbler. This uses<br>assembly langua | the functions | Uses(advantag<br>ed<br>+) 2 Marks<br>Example 2<br>marks | ``` Example (any suitable combination) # include <reg51.h> void main (void) while(1) P0 = \sim P0; # pragma asm MOV TMOD,#10H MOV TH1,#0xFFH MOV TL1,#0xFFH SETB TR1 JNB TF1,$ # pragma endasm Draw a labelled interconnection diagram between RS232 and 8951 4 Marks c) microcontroller. 4 Marks Ans: GND 89C51 RXD P3.1 (TxD) TXD P3.0 (RxD) TTL DB - QP RS232 Connector Side RS232C MAX 232 Any labeled diagram showing line driver /Receiver (MAX232/233 etc) A 230V AC bulb is connected through a relay at P2.2. A light sensor is connected d) 4 Marks at P3.4. A light sensor produces logic high in dark condition. Write a 'C' program to switch 'ON' the bulb in 'DARK' condition and switch it OFF in 'LIGHT' condition. # include<reg51.h> 4 Marks Ans: sbit relay = P2^2; Any suitable ``` ``` sbit sensor = P3^4; logic may be void main (void) used. Only program sensor=1; //P3.4 as input line is expected NO relay = 0; // Intially OFF Marks for algorithm and flow chart. while (1) Appropriate while ( sensor == 0); // check sensor if no dark wait// Marks for step // dark ON bulb// may be relay = 1; while ( sensor == 1); // wait till dark// awarded. } } OR # include<reg51.h> sbit relay = P2^2; sbit sensor = P3^4; void main (void) sensor=1: //P3.4 as input line relay = 0; // Intially OFF while (1) if (sensor == 1) // check sensor if dark // relay = 1; // ON bulb// else relay=0; } } Describe inter task communication in RTOS. 4 Marks e) Ans: Software is the basic building block of RTOS. Task is a simply subroutine. Task must 1 Marks for be able to communicate with one another to coordinate their activities or to share the basics of inter data. Kernel object is used for inter task communication. Kernel objects uses message task queue, mail box and pipes, Shared Memory, Signal Function and RPC a for inter task communicatio communication. 3 marks for its any three Message queue:- A message queue is a buffer like data structure, through which tasks and ISRs methods communicate with each other by sending and receiving messages and synchronize with (short ``` | Ans: | | Diagram - 2<br>marks<br>Functional<br>description of<br>any four - 2<br>Marks | |------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------| | f) | Draw and explain block diagram of embedded system. | 4 Marks | | | Remote Procedure Call(RPC) and Sockets:- RPC is a mechanism used by process(task) to call the procedure of another process running on same or different CPU in the network. Sockets are used for RPC communication and establishes full duplex communication between tasks. | | | | Shared memory is simplest way of inter process communication. The sender process writes data into shared memory and receiver process reads data. Signal Function: Operating system provides the signal function for messaging among task (process). | | | | Pipes:- Pipes are kernel objects used for unstructured data exchange between tasks facilities synchronization among tasks. Pipe provides a simple data transfer facility. Shared Memory:- | | | | Mail box:- In general, mailboxes are similar to message queues. Mail box technique for inter task communication in RTOS based system used for one way messaging. The task/thread creates mail box to send the message. The receiver task can subscribe the mail box. The thread which creates the mail box is known as mailbox server. The others are known as client. RTOS has function to create, write and read from mail box. No of messages (limited or unlimited) in mail box have been decided by RTOS. | | | | data. It temporarily stores the message from a sender until the intended receiver is ready to read them. A message queue has queue control block, queue name, unique ID, memory buffers, a queue length. Kernel allocates the memory for message queue, ID, control block etc. | description is<br>expected) | (Autonomous) (ISO/IEC - 27001 - 2005 Certified) #### Processor:- The processor is the heart of embedded system and selected as per application of interest. **Power supply** is also called as "charge pump". Power supply source or charge pump is essential in every system. Clock Oscillator Circuit and Clocking Units: For processing unit, highly stable oscillator is required and microprocessor clock out signal provides clock for synchronizing all system unit with the processor. Reset and watch dog timer is also available. **Memory :-** A system embeds either in the internal flash or ROM, PROM or in an external flash or ROM or PROM of the microcontroller. #### Input, output and I/O Ports, I/O Buses and I/O Interfaces A system connects to external physical devices and systems through parallel or serial I/O ports. De-multiplexers and multiplexers facilitate communication of signals from multiple channels through a common path. A system often n/w to other devices and systems through an I/O bus. E.g. I<sup>2</sup>C, CAN, USB, ISA, PCI, etc.For automatic control and signal processing applications, a system provides necessary interfacing circuit and software for DAC unit and ADC unit. **Keyboard/keypad :-** For inputs, a keypad or keyboard may interface to a system. The system provides necessary interfacing circuit and s/w to receive I/p's directly from the keys or through a controller. The system may need the necessary interfacing circuit and s/w for the o/p to the LCD display controller and the LED interfacing ports or for the I/O's with the touch screen. #### **Real Time Operating System (RTOS):-** It supervises the software application running on hardware and organizes access to resource according to priorities of task in the system. It provides a mechanism to run the process as per schedule and context switching between various processes. | Q.3 | | Attempt any <u>FOUR</u> of the following: | 16 Marks | |-----|------|-----------------------------------------------------------------------------------|----------------| | | a) | List wireless communication protocols and state four features of zigbee protocol. | 4 Marks | | | Ans: | Wireless Communication Protocols:- | List-2marks | | | | 1. Infrared [IrDA] | any 4 features | | | | 2. Bluetooth | -2marks | | | | 3. Zigbee | | | | | 4. Wi-Fi | | | | | Features of Zigbee:- | | | | | 1. Support for multiple network topologies such as point to point, point to | | | | | multipoint and mesh networks, cluster tree. | | | | | | | ı | | | | |------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|--|--| | | 2. ZigBee operates in the industrial, scientific and medical ( <u>ISM</u> ) radio bands: 2.4 GHz in most jurisdictions worldwide. | | | | | | | | | | | | | | | | | | | duty cycle provides long batter | y life. | | | | | | | <ul><li>4. 250 Kbps data rate.</li><li>5. Scalable and easy deployment.</li><li>6. Highly reliable and secure.</li></ul> | | | | | | | | | | | | | | | | | | | | | | | | | | | 7. Low | | | | | | | | | | effective. | | | | | | | | 9. Up to 65000 nodes per network. | | | | | | | | | | oit AES encryption for secure da | | | | | | | | Collision av | oidance, retries and acknowledg | ments. | | | | | | <b>b</b> ) | Write a 'C'<br>delay subro | | nuously with 100 ms delay. (Use simple | 4 Marks | | | | | Ans: | #include <re< th=""><th>•</th><th></th><th></th></re<> | • | | | | | | | Alis. | | lay (unsigned int); | | | | | | | | sbit data_bit | • , • | | | | | | | | void main (v | | | | | | | | | void mam (v | olu) | | | | | | | | ι<br>while (1) | | | | | | | | | wille (1) | | | | | | | | | {<br>doto <b>hi</b> t —1. | // act D2 1 bit | | | | | | | | · | // set P2.1 bit | | | | | | | | add_delay (1 | | | | | | | | | | // reset P2.1bit | | | | | | | | add_delay (1 | .00); | | | | | | | | } | | | | | | | | | } | | | | | | | | | | | | | | | | | | void add_de | | | | | | | | | { | | | | | | | | | unsigned int | | | | | | | | | for $(x = 0; x < delay_time; x ++)$ | | | | | | | | | for (y =0; y< | | | | | | | | | } | | | | | | | | <b>c</b> ) | Compare desktop operating system with RTOS with any four points. | | | | | | | | Ans: | Sr no | OS | RTOS | Any four points-1Mar | | | | | | 1 | Non-Deterministic time behavior. | Deterministic time behavior. | each | | | | | | 2 | Used in general desktop | Used in embedded system | | | | | | | | computer system. | Total in chiacodoca dystein | | | | | | | 3 | Generalized Kernel. | Real time kernel. | | | | | | | 4 | OS services can inject random | OS services consumes only known | | | | | | | | delays into application | and expected | | | | | | | | 1 | The state of s | | | | | | | | software, may cause slow | amounts of time regardless the | | | | | | | | responsiveness of an application at unexpected time. | number of services. | | | | |------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------|--|--| | | 5 | Slow context switching | fast context switching | | | | | | 6 | More memory requirements | Less memory requirements | | | | | | 7 | Ex: Windows XP, MS-DOS | Ex: Windows CE, VxWorks | | | | | <b>d</b> ) | State any tw | o advantages and disadvanta | ges of embedded system. | 4 Marks | | | | Ans: | Advantages | <b>:-</b> | | Advantages | | | | | 1. Cost | is low. | | any 2 – | | | | | 2. Small | l in size. | | 2 Marks | | | | | 3. Highl | y reliable. | | | | | | | | ation is fast. | | Disadvantage | | | | | | for mass production. | | any 2 – | | | | | | interconnection. | | 2 Marks | | | | | | oves product quality. | | - 1,141111 | | | | | Dia Admente | | | | | | | | Dis-Advanta | | 41 | | | | | | | for maintenance as it is use and | throw device. | | | | | | 2. No technological improvement. | | | | | | | | 3. Hard to back up of embedded files. | | | | | | | | | | | | | | | | 4. Less | power supply durability if it is b | pattery operated. | | | | | e) | | 11 0 | • • | 4 Marks | | | | <b>e</b> ) | Draw a labe | lled interfacing diagram of D | AC 0808 with 8951 microcontroller. | 4 Marks | | | | | Draw a labe | 11 0 | AC 0808 with 8951 microcontroller. | | | | | e) Ans: | Draw a labe | lled interfacing diagram of Da 'C' program to generate trial | AC 0808 with 8951 microcontroller. | Diagram - | | | | | Draw a labe | lled interfacing diagram of D | AC 0808 with 8951 microcontroller. | | | | | | Draw a labe | lled interfacing diagram of Da 'C' program to generate triage +5V +5V +5V | AC 0808 with 8951 microcontroller. | Diagram -<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da'C' program to generate trial | AC 0808 with 8951 microcontroller. ngular waveform using DAC. | Diagram -<br>2Marks<br>Program- | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trial DAC0808 RD VCC WR Vref (+) | AC 0808 with 8951 microcontroller. ngular waveform using DAC. | Diagram -<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trial DAC0808 RD VCC WR Vref (+) D0 D0 D0 OUT | AC 0808 with 8951 microcontroller. ngular waveform using DAC. | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trial DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da'C' program to generate trial DAC0808 RD VCC WR Vref (+) D0 D1 D0 D1 D2 D3 D4 Vref (-) | AC 0808 with 8951 microcontroller. ngular waveform using DAC. | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trial DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D5 D5 D6 Vref (-) | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da'C' program to generate trial DAC0808 RD VCC WR Vref (+) D0 D1 D0 D1 D2 D3 D4 D5 Vref (-) D5 | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D4 Vref (-) D5 D6 D7 | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trial DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D5 D5 D6 Vref (-) | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D4 Vref (-) D5 D6 D7 | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 Vref (-) D5 D6 D7 VEE COMP GND | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 Vref (-) D5 D6 D7 VEE COMP GND | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | DAC0808 PDAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D3 D4 D5 D6 D7 VEE COMP GND -12V | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D5 D6 D7 VEE COMP GND #include< | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D5 D6 D7 VEE COMP GND #include #include | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe<br>Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D5 D6 D7 VEE COMP GND #include #include | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | | | Draw a labe Also write a | lled interfacing diagram of Da 'C' program to generate trian DAC0808 RD VCC WR Vref (+) D0 D1 D2 D3 D4 D5 D6 D7 VEE COMP GND #include #include | AC 0808 with 8951 microcontroller. ngular waveform using DAC. TO SCOP Vout = 0 to 10V | Diagram -<br>2Marks<br>Program-<br>2Marks | | | (ISO/IEC - 27001 - 2005 Certified) (Autonomous) (ISO/IEC - 27001 - 2005 Certified) signals are processed between antenna and speaker in 0.1s shows phone performance. The system may need to handle a lot of data in a short time. - 3. Response: The system has to react to the changing events quickly. - 4. Memory: Hardware design must make the best estimate of the memory requirement and must make the provision for expansion. - 5. Power consumption: Systems generally work on battery and design of both software and hardware must take care of power saving techniques. - 6. Number of units: The number of units expected to be produced and sold will dictate the trade-off between production cost and development cost. - 7. Expected life-time: Design decisions like selection of components to system development cost will depend upon on how long the system is expected to run. - 8. Program Installation: Installation of software on to the embedded system needs special development tools. - 9. Testability and Debug ability: Setting up test conditions and equipment will be difficult and determining what is wrong with the software will become a difficult task without a keyboard and usual display. - 10. Reliability: It is always required that the system designed must give the output for which it is designed. - 11. Power Dissipation: For battery operated system this is important feature. Examples are mobile phone or digital camera where if power dissipation is small battery needs to be recharge less frequently. - 12. Unit cost: the monetary cost of manufacturing each copy of the system, excluding NRE cost. - 13. NRE cost (Non-Recurring Engineering cost): The monetary cost of designing the system. Once the system is designed, any number of units can be manufactured without incurring any additional design cost (hence the term "non-recurring"). - 14. Size: the physical space required by the system, often measured in bytes for software, and gates or transistors for hardware. - 15. Flexibility: the ability to change the functionality of the system without incurring heavy NRE cost. Software is typically considered very flexible. Flexibility in design enables, without significant engineering cost, development of different versions or product or to develop advanced version later on. For example software enhancement by adding extra functions. - 16. Maintainability: Deals with support and maintenance to the end user or client in case of technical issues and product failure. A more reliable system means with less maintainability. As reliability of the system increases chances of failure and non-functioning also reduces. - 17. Time-to-market: The amount of time required to design and manufacture the system to the point the system can be sold to customers. The main contributors are design time, manufacturing time and testing time. There may be multiple players in the embedded industry who develop products of the same category (like mobile phones, portable media players etc.). If you come with new product and time to market is high competitor may take advantage of it with their product. - 18. Time-to-prototype: The amount of time to build a working version of the system, which may be bigger or more expensive than the final system implementation, | | but can be used to verify the system's usefulness and correctness and to refine the system's functionality. If the prototype is developed faster, the actual estimated development time can be bought down. 19. Correctness: our confidence that we have implemented the system's functionality correctly. We can check the functionality throughout the process of designing the system, and we can insert test circuitry to check that manufacturing was correct. 20. Safety: the probability that the system will not cause harm. It deals with possible damages that can happen to the operators, public and the environment due to breakdown of embedded system, or due to the emission of radioactive or hazardous materials from embedded products. Safety analysis is a must in product engineering to evaluate the anticipated damages and determine best course of action. | | |------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | d) | Explain the concept of deadlock with suitable example. | 4 Marks | | Ans: | A deadlock is a situation where in two or more competing actions are each waiting for the other to finish, and thus neither ever does. In computer science, deadlock refers to a specific condition when two or more processes are each waiting for the other to release a resource, or more than two processes are waiting for resources in a circular chain. A deadlock, also called as deadly embrace, is a situation in which two threads are each unknowingly waiting for resource held by other. • Assume thread/process T1 has exclusive access to resource R1. • Thread/ process T2 has exclusive access to resource R2. • If T1 needs exclusive access to R2 and T2 needs exclusive access to R1, • Neither thread can continue. • They are deadlocked. • The simplest way to avoid a deadlock is for threads to: | Explanation-<br>2Marks Example-2 Marks | (Autonomous) (ISO/IEC - 27001 - 2005 Certified) In this example, process 1 wants the resource 2 ex; scanner while holding the resource 1 ex: printer. Process 1 cannot proceed until both the printer and the scanner are in its possession. Process 2 wants the printer while holding the scanner. Process 2 cannot continue until it has the printer and the scanner. Because neither process 1 nor process 2 is willing to give up what it already has, the two tasks are now deadlocked because neither can continue. | <b>b</b> ) | Attempt any <u>ONE</u> of the following: | 06 Marks | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------| | a) | Write a 'C' program to generate a square wave of 5 kHz.(Operate timer 0 in mode 1). | 6 Marks | | Ans: | Crystal frequency= 11.0592 MHz $\frac{1}{-} \times 11.0592 MHz = 921.6 KHz$ | Calculation-2<br>Marks | | | I/P clock= $\frac{1}{2}$ (crystal frequency) = $\frac{2}{3}$ Tin =1.085µsec<br>For5 kHz square wave<br>Fout = $\frac{1}{5x10^3}$ = $\frac{200\mu \text{ sec}}{200\mu \text{ sec}}$ Tout =200µsec | Program - 4<br>Marks | | | Consider half of it=Tout = $100\mu$ sec $= \frac{Tout}{Tin} = \frac{100\mu}{1.085\mu} = 92.16$ $65536-92 = (65444)D = FFA5 H$ | | | | Program: #include <reg51.h> void delay(void); sbit p=P3^5; void main (void)</reg51.h> | | | Ans: | Sr | Operator | Symbol | | Example | 1 Mark each | |------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------------| | | no: | Operator | Symbol | | Example | | | | 1. | AND | & is called Logical A | ND operator. | Y= A&B | | | | 2. | OR | is called Logical OR | operator. | Y= A B | | | | 3. | NOT | ~ is called NOT opera | ator. | Y= ~A | | | | 4. | EX-OR | ^ is called logical Ex- | OR operator. | Y=A ^B | | | <b>b</b> ) | 0 | | ynchronous and async | chronous comn | nunication with any | 4 Marks | | Ans: | four point | | ous | Asynchrono | us | Any four | | 2113. | 1 | Same clock | k pulse is required at<br>and receiver | Different clo | ck pulse is required<br>and receiver | points -1 Mark<br>each | | | 2 | Used to<br>character | transfer group of | Used to transfer one character at a time | | | | | 3 Synchrono required. | | us character is | Synchronous character is required. | | | | | 4 | No start a<br>required | nd stop signals are Start and stop signals are required. | | | | | | 5 | | nsmission rate is<br>hen or equal to | | ission rate is less<br>to 20 Kbps. | | | | 6 | It is less re | liable | It is more reli | iable | | | <b>c</b> ) | | ber of port | lines required for a ke | yboard matrix | | 4 Marks | | Ans: | Number of having fol (i) 16 -16 4+4 =8 (ii) 256 - 2 are 16+16 (iii) 64 - 6 are 8+8 =1 | lowing keys:<br>keys can be a<br>56 keys can b<br>=32<br>4 keys can b<br>16<br>44 keys can b | e arranged in a matrix of a matrix of a arranged in a matrix of | 4X4, so number of 16X16, so num | r of port lines required are<br>nber of port lines required<br>ber of port lines required<br>nber of port lines required | 1 Mark Each | | d) | State four key specifications of RTOS. | 4 Marks | |------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------| | Ans: | Key specifications of RTOS: 1. Reliability: A reliable system must be available (continue to provide service) and should not fail. The combination of all system elements determines the reliability of a system. (Hardware, BSP, RTOS, and applications) 2. Predictability: The RTOS used in this case needs to be predictable to a certain degree. The term deterministic describes RTOSes with predictable behavior, in which the completion of operating system calls occurs within known timeframes. 3. Performance: An embedded system must perform fast enough to fulfill its timing requirements. Typically, the processor's performance is expressed in million instructions per second (MIPS). Throughput also measures the overall performance of a system, with hardware and software combined. One definition of throughput is the rate at which a system can generate output based on the inputs coming in. 4. Compactness: In embedded systems, where hardware real estate is limited due to size and costs, the RTOS clearly must be small and efficient. In these cases, the RTOS memory footprint can be an important factor. 5. Scalability: Because RTOSes can be used in a wide variety of embedded systems, they must be able to scale up or down to meet application-specific requirements. Depending on how much functionality is required, an RTOS should be capable of adding or deleting modular components, including file systems and protocol stacks. | Any 4 1 Mark each | | | | 452.5 | | e)<br>Ans: | Describe in-circuit emulator. In-circuit emulator:- | 4 Marks<br>1 Mark | | | In-circuit emulator (ICE) is one of the oldest embedded debugging tools, and is still unmatched in power and capability. It is only tool that substitutes its own internal processor for the one in the target system Using one of a number of hardware tricks, the emulator can monitor everything that goes on in this on-board CPU, giving a complete visibility into the target code's operation. The emulator is bridge between the target and workstation giving an interactive terminal | Diagram, 3 Marks Explanation. | | | f) Ans: | • An in-circuit emulator (ICE) is a hardware device used to debug the software of an embedded system. It was historically in the form of bond-out processor which has many internal signals brought out for the purpose of debugging. These signals provided information about the state of the processor. • An in-circuit emulator provides a window into the embedded system. The programmer uses the emulator to load programs into the embedded system, run them, step through them slowly, and view and change data used by the system's software. • More recently the term also covers JTAG based hardware debuggers which provide equivalent access using on-chip debugging hardware with standard production chips. • ICE's attach a terminal or PC to the embedded system. The terminal or PC provides an interactive user interface for the programmer to investigate and control the embedded system. • In usage, an ICE provides the programmer with execution breakpoints, memory display and monitoring, and input/output control Draw labeled interfacing diagram of 4 X 4 matrix keypad with 8951. Interfacing diagram of 4 X 4 matrix keypad with 8951 | 4 Marks Diagram 4 Marks | |-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | Q.6 | | Attempt any <u>FOUR</u> of the following: | 16 Marks | | | a) | Distinguish between assembly language and C language with reference to: (i) Ease of programming (ii) Memory requirement (iii) Coding time (iv) Execution time | 4 Marks | | Ans: | Sr<br>no | Parameters | Assembly Language program | Embedded C | 1 Mark ea | | | |------------|-------------------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|--| | | | Ease of<br>Programming | Less | More. | | | | | | | Memory<br>requirement | Less | More. | | | | | | 3. | Coding time | More time is required for coding. | Less time required for coding | | | | | | | Execution<br>Time | Faster [Less Execution time required] | Slower [More execution time required] | | | | | <b>b</b> ) | Draw pin d | iagram of DB | 9. connector, stating fun | ction of each pin. | 4 Marks | | | | Ans: | | | | | Pin diagra | | | | | Pin Diagra | m: | Pin 1 Pin : | 5 | 1Marks,<br>function - | | | | | Pin 1 Pin 5 | | | | | | | | | | | | | 3Marks | | | | | | | Pin 6 Pin 9 | | 3Marks | | | | | Abbrevia | | ne Function | | 3Marks | | | | | TD | tion Full Nar<br>Transmit E | ne Function Data Serial Data Output (T | (XD) | 3Marks | | | | | | | ne Function Data Serial Data Output (T Data Serial Data Input (RX | (XD) | 3Marks | | | | | TD | Transmit I | ne Function Data Serial Data Output (T Data Serial Data Input (RX | (XD) | 3Marks | | | | | TD<br>RD | Transmit D | ne Function Data Serial Data Output (T rata Serial Data Input (RX end This line indicates that data. ier When the modem det | (XD) | 3Marks | | | | | TD<br>RD<br>CTS | Transmit I Receive D Clear to Se Data Carr | ne Function Data Serial Data Output (T rata Serial Data Input (RX end This line indicates that data. ier When the modem dete the other end of the plant | EXD) It the Modem is ready to exchange ects a "Carrier" from the modem at | 3Marks | | | | | TD RD CTS DCD | Transmit I Receive D Clear to Se Data Carr Detect | ne Function Data Serial Data Output (T Data Serial Data Input (RX Inpu | EXD) If the Modem is ready to exchange ects a "Carrier" from the modem at hone line, this Line becomes active. That the modem is ready to establish a DSR. This tells the Modem that the | 3Marks | | | | | TD RD CTS DCD DSR | Transmit I Receive D Clear to Se Data Carr Detect Data Set Re | ne Function Data Serial Data Output (T Data Serial Data Input (RX Inpu | EXD) If the Modem is ready to exchange ects a "Carrier" from the modem at hone line, this Line becomes active. That the modem is ready to establish a DSR. This tells the Modem that the | 3Marks | | | | | Draw labelled interfacing diagram of 16 X 2 LCD with 8951 and state function of RS and R/W pin. | 4 Marks | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------| | Ans: | Interfacing diagram of 16 X 2 LCD with 8951 P2.0 P2.1 RS R/W E LCD DISPLAY VLC VEE POT POT | labelled interfacing diagram-2 Marks, functions-1 Mark each | | | D0 D1 D2 D3 D4 D5 D6 D7 5 P1.0 P1.7 | | | | Function:- RS: RS is used to make the selection between data and command register. RS=0, command register is selected RS=1 data register is selected. | | | | RW: -R/W gives you the choice between writing and reading. | | | <b>d</b> ) | R/W=1, reading is enabled. R/W=0 ,writing is enabled A key is connected at P3.2 and 8 LEDs are connected to P1 of 8951. Write a 'C' | 4 Marks | | d) Ans: | R/W=1, reading is enabled. R/W=0 ,writing is enabled | 4 Marks Program w correct log 4 Marks | | | <pre>} } else P1=0; } void delay (unsig { unsigned int i,j: for (i=0;i<itime;i- for(j="0;j&lt;1275;j+" pre="" }<=""></itime;i-></pre> | ++)<br>-+); | data turas s | rad in (C) | 4 Marks | | | |------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------|---------------------|-------------|--|--| | e) | Manipulate the following table for data types used in 'C' language. | | | | | | | | | Sr. No. | Data type | Bit size | Data range | 7 | | | | | 1. | Unsigned char | ? | ? | - | | | | | 2. | Signed int | ? | ? | | | | | | 3. | Sbit | ? | ? | | | | | | 4. | Sfr | ? | ? | | | | | Ans: | Sr. No. | Data type | Bit size | Data range | 1 Mark each | | | | | 1. | <b>Unsigned char</b> | 8 | 0 to 255 | - | | | | | | G' 1 1 1 4 | 16 | -32768 to +32767 | $\neg$ | | | | | 2. | Signed int | 10 | 22.00 to .22.0. | | | | | | | Signed int Sbit | 1 | SFR bit addressable | | | |