# Embedded Systems

# Week 6: Combinational Circuits Embedded Linux



**Dr. Vecdi Emre Levent** 



#### Instructors

Assist. Prof. Dr. Vecdi Emre Levent

Email: emre@levent.tc

emre.levent@marmara.edu.tr

Web: www.levent.tc



UNIVERSITES.
1883

- Computer Hardware
  - Softwares that require performance can be only written by who have a deep understanding of hardware.
- Almost all electronic devices are digital
  - Audio recorders, cameras, vehicles ph1s, medical devices...
  - Developing equipment needed in almost every industry
  - It is an area that is highly needed both in our country and abroad. It could be a different career goal for you.





#### What Does Digital Mean?

- Analog Signal
  - It has infinite possible value.
    - For example, the vibration created by a microph1 on the line.

#### **Analog Signal**



- Digital Signal
  - Finite possible values
    - For example : Pressing a button on a keypad







electric signal



# Digital Signals with Only Two Values: Binary

- *Binary* digital signals have only two possible values
  - These are shown as 0 and 1
  - A binary digit is expressed as a "bit".
  - Within the scope of the course, binary digital systems will be considered.
  - Binary is popular because:
    - Transistors, the most basic digital electrical comp1nt, operate at two voltage values (0 and 1)





WHAN UNIVERSITES.

- Analogue signal is very sensitive to noise
  - During transmission, voltage levels may change due to many factors.
- Digital signals are more resistant to degradation during transmission.
  - Voltage levels still may not transmit perfectly
  - However, some distorted 1s and 0s can be recovered.





#### Digitized Content, Compression Benefits

- Digitized Audios can be compressed
  - eg . MP3
- Compression can also be d1 on photos (jpeg) or videos (mpeg)

 Digitization has many different advantages. Example Compression Table 00 --> 0000000000 01 --> 11111111111 1X --> X

00 00 10000001111 01







- If button is not pressed (0), if pressed (1)
- Multi-button : coding
  1st button =001, 2nd button
  =010, ...
- Some inputs are analog
  - Requires an analog-to-digital converter to switch to digital.
- ADC (Analog to Digital Converter):
   Converts analog signal to digital
- DAC (Digital to Analog Converter):
   Converts digital signal to analog







#### **ASCII Encoding**

 ASCII: 8 bits of each character and symbol. It is a table with the corresponding

| Symbol      | Mostding | Symbol          | M <b>ost</b> ding |  |  |
|-------------|----------|-----------------|-------------------|--|--|
| R           | 1010010  | r               | 1110010           |  |  |
| S           | 1010011  | S               | 1110011           |  |  |
| Т           | 1010100  | t               | 1110100           |  |  |
| L           | 1001100  | 1               | 1101100           |  |  |
| N           | 1001110  | n               | 1101110           |  |  |
| TO          | 1000101  | to              | 1100101           |  |  |
| 0           | 0110000  | 9               | 0111001           |  |  |
|             | 0101110  | !               | 0100001           |  |  |
| <tab></tab> | 0001001  | <space></space> | 0100000           |  |  |

1010010 1000101 1010011 1010100



