

| l-type            | Description                         | Range           | Type definitions in Ada                                                     |
|-------------------|-------------------------------------|-----------------|-----------------------------------------------------------------------------|
| unsigned<br>char  | 8-bit<br>integer no<br>sign         | 0255            | <pre>type UINT8 is integer range 0255;<br/>for UINT8'size use 8;</pre>      |
| signed<br>char    | 8 bit<br>integer 2's<br>complement  | -128+127        | <pre>type SINT8 is integer range -128127;<br/>for SINT8'size use 8;</pre>   |
| unsigned<br>short | 16-bit<br>integer no<br>sign        | 065535          | <pre>type UINT16 is integer range 065535;<br/>for UINT16'size use 16;</pre> |
| signed<br>short   | 16 bit<br>integer 2's<br>complement | -32768<br>32767 | type SINT16 is integer<br>range -3276832767;<br>for SINT16'size use 16;     |

| type BIT_TYP | E is range 01; Named type and | l minmax values |
|--------------|-------------------------------|-----------------|
| FOR BIT_TYPE | SIZE use 1; Object type n     | leeds a bit     |
| cype BITFIEL | D8 18                         |                 |
| b0:          | BIT TYPE:                     |                 |
| b1:          | BIT TYPE;                     |                 |
| b2:          | BIT_TYPE;                     |                 |
| b3:          | BIT_TYPE;                     |                 |
| b4:          | BIT_TYPE;                     |                 |
| b5:          | BIT_TYPE;                     |                 |
| b6:          | BIT_TYPE;                     |                 |
| b7:          | BIT_TYPE;                     |                 |
| end record;  |                               |                 |



L5-EDA222











## CHALMERS Low level programming in Ada95

## Declaring a "variable" for an IO register

- 1. Create a type definition that represents the register bits.
- 2. Declare an object ("variable") of this type
- 3. Use an *address clause*, to tell the compiler where this object resides

Roger Johanssor

## IO\_port : BITFIELD8;

-- address clause for this object:
for IO\_port'address use constant System.address :=
 System.Storage\_elements.to\_address( memory address );

L5-EDA222

. . .