| Dec | Нх | Oct | Char |                          | Dec | Нα | Oct | Html  | Chr   | Dec | Нх | Oct | Html  | Chr | Dec | : H) | Oct | Html Ci | hr  |
|-----|----|-----|------|--------------------------|-----|----|-----|-------|-------|-----|----|-----|-------|-----|-----|------|-----|---------|-----|
| 0   | 0  | 000 | NUL  | (null)                   | 32  | 20 | 040 | 6#32; | Space | 64  | 40 | 100 | 6#64; | 8   | 96  | 60   | 140 | 6#96;   |     |
| 1   | 1  | 001 | SOH  | (start of heading)       | 33  | 21 | 041 | 6#33; | 1     | 65  | 41 | 101 | 6#65; | A   | 97  | 61   | 141 | 4#97;   | a   |
| 2   | 2  | 002 | STX  | (start of text)          | 34  | 22 | 042 | 6#34; | "     | 66  | 42 | 102 | 6#66: | В   | 98  | 62   | 142 | 4#98;   | b   |
| 3   | 3  | 003 | ETX  | (end of text)            | 35  | 23 | 043 | 6#35; | #     | 67  | 43 | 103 | 6#67: | C   |     |      |     | 4#99;   | C   |
| 4   | 4  | 004 | EOT  | (end of transmission)    | 36  | 24 | 044 | 6#36; | ę     | 68  | 44 | 104 | 6#68; | D   | 100 | 64   | 144 | %#100;  | d   |
| 5   |    |     |      | (enquiry)                | 37  | 25 | 045 | 6#37; | S.    | 69  | 45 | 105 | 6#69; | Ε   | 101 | 65   | 145 | %#101;  | e   |
| 6   | 6  | 006 | ACK  | (acknowledge)            | 38  |    |     | 6#38; |       | 70  | 46 | 106 | 6#70; | F   |     |      |     | %#10Z;  |     |
| 7   | 7  | 007 | BEL  | (bell)                   | 39  | 27 | 047 | 6#39; | 1     | 71  |    |     | 6#71; |     | 103 | 67   | 147 | %#103;  | g   |
| 8   | 8  | 010 | BS   | (backspace)              | 40  |    |     | 6#40; |       | 72  |    |     | 6#72; |     |     |      |     | %#104;  |     |
| 9   | 9  | 011 | TAB  | (horizontal tab)         | 41  | 29 | 051 | 6#41; | )     | 73  |    |     | 6#73; |     |     |      |     | %#105;  |     |
| 10  |    | 012 |      | (NL line feed, new line) |     |    |     | 6#4Z; |       |     |    |     | 6#74; |     |     |      |     | 4#106;  |     |
| 11  | В  | 013 |      | (vertical tab)           |     |    |     | 6#43; |       |     |    |     | 6#75; |     |     |      |     | %#107;  |     |
| 12  |    | 014 |      | (NP form feed, new page) |     |    |     | ¢#44; |       | 76  | -  |     | 6#76; |     |     |      |     | %#108;  |     |
| 13  |    |     |      | (carriage return)        |     |    |     | a#45; |       | 77  |    |     | 6#77; |     |     |      |     | %#109;  |     |
| 14  | Ε  | 016 | S0   | (shift out)              |     |    |     | a#46; |       |     |    |     | 6#78; |     |     |      |     | a#110;  |     |
| 15  | F  | 017 | SI   | (shift in)               | 47  | 2F | 057 | 6#47; | /     |     | -  |     | 6#79; |     |     |      |     | 6#111;  |     |
| 16  | 10 | 020 | DLE  | (data link escape)       | -   |    |     | 6#48; |       |     |    |     | 6#8O; |     |     |      |     | 6#112;  |     |
| 17  | 11 | 021 | DCL  | (device control 1)       |     |    |     | ¢#49; |       | 81  | 51 | 121 | 6#81; | Q   |     |      |     | a#113;  |     |
| 18  | 12 | 022 | DC2  | (device control 2)       | 50  | 32 | 062 | 4#50; | 2     | 82  | 52 | 122 | 6#82; | R   | 114 | 72   | 162 | a#114;  | Ľ   |
|     |    |     |      | (device control 3)       | 51  | 33 | 063 | a#51; | 3     | 83  | 53 | 123 | 6#83; | 3   | 115 | 73   | 163 | a#115;  | 3   |
| 20  | 14 | 024 | DC4  | (device control 4)       |     |    |     | a≢52; |       | 84  | 54 | 124 | 6#84; | Т   |     |      |     | a#116;  |     |
| 21  | 15 | 025 | NAK  | (negative acknowledge)   |     |    |     | 4≸53; |       | 85  | 55 | 125 | 6#85; | U   |     |      |     | 6#117;  |     |
| 22  | 16 | 026 | SYN  | (synchronous idle)       |     |    |     | a#54; |       | 86  | 56 | 126 | 6#86; | V   |     |      |     | a#118;  |     |
| 23  | 17 | 027 | ETB  | (end of trans, block)    |     |    |     | a#55; |       | 87  | 57 | 127 | 6#87; | W   | 119 | 77   | 167 | 6#119;  | OF. |
| 24  | 18 | 030 | CAN  | (cancel)                 |     |    |     | a#56; |       | 88  | 58 | 130 | 6#88; | Х   |     |      |     | a#120;  |     |
| 25  | 19 | 031 | EΜ   | (end of medium)          | 57  | 39 | 071 | a≢57; | 9     | 89  | 59 | 131 | 6#89; | Y   |     |      |     | 6#121;  |     |
| 26  | 1A | 032 | SUB  | (substitute)             |     |    |     | ;58≱د |       | 90  | 5A | 132 | 6#90; | Z   | 122 | 7A.  | 172 | 6#122;  | z   |
| 27  | 1B | 033 | ESC  | (escape)                 | 59  | ЗΒ | 073 | a#59; | 2     | 91  | 5B | 133 | 6#91; |     | 123 | 7B   | 173 | a#123;  | -{  |
| 28  | 10 | 034 | FS   | (file separator)         | 60  | 30 | 074 | 4#60; | <     | 92  | 5C | 134 | 4#92; | N   | 124 | 70   | 174 | a#124;  | 1   |
| 29  | 1D | 035 |      | (group separator)        | 61  | ЗD | 075 | a#61; | =     | 93  | 5D | 135 | 4#93; | 3   |     |      |     | a#125;  |     |
| 30  | 1E | 036 | RS   | (record separator)       | 62  | ЗE | 076 | a#62; | >     | 94  | 5E | 136 | 4#94; |     |     |      |     | a#126;  |     |
| 31  | 1F | 037 | US   | (unit separator)         | 63  | ЗF | 077 | a#63; | 2     | 95  | 5F | 137 | 6#95; | _   |     |      |     | 4#127;  |     |



#### Numbers Encoding

- Decimal base ( decimal )
  - There are 10 symbols: 0, 1, 2, ..., 8, and 9
  - After 9 comes a new digit
    - So each digit is a power of 10.
    - Base of 10 is used as it is suitable for daily life operations.
- Binary Base ( binary )
  - There are two symbols: 0 and 1
  - New power comes after 1
    - So each digit is a power of 2.

$$\frac{5}{10^2} \ \frac{2}{10^1} \ \frac{3}{10^0}$$



#### Boolean Algebra

Logic Gates are built with

















Answer : 
$$F = (1 \text{ AND } 1) \text{ OR } (1 \text{ AND } 0)$$
  
= 1 OR 0 = 1.

| а | b | AND |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 0   |
| 1 | 0 | 0   |
| 1 | 1 | 1   |

| а | b | OR |
|---|---|----|
| 0 | 0 | 0  |
| 0 | 1 | 1  |
| 1 | 0 | 1  |
| 1 | 1 | 1  |

| а | NOT |
|---|-----|
| 0 | 1   |
| 1 | 0   |



#### Boolean Algebra Example

boolean equation

given below F = a AND NOT(b OR NOT(c))





#### Truth Tables

• F indicates output.

• 2- Input : 4 lines

• 3- Input : 8 lines

• 4- Input : 16 lines

| а | b | F |
|---|---|---|
| 0 | 0 |   |
| 0 | 1 |   |
| 1 | 0 |   |
| 1 | 1 |   |

| а | b | С | F |
|---|---|---|---|
| 0 | 0 | 0 |   |
| 0 | 0 | 1 |   |
| 0 | 1 | 0 |   |
| 0 | 1 | 1 |   |
| 1 | 0 | 0 |   |
| 1 | 0 | 1 |   |
| 1 | 1 | 0 |   |
| 1 | 1 | 1 |   |

| a | b | С | D | F |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 |   |
| 0 | 0 | 0 | 1 |   |
| 0 | 0 | 1 | 0 |   |
| 0 | 0 | 1 | 1 |   |
| 0 | 1 | 0 | 0 |   |
| 0 | 1 | 0 | 1 |   |
| 0 | 1 | 1 | 0 |   |
| 0 | 1 | 1 | 1 |   |
| 1 | 0 | 0 | 0 |   |
| 1 | 0 | 0 | 1 |   |
| 1 | 0 | 1 | 0 |   |
| 1 | 0 | 1 | 1 |   |
| 1 | 1 | 0 | 0 |   |
| 1 | 1 | 0 | 1 |   |
|   |   |   |   |   |
|   |   |   |   |   |



- The computer is an electronic circuit.
  - It basically works by controlling the flow of electrons.





- Electrons are controlled by "Transistors".
  - It basically works by controlling the flow of electrons.





- Electrons are controlled by "Transistors".
  - It basically works by controlling the flow of electrons.







- Electrons are controlled by "Transistors".
  - It basically works by controlling the flow of electrons.





- Data has two states:
  - 1. the voltage (Voltage) exists This state is called "1".
  - 2. The state where the voltage disappears This state is called "0".







- It is also possible to make a computer that works according to more than two voltage states.
  - But the control circuit of this computer will be much more complex.

- For this reason, today's modern computers work with the concept of bit, which is the smallest unit, while expressing information.
- It is the smallest data storage unit that can hold 0 or 1 on a bit.



#### Binary system:

It has two states: 0 and 1

- Larger storage areas are obtained by combining multiple bits.
  - two bits , 4 different numbers can be expressed.



• Two bits , 4 different numbers can be expressed.

- 00 = 0 (in decimal)
- 01 = 1
- 10 = 2
- 11 = 3



• 3 bits 8 numbers can be expressed by combining them:

- 000 = 0
- 001 = 1
- 010 = 2
- 011 = 3
- 100 = 4
- 101 = 5
- 110 = 6
- 111 = 7



- In summary;
- $2^n$  with n bits-different numbers can be expressed.
- $\frac{2}{2}$  = 4 different numbers for <u>2</u> bits
- $2^3$  = 8 different numbers for 3 bits
- $2^4$  = 16 different numbers for 4 bits

•••

can be expressed.



# What types of data are expressed / stored in the computer?

- Numbers signed (unsigned), integers, decimal numbers (floating \_ \_ \_ \_ \_ point), complex numbers (complex), rational, irrational, ...
- Texts Characters (characters), texts (string), ...
- Images pixels , images , ...
- Sound
- Logic (logic) true (true), false (false)
- Operations (Instructions)
- ...
- Let's start with the numbers ...



#### Unsigned (Unsigned) Integers (Integers)

- Unsigned integers
  - They always store positive values

• Ex:



$$3x100 + 2x10 + 9x1 = 329$$

$$101 \text{ (in base 2)}$$

$$1x4 + 0x2 + 1x1 = 5$$



# **Unsigned Integers**

• An n - bit unsigned integer  $2^n$  has a value : from 0 to  $2^n$ -1.

| 2 <sup>2</sup> | <b>2</b> <sup>1</sup> | <b>2</b> <sup>0</sup> |   |
|----------------|-----------------------|-----------------------|---|
| 0              | 0                     | 0                     | 0 |
| 0              | 0                     | 1                     | 1 |
| 0              | 1                     | 0                     | 2 |
| 0              | 1                     | 1                     | 3 |
| 1              | 0                     | 0                     | 4 |
| 1              | 0                     | 1                     | 5 |
| 1              | 1                     | 0                     | 6 |
| 1              | 1                     | 1                     | 7 |



#### Unsigned Binary Base Arithmetic