| 1 I. (1                           | and the design of the design of the                       |                   |
|-----------------------------------|-----------------------------------------------------------|-------------------|
| ne volatile prag<br>dependently o | gma tells the compiler that an obje<br>f program control. | ct can be changed |
| he generic exa                    | ample is IO interface registers (in the                   | ne hardware).     |
|                                   |                                                           |                   |
| <br>TO mont :                     |                                                           |                   |
| pragma Volati                     | le( IO Port );                                            |                   |
| address cl                        | ause for this object:                                     |                   |
| for IO_port'a                     | ddress use constant System.addr                           | ess :=            |
| System                            | .Storage_elements.to_address( n                           | nemory address ); |
|                                   |                                                           |                   |

L5-EDA222

12

| Cł | ALMERS                                                        | Low level programming in Ada95                                                                                      | Roger Johansson                                         |
|----|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
|    | Why is "Vola                                                  | atile" important?                                                                                                   |                                                         |
|    | Consider the follo<br>oop into a single<br>unless the test va | owing example, a decent compiler sh<br>statement (test only once, or perhap<br>alue couldn't change between the loc | ould reduce the<br>os even remove it)<br>op iterations. |
|    | wait for de while (IO_Port NULL;                              | vice ready<br>.b7 /= 0 ) loop                                                                                       |                                                         |
|    | end loop;                                                     |                                                                                                                     |                                                         |
|    | The<br>pragma Volatil                                         | e( IO_Port );                                                                                                       |                                                         |
|    | tells the compile                                             | er to do NO such optimizations here                                                                                 |                                                         |

L5-EDA222











| 00      | Πa   | rcommunicatio                     |                                         |                    |
|---------|------|-----------------------------------|-----------------------------------------|--------------------|
| Address | FC   | Register Read (R/W = 1)           | Register Write (R/W = 0)                | _                  |
| 700     | s1   | MCR (HIGH BYTE)                   | MCR (HIGH BYTE)                         | Control registers  |
| 701     | 8    | MCR (LOW BYTE)                    | MCR (LOW BYTE)                          |                    |
| 702     | s    | DO NOT ACCESS <sup>3</sup>        | DO NOT ACCESS <sup>3</sup>              | ]                  |
| 703     | s    | DO NOT ACCESS <sup>3</sup>        | DO NOT ACCESS <sup>3</sup>              |                    |
| 704     | s    | INTERRUPT LEVEL (ILR)             | NTERRUPT LEVEL (ILR)                    | ] Status registers |
| 705     | s    | INTERRUPT VECTOR (IVR)            | INTERRUPT VECTOR (IVR)                  | ]                  |
| 710     | sN2  | MODE REGISTER 1A (MR1A)           | MODE REGISTER 1A (MR1A)                 | Data registers     |
| 711     | au 📘 | STATUS REGISTER A (SRA)           | CLOCK-SELECT REGISTER A (CSRA)          | Data registers     |
| 712     | su 🗌 | DO NOT ACCESS <sup>3</sup>        | COMMAND REGISTER A (CRA)                | 1                  |
| 713     | su   | RECEIVER BUFFER A (RBA)           | TRANSMITTER BUFFER A (TBA)              | 1                  |
| 714     | au 📘 | INPUT PORT CHANGE REGISTER (IPCR) | AUXILIARY CONTROL REGISTER (ACR)        | 1                  |
| 715     | su 🗌 | INTERRUPT STATUS REGISTER (ISR)   | INTERRUPT ENABLE REGISTER (IER)         | 1                  |
| 716     | su 🗌 | DO NOT ACCESS <sup>3</sup>        | DO NOT ACCESS <sup>3</sup>              | 1                  |
| 717     | au 🗌 | DO NOT ACCESS <sup>3</sup>        | DO NOT ACCESS <sup>3</sup>              | 1                  |
| 718     | su 🗌 | MODE REGISTER 1B (MR1B)           | MODE REGISTER 1B (MR1B)                 | 1                  |
| 719     | su   | STATUS REGISTER B (SRB)           | CLOCK-SELECT REGISTER B (CSRB)          | 1                  |
| 71A     | au   | DO NOT ACCESS <sup>3</sup>        | COMMAND REGISTER B (CRB)                | 1                  |
| 718     | su   | RECEIVER BUFFER B (R88)           | TRANSMITTER BUFFER B (TBB)              | 1                  |
| 71C     | su   | DO NOT ACCESS <sup>3</sup>        | DO NOT ACCESS <sup>3</sup>              | ]                  |
| 71D     | su 🗌 | INPUT PORT REGISTER (IP)          | OUTPUT PORT CONTROL REGISTER (OPCR)     | 1                  |
| 71E     | su   | DO NOT ACCESS <sup>3</sup>        | OUTPUT PORT (OP) <sup>4</sup> BIT SET   | 1                  |
| 71F     | su 🗌 | DO NOT ACCESS <sup>3</sup>        | OUTPUT PORT (OP) <sup>4</sup> BIT RESET | 1                  |
| 720     | su 🗌 | MODE REGISTER 2A (MR2A)           | MODE REGISTER 2A (MR2A)                 | 1                  |
| 721     | SU D | MODE REGISTER 28 (MR28)           | MODE REGISTER 28 (MR28)                 | 1                  |



| CHALMERS                            | Low level prog                                                                                                                                                                       | ramming     | in Ada95 | i        |         |        |                 |        | Roger Joha | nsson |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------|----------|---------|--------|-----------------|--------|------------|-------|
| Use of in                           | Use of interrupts                                                                                                                                                                    |             | 6        | 5        | 4       | 3      | 2               | 1      | \$715<br>0 |       |
| COS<br>- Change of State<br>DBA/DBB |                                                                                                                                                                                      | COS         | DBB      | RxRDYB   | TxRDYB  | 0      | DBA             | RxRDYA | TxRDYA     |       |
|                                     |                                                                                                                                                                                      | RESET:<br>0 | 0        | 0        | 0       | 0      | 0               | 0      | 0          |       |
| - Delta Break                       | - Delta Break                                                                                                                                                                        |             | Only     |          |         |        | Supervisor/User |        |            |       |
|                                     | RxRDYB—Channel B Receiver Ready or FIFO full<br>1 = Enable interrupt<br>0 = Disable interrupt<br>TxRDYB—Channel B Transmitter Ready<br>1 = Enable interrupt<br>0 = Disable interrupt |             |          |          |         |        |                 |        |            |       |
|                                     | Use IER to enable                                                                                                                                                                    | e interr    | upt so   | urces fi | rom the | serial | modul           | е      |            |       |
|                                     |                                                                                                                                                                                      |             |          |          |         |        |                 |        |            |       |
| L5-EDAZZZ                           |                                                                                                                                                                                      |             |          |          |         |        |                 |        |            | 21    |