- Binary base addition (like base 10)
  - It is collected starting from the rightmost, and if it is available, it is transferred to the next total.



#### Signed Integers (Integrs)

- With n bits, we can store 2 n different values.
  - 2 <sup>n</sup> different value;
  - Signed integers are obtained by assigning half to positive numbers and half to negative numbers.
  - Positive numbers 1 to 2 <sup>n-1</sup>
     Negative numbers -( 2 <sup>n-1</sup>) to -1
  - For example , if we have a 3-bit storage;
  - Positive numbers are from 1 to 4 and negative numbers are from -4 to -1.



# Signed Integers (Integrs)

- For example, if we have a 3-bit storage;
- Positive numbers are from 1 to 4 and negative numbers are from -4 to -1.
- If the number 0 is also used, a number from either positive or negative part is expressed as 0.



#### Signed Integers (Integrs)

- Positive integers
  - They are like unsigned integers.
     00101 = 5
- Negative integers
  - Sign Bit Representation Always sign bit is first bit,
     Other bits are written as in unsigned representation.
     10101 = -5
  - 1 's complement Each bit is inverted
    . 11010 = -5
  - In both representations, the largest bit represents the sign of the number:
     0= positive , 1= negative



#### Two's complement

- Sign bit notation and 1 's complement problems
  - The number 0 has two representations (+0 and -0)

• 1 's complement

$$00000 = +0$$
  
 $11111 = -0$ 



#### Two's complement

- Sign bit notation and 1 's complement problems
  - The necessary hardware circuits of arithmetic operations are very complex.
    - Problem with sign bit denoted addition

- For the solution, before adding, it is necessary to check which one is larger, subtract the smaller from the larger, and place the sign of the larger number.
- Therefore, it is necessary to have a circuit, subtractor and sign bit setter in the necessary hardware to perform the necessary addition process. That is, the hardware becomes complex and large.



#### Two's Complement

- If the value to be expressed is 0 or positive,
  - They are written as unsigned integers, with the largest bits filled with 0.
- If the number is negative,
  - written as a positive number
  - Each bit is inverted (1's complement)
  - 1 is added to the result.

00101 (5) 01001 (9) 11010 (1's complement) 
$$+ \frac{1}{1011}$$
 (-5)  $+ \frac{1}{10111}$  (-9)



#### Two's Complement

- Shortcut to find Two's complement :
  - Copy bits of the number from right to left until you see the first "1"
  - Reverse remaining bits





## Two's complement

- Biggest bit sign bit and weight  $-2^{n-1}$  is .
- -2 <sup>n-1</sup> with n bits It can be expressed from 2 <sup>n-1</sup> to 1.
  - The smallest negative number (-2 n-1) has no positive counterpart.

| <b>-2</b> <sup>3</sup> | <b>2</b> <sup>2</sup> | <b>2</b> <sup>1</sup> | <b>2</b> <sup>0</sup> |   | <b>-2</b> <sup>3</sup> | <b>2</b> <sup>2</sup> | <b>2</b> <sup>1</sup> | <b>2</b> <sup>0</sup> |    |
|------------------------|-----------------------|-----------------------|-----------------------|---|------------------------|-----------------------|-----------------------|-----------------------|----|
| 0                      | 0                     | 0                     | 0                     | 0 | 1                      | 0                     | 0                     | 0                     | -8 |
| 0                      | 0                     | 0                     | 1                     | 1 | 1                      | 0                     | 0                     | 1                     | -7 |
| 0                      | 0                     | 1                     | 0                     | 2 | 1                      | 0                     | 1                     | 0                     | -6 |
| 0                      | 0                     | 1                     | 1                     | 3 | 1                      | 0                     | 1                     | 1                     | -5 |
| 0                      | 1                     | 0                     | 0                     | 4 | 1                      | 1                     | 0                     | 0                     | -4 |
| 0                      | 1                     | 0                     | 1                     | 5 | 1                      | 1                     | 0                     | 1                     | -3 |
| 0                      | 1                     | 1                     | 0                     | 6 | 1                      | 1                     | 1                     | 0                     | -2 |
| 0                      | 1                     | 1                     | 1                     | 7 | 1                      | 1                     | 1                     | 1                     | -1 |

Dr. V. E. Levent Embedded Systems



### Convert binary complement to base 10

- 1. If the largest bit (leftmost) is 1, take the twos complement of the number and find its positive value.
- 2. Add the values by multiplying by powers of 2, starting with the rightmost bit.
- 3. If the number is negative when starting the process (i.e. its leftmost bit is 1), put a sign on the base 10 number that appears.

$$X = 01101000$$
 binary  
=  $2^{6} + 2^{5} + 2^{3} = 64 + 32 + 8$   
=  $104_{tens}$ 

| n  | 2 n  |
|----|------|
| 0  | 1    |
| 1  | 2    |
| 2  | 4    |
| 3  | 8    |
| 4  | 16   |
| 5  | 32   |
| 6  | 64   |
| 7  | 128  |
| 8  | 256  |
| 9  | 512  |
| 10 | 1024 |



## Convert binary complement to base 10

$$X = 00100111_{binary}$$
  
=  $2^{5}+2^{2}+2^{1}+2^{0}=32+4+2+1$   
=  $39_{tens}$ 

$$X = 11100110_{binary}$$
 $-X = 00011010$ 
 $= 2^{4} + 2^{3} + 2^{1} = 16 + 8 + 2$ 
 $= 26_{tens}$ 
 $X = -26_{tens}$ 

| n  | <b>2</b> <sup>n</sup> |
|----|-----------------------|
| 0  | 1                     |
| 1  | 2                     |
| 2  | 4                     |
| 3  | 8                     |
| 4  | 16                    |
| 5  | 32                    |
| 6  | 64                    |
| 7  | 128                   |
| 8  | 256                   |
| 9  | 512                   |
| 10 | 1024                  |



### Decimal to Binary Complement Conversion

- Method 1 : Division
- 1. Get the absolute value of the decimal number . (It should always be positive .)
- 2. Divide by two remainder is the smallest bit .
- 3. Keep dividing until you find 0, and write the remainder of the divisions from right to left.
- 4. Add zeros to the most right for completing width of the number. (in the example below the number is assumed to be 8 bits)

  If the decimal number is negative, take the binary complement of the resulting number.

$$X = 104_{tens}$$
 $104/2 = 52 k0 bit 0$ 
 $52/2 = 26 k0 bit 1$ 
 $26/2 = 13 k0 bit 2$ 
 $13/2 = 6 k1 bit 3$ 
 $6/2 = 3 k0 bit 4$ 
 $3/2 = 1 k1 bit 5$ 
 $X = 01101000_{binary}$ 
 $1/2 = 0 k1 bit 6$ 



### Decimal to Binary Complement Conversion

- Second Method : Subtracting powers of 2
- 1. Get the absolute value of the decimal number.
- 2. Subtract the number less than or equal to the number from the powers of 2.
- 3. Place 1 in the relevant place.
- 4. Keep going until you get 0.
- 5. Add zeros to the most right for completing width of the number. If the decimal number is negative, take the binary complement of the resulting binary number

| n  | 2 <sup>n</sup> |
|----|----------------|
| 0  | 1              |
| 1  | 2              |
| 2  | 4              |
| 3  | 8              |
| 4  | 16             |
| 5  | 32             |
| 6  | 64             |
| 7  | 128            |
| 8  | 256            |
| 9  | 512            |
| 10 | 1024           |
|    |                |



# Decimal to Binary Complement Conversion

| X = 104 <sub>tens</sub> | 104 - 64 =<br>40 - 32 =<br>8 - 8 = | <del>-</del> 8 | bit 6<br>bit 5<br>bit 3 |
|-------------------------|------------------------------------|----------------|-------------------------|
| $X = 01101000_{binary}$ |                                    |                |                         |

| n  | <b>2</b> <sup>n</sup> |
|----|-----------------------|
| 0  | 1                     |
| 1  | 2                     |
| 2  | 4                     |
| 3  | 8                     |
| 4  | 16                    |
| 5  | 32                    |
| 6  | 64                    |
| 7  | 128                   |
| 8  | 256                   |
| 9  | 512                   |
| 10 | 1024                  |



#### Addition

- Binary complement numbers is similar to the addition of unsigned numbers. No control mechanism is required.
  - The hand bit to be obtained from the largest bit is discarded.



#### Subtraction

- Find the negative form of the second number and add.
  - Binary complement of the second number and add it with the first number

```
01101000 (104)
- 00010000 (16)
01101000 (104)
+ 11110000 (-16)
01011000 (88)
```



## Sign Extension

- When adding two numbers, both numbers must have the same bit width.
- If we just add 0 to the left of the two numbers to make them the same bit width;

```
4-bit 8-bit
0100 (4) 00000100 (currently 4)
1100 (-4) 00001100 (12, not -4)
```

• For correct calculation, the sign bit of the number is placed where it will be expanded. 4-bit 8-bit

```
1100 (-4) 11111100 (currently -4)
```



#### Overflow

• When numbers are very large, the sum may turn out to be too large to be expressed in n-bit numbers.

$$01000 (8)$$
  $11000 (-8)$   
+  $01001 (9)$  +  $10111 (-9)$   
 $10001 (-15)$   $01111 (+15)$ 

- Overflow status :
  - It can happen in addition operations where both numbers have the same sign .



# Logic Operations

- Are calculated as
  - There are two cases, True =1, False =0

| A | В | A and B |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 0       |
| 1 | 0 | 0       |
| 1 | 1 | 1       |

| A | В | A or B |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 1      |

| Α | Not A |
|---|-------|
| 0 | 1     |
| 1 | 0     |



## Logic Operation Examples

- And
- With 0 = result is 0
- With 1 = result no change

- Or
- With 0 or operation = no change
- With 1 or operation = 1

- Not
  - It changes every bit.

|     | 11000101 |
|-----|----------|
| and | 00001111 |
|     | 00000101 |

|     | 11000101 |
|-----|----------|
| or_ | 00001111 |
|     | 11001111 |



#### Hexadecimal Notation

- It is a 16 bit format that is frequently used on computers.
  - Each 4 bits of a binary number represents a hexadecimal representation.
  - It provides fewer mistakes than using long 0's and 1's.

| Bin  | Hex | Dec | Bin  | Hex | Dec |
|------|-----|-----|------|-----|-----|
| 0000 | 0   | 0   | 1000 | 8   | 8   |
| 0001 | 1   | 1   | 1001 | 9   | 9   |
| 0010 | 2   | 2   | 1010 | Α   | 10  |
| 0011 | 3   | 3   | 1011 | В   | 11  |
| 0100 | 4   | 4   | 1100 | С   | 12  |
| 0101 | 5   | 5   | 1101 | D   | 13  |
| 0110 | 6   | 6   | 1110 | E   | 14  |
| 0111 | 7   | 7   | 1111 | F   | 15  |



## Converting from Binary to Hexadecimal

- Each 4 bits equals 1
  - They are grouped starting from the right.





### Decimal Numbers: Fixed -Point Representation

- Decimals expression
  - A point is chosing for seperating integer and fraction parts
  - Addition and subtration operations are calculating as twos complement operations





#### Texts: ASCII Characters

• The ASCII table is an 8-bit table. Each number between 0-255 has a corresponding character or control signal.

| 00 | nul | 10 | dle | 20 | sp               | 30 | 0 | 40 | <u>a</u> | 50 | P | 60 | ` | 70 | p   |
|----|-----|----|-----|----|------------------|----|---|----|----------|----|---|----|---|----|-----|
| 01 | soh | 11 | dc1 | 21 | !                | 31 | 1 | 41 | A        | 51 | Q | 61 | a | 71 | q   |
| 02 | stx | 12 | dc2 | 22 | 11               | 32 | 2 | 42 | В        | 52 | R | 62 | b | 72 | r   |
| 03 | etx | 13 | dc3 | 23 | #                | 33 | 3 | 43 | С        | 53 | s | 63 | C | 73 | s   |
| 04 | eot | 14 | dc4 | 24 | \$               | 34 | 4 | 44 | D        | 54 | T | 64 | d | 74 | t   |
| 05 | enq | 15 | nak | 25 | o <sub>l</sub> o | 35 | 5 | 45 | E        | 55 | U | 65 | е | 75 | u   |
| 06 | ack | 16 | syn | 26 | &                | 36 | 6 | 46 | F        | 56 | V | 66 | f | 76 | v   |
| 07 | bel | 17 | etb | 27 | T                | 37 | 7 | 47 | G        | 57 | W | 67 | g | 77 | w   |
| 80 | bs  | 18 | can | 28 | (                | 38 | 8 | 48 | H        | 58 | X | 68 | h | 78 | x   |
| 09 | ht  | 19 | em  | 29 | )                | 39 | 9 | 49 | I        | 59 | Y | 69 | i | 79 | У   |
| 0a | nl  | 1a | sub | 2a | *                | 3a | : | 4a | J        | 5a | Z | 6a | j | 7a | z   |
| 0b | vt  | 1b | esc | 2b | +                | 3b | ; | 4b | K        | 5b | [ | 6b | k | 7b | {   |
| 0c | np  | 1c | fs  | 2c | ,                | 3с | < | 4c | L        | 5c | \ | 6c | 1 | 7c | - 1 |
| 0d | cr  | 1d | gs  | 2d | -                | 3d | = | 4d | M        | 5d | 1 | 6d | m | 7d | }   |
| 0e | so  | 1e | rs  | 2e |                  | 3e | > | 4e | N        | 5e | ^ | 6e | n | 7e | ~   |
| 0f | si  | 1f | us  | 2f | /                | 3f | ? | 4f | 0        | 5f | _ | 6f | 0 | 7f | del |

Dr. V. E. Levent Embedded Systems



## Other Data Types

- Texts
  - Formed by sequential writing of characters
- Image
  - They are formed by the combination of pixels.
    - Black and White: 1 bit (1/0 = black / white)
    - Color: Red, Blue, Green (RGB) comp1nts are available. Each is stored as 8-bit numbers.
- Sound
  - It is usually represented as a sequential recording of fixedpoint notation numbers.



## Design of Processor Blocks with

- Number of Transistors in Processors
  - Intel 4004 (1971): 2250
  - Intel 8088 (1979): 29k
  - AMD K6 (1997): 7.5 million
  - Intel Pentium 4 (2006): 184 Million
  - Intel I7 Haswell -E (2014): 2.6 Billion
  - AMD Epyc Rome (2019): 32 Billion





- **Decoder**: Activates the pin corresponding to the number received in the input.
- 2 -input decoder: There are 4 possible inputs.
  - It has 4 outputs
- Enable with pin decoder
  - If e=0, all outputs are 0
  - If e=1, it behaves normally
- N input decoder: 2 <sup>n</sup> exit







## Multiplex e r (Mux)

- Mux: It is a combinational circuit. Outputs incoming inputs according to the select bit.
  - 4 input mux → 2 select inputs
  - 8 input mux → 3 select input
  - N inputs  $\rightarrow \log_2(N)$  select input





## Mux Internal Structure



Dr. V. E. Levent Embedded Systems



### MUX Merge



- Example: Two 4-bit inputs, A (a3 a2 a1 a0) and B (b3 b2 b1 b0)
  - 4-bit 2x1 MUX can be done using 4 1 bit, 2x1 MUX



### N-bit MUX Example





- There are 4 possible texts to display
  - Temperature, Average Fuel Usage, Average Speed, KM Remaining all
  - Which one will appear on the screen is selected with the x and y bits.
  - 8-bit 4x1 MUX can be used.



## Gate Delays



- All circuits have a delay.
  - Outputs don't change instantly



### From Logic Gates to Control Units

- Combinational Circuits
  - The output of the circuit depends on the current input.
  - The output delay of the circuit depends on the longest path in the circuit.





#### From Logic Gates to Control Units

- Sequential Circuits
  - The output depends on both the current input and the values in memory.
  - Some outputs of the circuit are stored in memory and reused.
  - We'll get into the details next week.





### Multiplexer - MUX

- *n* bit select, 2 <sup>n</sup> input and It has only one output.
  - According to the select bit, the value from the input is transferred to the output.



4-1 MUX



## Selector (Multiplexer - MUX)

- *n* bit select, 2 <sup>n</sup> input and It has only one output.
  - According to the select bit, the value from the input is transferred to the output.



2 -1 MUX



#### Full Adder

• Taking two bits (A and B) and a carry input (Cin), it produces a one-bit sum (S) and carry (Cout).



| A | В | $\mathbf{C}_{in}$ | S | C <sub>out</sub> |
|---|---|-------------------|---|------------------|
| 0 | 0 | 0                 | 0 | 0                |
| 0 | 0 | 1                 | 1 | 0                |
| 0 | 1 | 0                 | 1 | 0                |
| 0 | 1 | 1                 | 0 | 1                |
| 1 | 0 | 0                 | 1 | 0                |
| 1 | 0 | 1                 | 0 | 1                |
| 1 | 1 | 0                 | 0 | 1                |
| 1 | 1 | 1                 | 1 | 1                |



#### 4-bit Adder





#### Other Circuits

Any circuit can be expressed with And, Or and Not gates.

| A | В | C | D |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 |



- L. In the truth table, do and operation for 1 outputting rows
- 2. Combine these and gates with or gate



# Vivado Design Tool

 Design Flow Various IPs RTL **FPGA** Hardware Synthesis Algorithm Implementation Design Configuration Architecture Design Behavioral Timing In-Chip Validation Verification Debugging Verification



## Verilog – Combinational Circuits





## Verilog – Combinational Circuits





## Chip Design Training

- FPGA (Field programmable Gate Arrays) is an integrated chip.
- It contains programmable blocks and configurable connections between these blocks.
- By programming these blocks and connections, the desired circuit can be implemented in the FPGA .



Example FPGA Chip



## Chip Design Training

- Some FPGAs can only be programmed once.
- It is called one-time programmable (OTP).



### What is FPGA?

- "Field Programmable" means that it can be programmed in the required application with unlimited count.
- This means that after the FPGA chips are produced in the factory, they can be used in the desired design later on.



### Why is FPGA important?

Wide variety of integrated circuits (IC – Integrated circuits ) are available.

- Memory
- Microprocessors
- Programmable logic devices ( Programmable logic devices )
  - SPLD (Simple)
  - CPLD (Complex)
- ASIC Application specific integrated circut
- And FPGAs ...



#### **ASICs**

- They are useful in the implementation of huge and complex circuits.
- ASICs are integrated circuits built to perform a specific operation.
- ASICs provide very high performance (operation at high frequencies), ASIC design complexity and design time and costs are quite high.
- And the produced chips cannot be modified. In case of a fault with the chip, all produced chips will be thrown away.



### **FPGAs**

- FPGAs It is programmable.
- Unlike ASICs; In the case of an error in the design, the design can be repeatedly modified and tested.



#### **FPGAs**

- FPGAs They are much cheaper than ASICs. (ASICs are only cheap when millions of units are produced)
- FPGAs is much easier than creating an ASIC design.
- Due to the shorter design time, once a product is produced, the time to market is shorter.
- NRE (Non-recurring engineering) is high when developing a ASIC Design





### FPGA is mainly used

- Telecommunication
- Networking
- Automotive
- Medical
- Various industrial applications
- Prototypes of ASIC designs
- DSP ( Digital signal processor ) applications
- SoC (System on Chip), a single IC where all necessary electronics are gathered together



Reasons for FPGA Use

- Computing Power
- Controlling with nanosecond order



#### Reasons for FPGA Use

| <b>Processors</b> |
|-------------------|
|-------------------|

```
 c[0]=a[0]+b[0]; \\ c[1]=a[1]+b[1]; \\ c[2]=a[2]+b[2]; \\ c[3]=a[3]+b[3]; \\ c[3]=a[1000]+b[1000]; \\ c[1000]=a[1000]+b[1000]; \\ c[0]<=a[0]+b[0]; \\ c[1]<=a[0]+b[0]; \\ c[1]<=a[1]+b[1]; \\ c[2]<=a[1]+b[1]; \\ c[2]<=a[2]+b[2]; \\ c[3]<=a[3]+b[3]; \\ ... \\ c[1000]<=a[1000]+b[1000]; \\ c[1000]<=a[1000]+b[1000]+b[1000]; \\ c[1000]<=a[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1
```



#### Reasons for FPGA Use

### <u>Processors</u>

### c[0]=a[0]+b[0];

$$c[1]=a[1]+b[1];$$

$$c[2]=a[2]+b[2];$$

$$c[3]=a[3]+b[3];$$

---

### **FPGA**

$$c[0] <= a[0] + b[0];$$

$$c[1] <= a[1] + b[1];$$

$$c[2] <= a[2] + b[2];$$

$$c[3] <= a[3] + b[3];$$

...

$$c[1000] <= a[1000] + b[1000];$$



#### Reasons for FPGA Use

| <b>Processors</b> |
|-------------------|
|-------------------|

# <u>FPGA</u>

```
 c[0]=a[0]+b[0]; \\ c[1]=a[1]+b[1]; \\ c[2]=a[2]+b[2]; \\ c[3]=a[3]+b[3]; \\ c[3]=a[1000]+b[1000]; \\ c[1000]=a[1000]+b[1000]; \\ c[1000]<=a[1000]+b[1000]; \\ c[1000]<=a[1000]+b[1000]+b[1000]; \\ c[1000]<=a[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]+b[1000]
```



#### Reasons for FPGA Use

| <u>Processors</u> |
|-------------------|
|-------------------|

### <u>FPGA</u>

```
 c[0]=a[0]+b[0]; \\ c[1]=a[1]+b[1]; \\ c[2]=a[2]+b[2]; \\ c[3]=a[3]+b[3]; \\ c[3]<=a[3]+b[3]; \\ c[1]<=a[1]+b[1]; \\ c[2]<=a[2]+b[2]; \\ c[3]<=a[2]+b[2]; \\ c[3]<=a[3]+b[3]; \\ c[3]<=a[3]+b[3]; \\ c[1000]=a[1000]+b[1000]; \\ c[1000]<=a[1000]+b[1000];
```



#### Reasons for FPGA Use

| <b>Processors</b> |
|-------------------|
|-------------------|

# **FPGA**

c[0]=a[0]+b[0]; $c[0] \le a[0] + b[0];$ 

c[1]=a[1]+b[1];c[1] <= a[1] + b[1];

c[2]=a[2]+b[2];c[2] <= a[2] + b[2];

c[3]=a[3]+b[3]; c[3] <= a[3] + b[3];

c[1000]=a[1000]+b[1000]; c[1000] < =a[1000] + b[1000];



#### Reasons for FPGA Use

# **Processors**

```
c[0]=a[0]+b[0];

c[1]=a[1]+b[1];

c[2]=a[2]+b[2];

c[3]=a[3]+b[3];

...

c[1000]=a[1000]+b[1000];
```



#### Reasons for FPGA Use

### **Processors**

```
c[0]=a[0]+b[0];
c[1]=a[1]+b[1];
c[2]=a[2]+b[2];
c[3]=a[3]+b[3];
...
c[1000]=a[1000]+b[1000];
```



### Reasons for FPGA Use

# **Processors**







### Reasons for FPGA Use

### <u>CPU</u>

For 1000 transactions (assume each operation takes 1 cycle),

Average Processor frequency: 3 GHz,

Required Time = Number of operations X (1/Frequency)

= 1000 X 1/3 billion

= 333 nanoseconds

# **FPGA**

For 1000 transactions (assume each operation takes 1 cycle),

Average FPGA frequency: 100mhz

Time required =  $1 \times (1/\text{Frequency})$ 

= 1 X 1/100m

= 10 nanoseconds



In LABs Xilinx Basys3 FPGAs with Artix 7 FPGAs will be used.





Vivado IDE will be used to programming Xilinx Based FPGAs





- Download Address: <a href="https://www.xilinx.com/support/download.html">https://www.xilinx.com/support/download.html</a>
- Installation and Licensing Video: <a href="https://www.youtube.com/watch?v=yW7t28XaVEs">https://www.youtube.com/watch?v=yW7t28XaVEs</a>



























Vivado Design Tool

is the FPGA we will use in LABs

XC7A35Tcpg236-1

The model must be selected.









Vivado Design Tool

Adding a new design resource





















Vivado Design Tool

RTL Design File To Do





Vivado Design Tool

Adding a constraint





Vivado Design Tool

Adding a constraint





Vivado Design Tool

Adding a constraint





Vivado Design Tool

Adding a constraint





Vivado Design Tool

Adding a constraint

Write constraints





Vivado Design Tool

Bitstream generation





Vivado Design Tool

Bitstream generation





Vivado Design Tool

Bitstream generation





Most commonly using HDL (Hardware Description Language) Languages

- Verilog
- System Verilog
- VHDL











Vivado,

- Verilog
- system Verilog
- VHDL

It supports languages. Within the scope of the course, designs will be made with Verilog language.





myModule





myModule

#### **Verilog Design**

module myModule(input a, input b, input c,
output reg y);

endmodule





myModule

#### **Verilog Design**

```
module myModule(input a, input b, input c, output reg y);

reg tmp;
always@(*) begin
    tmp = a & b;
    y = tmp | c;
end

endmodule
```





FPGA





Dr. V. E. Levent Digital Design





Dr. V. E. Levent Digital Design



Constraint (XDC) File

http://levent.tc/files/courses/digital\_design/labs/basys3.xdc