|        | a. Mf                        | R1B                          |                                                         |                                                                 |                                  | \$710. \$7                                                                                         | 18 |            |      |                |   |
|--------|------------------------------|------------------------------|---------------------------------------------------------|-----------------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------|----|------------|------|----------------|---|
| 7      | 6                            | 5                            | 4                                                       | 3                                                               | 2                                | 1 0                                                                                                |    |            |      |                |   |
| RxRTS  | R/F                          | ERR                          | PM1                                                     | PM0                                                             | PT                               | B/C1 B/C                                                                                           | 0  |            |      |                |   |
| RESET: |                              |                              |                                                         | -                                                               |                                  |                                                                                                    |    | B/C1       | B/C0 | Bits/Character |   |
| 0      | 0                            | 0                            | 0                                                       | 0                                                               | 0                                | 0 0                                                                                                |    | 0          | 0    | Five Bits      | 1 |
| Read   | 1/Writ                       | e                            |                                                         |                                                                 | Sup                              | ervisor/Us                                                                                         | er | 0          | 1    | Six Bits       | 1 |
| 1 (Cuu |                              |                              |                                                         | 0141301/03                                                      |                                  | 1                                                                                                  | 0  | Seven Bits |      |                |   |
|        |                              |                              |                                                         |                                                                 |                                  |                                                                                                    |    | 1          | 1    | Eight Bits     |   |
|        |                              |                              |                                                         |                                                                 |                                  |                                                                                                    |    |            |      |                |   |
| 1      | PM1                          | PM0                          | Parity                                                  | Mode                                                            | PT                               | Parity Type                                                                                        | _  |            |      |                |   |
| [      | <b>PM1</b>                   | <b>PM0</b>                   | Parity<br>With F                                        | Mode<br>Parity                                                  | <b>РТ</b><br>0                   | Parity Type<br>Even Parity                                                                         |    |            |      |                |   |
|        | PM1<br>0                     | <b>PM0</b><br>0              | Parity<br>With F                                        | Mode<br>Parity<br>Parity                                        | <b>РТ</b><br>0<br>1              | Parity Type<br>Even Parity<br>Odd Parity                                                           | 7  |            |      |                |   |
|        | PM1<br>0<br>0                | PM0<br>0<br>0                | Parity<br>With F<br>With F<br>Force                     | Mode<br>Parity<br>Parity<br>Parity                              | РТ<br>0<br>1<br>0                | Parity Type<br>Even Parity<br>Odd Parity<br>Low Parity                                             |    |            |      |                |   |
|        | PM1<br>0<br>0<br>0           | PM0<br>0<br>1<br>1           | Parity<br>With F<br>With F<br>Force<br>Force            | Mode<br>Parity<br>Parity<br>Parity<br>Parity                    | PT<br>0<br>1<br>0<br>1           | Parity Type<br>Even Parity<br>Odd Parity<br>Low Parity<br>High Parity                              |    |            |      |                |   |
|        | PM1<br>0<br>0<br>0<br>1      | PM0<br>0<br>1<br>1<br>0      | Parity<br>With F<br>Force<br>Force<br>No Pa             | Mode<br>Parity<br>Parity<br>Parity<br>Parity<br>arity           | PT<br>0<br>1<br>0<br>1<br>X      | Parity Type<br>Even Parity<br>Odd Parity<br>Low Parity<br>High Parity<br>No Parity                 |    |            |      |                |   |
|        | PM1<br>0<br>0<br>0<br>1<br>1 | PM0<br>0<br>1<br>1<br>0<br>1 | Parity<br>With F<br>Force<br>Force<br>No Pa<br>Multidro | Mode<br>Parity<br>Parity<br>Parity<br>Parity<br>arity<br>p Mode | PT<br>0<br>1<br>0<br>1<br>X<br>0 | Parity Type<br>Even Parity<br>Odd Parity<br>Low Parity<br>High Parity<br>No Parity<br>Data Charact | er |            |      |                |   |





| CHALMERS Low level prog.                                                                                                                                                                                                                                                                                                                                                                                                                                                 | CHALMERS Low level programming in Ada95 Roger Johansso                                                                                |                                                                                                                              |                                                                                                                     |                                                                                                 |                                                             |       |        |       |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------|-------|--------|-------|--|
| Status register.                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SRA,                                                                                                                                  | SRB                                                                                                                          |                                                                                                                     |                                                                                                 |                                                             |       | \$711, | \$719 |  |
| (one for each                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 7                                                                                                                                     | 6                                                                                                                            | 5                                                                                                                   | 4                                                                                               | 3                                                           | 2     | 1      | 0     |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RB                                                                                                                                    | Æ                                                                                                                            | PE                                                                                                                  | OE                                                                                              | TXEMP                                                       | TXRDY | FFULL  | RxRDY |  |
| channel A and B)                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RESET:<br>0                                                                                                                           | 0                                                                                                                            | 0                                                                                                                   | 0                                                                                               | 0                                                           | 0     | 0      | 0     |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                       | Supervisor/User                                                                                                              |                                                                                                                     |                                                                                                 |                                                             |       |        |       |  |
| This bit is duplicated in the ISR; bit 0 for chi<br>1 = The transmitter holding register is er<br>This bit is set when the character is i<br>This bit is set when the transmit<br>the transmitter holding register while<br>transmitter holding register was<br>disabled.<br>RxRDY—Receiver Ready<br>1 = A character has been received and<br>CPU32. This bit is set when a charar<br>register to the FIFO.<br>0 = The CPU32 has read the receiver I<br>after this read. | annel A an<br>mpty and re<br>transferred<br>ther is first t<br>the transm<br>loaded by<br>d is waiting<br>acter is tra<br>buffer, and | d bit 4 for<br>eady to be<br>to the tra-<br>enabled. (<br>nitter is di<br>the CPU:<br>g in the Fl<br>ansferred<br>t no chard | channel I<br>loaded v<br>nsmitter s<br>Character:<br>sabled and<br>32, or the<br>FO to be<br>from the<br>acters rer | B.<br>vith a cha<br>shift regist<br>s loaded i<br>e not<br>transmitte<br>receiver<br>main in th | racter.<br>ter.<br>into<br>er is<br>the<br>shift<br>ne FIFO |       |        |       |  |
| L5-EDA222                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                       |                                                                                                                              |                                                                                                                     |                                                                                                 |                                                             |       |        | 25    |  |

| CHALMERS  | Low level prog                | ramming i      | n Ada95           |      |    |              |       | F      | oger Johanss | on |
|-----------|-------------------------------|----------------|-------------------|------|----|--------------|-------|--------|--------------|----|
|           |                               | SRA,           | SRB               |      |    |              |       | \$711, | \$719        |    |
| EXAMPLE:  |                               | 7              | 6                 | 5    | 4  | 3            | 2     | 1      | 0            |    |
| C or Java |                               | RB             | Æ                 | PE   | OE | TXEMP        | TxRDY | FFULL  | RxRDY        |    |
|           |                               | RESET:<br>0    | 0                 | 0    | 0  | 0            | 0     | 0      | 0            |    |
|           | Read Only Supe                |                |                   |      |    | ervisor/User |       |        |              |    |
| wł<br>/ / | nile( ! (<br>; /<br>/ ok to t | SRB (<br>/ spi | & TxI<br>n<br>mit | RDY) | )  |              |       |        |              |    |
| L5-EDA222 |                               |                |                   |      |    |              |       |        | 20           | 6  |

| CHALMERS   | Low level programming in Ada95 Roger Johansso                                    |             |     |    |    |                 |                   |                    | isson       |    |
|------------|----------------------------------------------------------------------------------|-------------|-----|----|----|-----------------|-------------------|--------------------|-------------|----|
|            |                                                                                  | SRA,        | SRB |    |    |                 |                   | \$711,             | \$719       |    |
| I EXAMPLE: |                                                                                  | 7           | 6   | 5  | 4  | 3               | 2                 | 1                  | 0           |    |
| Ado        |                                                                                  | RB          | Æ   | PE | OE | TXEMP           | TxRDY             | FFULL              | RxRDY       |    |
| Aua        |                                                                                  | RESET:<br>0 | 0   | 0  | 0  | 0               | 0                 | 0                  | 0           |    |
|            | Read Only                                                                        |             |     |    |    |                 | Supervisor/User   |                    |             |    |
|            | wait for device ready<br>while (SRB.TxRDY == 0 ) loop<br>NULL; spin<br>end loop; |             |     |    |    |                 |                   |                    |             |    |
|            |                                                                                  |             |     |    | As | suming<br>of IO | propei<br>registe | r declar<br>r "SRB | ration<br>" |    |
| L5-EDA222  |                                                                                  |             |     |    |    |                 |                   |                    |             | 27 |

|                       | TBA,        | твв                                                   |      |                 |       |     | \$713, | \$71B |
|-----------------------|-------------|-------------------------------------------------------|------|-----------------|-------|-----|--------|-------|
| Transmit              | 7           | 6                                                     | 5    | 4               | 3     | 2   | 1      | 0     |
| register              | TB7         | TB6                                                   | TB5  | TB4             | TB3   | TB2 | TB1    | TB0   |
| register              | RESET:<br>0 | 0                                                     | 0    | 0               | 0     | 0   | 0      | 0     |
|                       | Write       | Only                                                  |      | Supervisor/User |       |     |        |       |
| EXAMPLE:<br>C or Java | ,           | <pre>while( ! (SRB &amp; TxRDY) )     ; // spin</pre> |      |                 |       |     |        |       |
|                       |             | // ok                                                 | to t | rans            | nit . | ••  |        |       |
|                       |             | гвв =                                                 | c;   |                 |       |     |        |       |
|                       |             |                                                       |      |                 |       |     |        |       |



| CHALMERS Low level program                                                  | nming in Ada95                                                                                                                                                                                                  | Roger Johansson                                                          |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| Transmit/ Receive<br>registers shares<br>address                            | TBA, TBB<br>7 6 5 4<br>T37 TB6 TB5 TB4<br>RESET:<br>0 0 0 0<br>Write Only                                                                                                                                       | \$713, \$71B<br>3 2 1 0<br>TB3 TB2 TB1 TB0<br>0 0 0 0<br>Supervisor/User |
| cpu32 bus signal<br>"Read/Write" is used as a<br>discriminating address bit | RBA, RBB         7         6         5         4           1837         1886         1885         1884           RESET:         0         0         0           Read Only         Read Only         1         1 | \$713, \$71B<br>3 2 0<br>RB3 RB2 RB1 RB0<br>0 0 0 0<br>Supervisor/User   |
| L5-EDA222                                                                   |                                                                                                                                                                                                                 | 30                                                                       |





| <pre>procedure init_port_B is<br/>begin</pre>                                                                                                                                                                                                                 | <pre>ivector : constant := Ada_interrupts.Names.PORTEINT;<br/>cmd_reset_receiver : bits := bits(16#20#);<br/>cmd_reset_transmitter : bits := bits(16#20#);<br/>cmd_reset_errorstatus : bits := bits(16#20#);<br/>cmd_reset_break : bits := bits(16#24#);<br/>rec_ire_enable: bits := bits(16#24#);</pre>                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>D_CRB := cmd_reset_break;<br/>D_MR1B := MR1B_init;<br/>D_MR2B := MR2B_init;<br/>D_CSRB := CSRB_init;<br/>D_ILR := ILEVEL;<br/>D_IVR := VECTOR;<br/>D_IRR := rec_irq_enable;<br/>D_CRB := cmd_enable_receiver;<br/>D_CRB := cmd_enable_transmitter;</pre> | <pre>cmd_enable_receiver : bits := bits(168018);<br/>cmd_enable_transmitter : bits := bits(168018);<br/> 8 bits, no parity<br/>W828_init : constant bits := bits(168078);<br/> normal, 1 stop bit<br/>CS88_init : constant bits := bits(168888);<br/> 9600 baud, 1x and 1x<br/> 9600 baud, 1x and 1x<br/> 1hterrupt level 4, port A and portB !!<br/>VSCTOP : hirs := bits(vertor):<br/></pre> |
| end init_port_B;                                                                                                                                                                                                                                              | - Interrupt vector port A and port B !!                                                                                                                                                                                                                                                                                                                                                        |



| CHALM     | IERS                                                                                                                          | Low level programming in Ada95                                                                                                                                                                                                                                                                                                                                                                                                                | Roger Johansson |
|-----------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Sumr      | nary                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                               |                 |
| .         | Useful typ<br>– We hav<br>Bit manip<br>– Ada typ<br>it right.<br>Declaring<br>– Ada let<br>underst<br>Ada95 an<br>– A full bl | De declarations<br>ve seen register mappings and howto specify bit positions(location<br>ulations and conversions<br>be checking might seem frustrating, but following some simple rule<br>I Input/Output memory locations and volatile entities<br>'s you specify hardware register addresses in a way that is easy to<br>tand and at the same time indisputable.<br>Id the hardware – UART example<br>lown device driver has been sketched. | s)<br>s get     |
| L5-EDA222 |                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                               | 35              |