### Features

- Links an Embedded ARM7TDMI<sup>™</sup> Core to the Atmel AMBA<sup>™</sup> Bus
- Bus Master Granted State Machine
- Bus Interface State Machine
- Fully Scan Testable (up to 96% Fault Coverage)

## Description

Designed for the Atmel implementation of the AMBA Bus, the ARM7TDMI Bus Interface module enables an ARM7TDMI embedded core to become an AMBA bus master.

The bus interface is designed to link the embedded ARM7TDMI core signals to the AMBA Bus. It includes two state machines. The first state machine determines if the master is currently granted the bus, and the second, more complex, state machine is used to control the bus interface of the master.

This peripheral can only be used with an embedded ARM7TDMI core.

There are no user-programmable registers in this block.







# 32-bit Embedded Core Interface

ARM7TDMI<sup>™</sup> Bus Interface

Rev. 1283D-03/01





### Table 1. Bus Interface Pin Description

| Name                          | Direction | Source/Destination                 | Description                                                                                                                                                                                                                         |
|-------------------------------|-----------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               |           | AMBA                               | Bus Inputs                                                                                                                                                                                                                          |
| nreset_r                      | Input     | Reset Controller                   | System reset for flip-flop working on the rising edge of the System Clock (nreset_r synchronous to nclock). Active low.                                                                                                             |
| nreset_f                      | Input     | Reset Controller                   | System reset for flip-flop working on the rising edge of the inverted System Clock (nreset_f synchronous to clock). Active low.                                                                                                     |
| clock                         | Input     |                                    | System Clock                                                                                                                                                                                                                        |
| nclock                        | Input     |                                    | Inverted System Clock                                                                                                                                                                                                               |
| bwait_in                      | Input     | Slaves + decoder                   | Multiplexed BWAIT response from all the peripherals. Active high.                                                                                                                                                                   |
| berror_in                     | Input     | Slaves + decoder                   | Multiplexed BERROR response from all the peripherals. Active high.                                                                                                                                                                  |
| blast_in                      | Input     | Slaves + decoder                   | Multiplexed BLAST response from all the peripherals. Active high.                                                                                                                                                                   |
| agnt                          | Input     | Arbiter                            | Bus Grant: indicates that the bus master (ARM7TDMI) will be granted the bus when BWAIT is low.                                                                                                                                      |
|                               | 1         | AMBA                               | Bus Outputs                                                                                                                                                                                                                         |
| btran[1:0]                    | Output    | Current bus master/decoder, slaves | Transfer type: type of the next transaction (Address-only, Non-<br>sequential or Sequential). To be connected to the tri-state bus<br>BTRAN[1:0] of the ASB.                                                                        |
| bprot[1:0]                    | Output    | Current bus master                 | Protection control: indicates if the transfer is an opcode fetch or<br>data access, as well as if the transfer is a supervisor mode access<br>or a user mode access. To be connected to the tri-state bus<br>BPROT[1:0] of the ASB. |
| mabe                          | Output    |                                    | Master address bus enable: indicates when BA bus can be taken into account. Active high.                                                                                                                                            |
| ARM7TDMI AMBA Related Signals |           |                                    |                                                                                                                                                                                                                                     |
| nwait                         | Output    | ARM7TDMI                           | Not wait: used when accessing slow peripherals to make the processor wait. Active Low.                                                                                                                                              |
| abort                         | Output    | ARM7TDMI                           | Memory abort: tells the processor that a requested access is not allowed. Active High.                                                                                                                                              |
| nmreq                         | Input     | ARM7TDMI                           | Not memory request: memory access requested by the processor.<br>Active Low.                                                                                                                                                        |
| seq                           | Input     | ARM7TDMI                           | Sequential address: next address (memory access) will be related to the last memory access. Active High.                                                                                                                            |
| порс                          | Input     | ARM7TDMI                           | Not op-code fetch: indicates that the processor is fetching an instruction from the memory. Active Low.                                                                                                                             |
| ntrans                        | Input     | ARM7TDMI                           | Not memory translate: indicates that the processor is in user mode. Active Low.                                                                                                                                                     |

### Table 1. Bus Interface Pin Description (Continued)

| Name                   | Direction | Source/Destination | Description                                                                |
|------------------------|-----------|--------------------|----------------------------------------------------------------------------|
| Scan Test              |           |                    |                                                                            |
| scan_test_mode         | Input     |                    | Must be tied to 1 during scan test<br>Must be tied to 0 in functional mode |
| test_se                | Input     |                    | Test scan shift enabled when tied to 1                                     |
| test_si <sup>(1)</sup> | Input     |                    | Test scan input (input of the scan chain)                                  |
| test_so <sup>(1)</sup> | Output    |                    | Test scan output (output of the scan chain)                                |

Note: 1. The scan chain uses the clock BCLK.

Scan Test Configuration

The coverage is maximum if all non-scan inputs can be controlled and all non-scan outputs can be observed. In order to achieve this, the ATPG vectors must be generated on the entire circuit (top level) which includes the ARM7TDMI Bus Interface or all ARM7TDMI Bus Interface I/Os must have a top level access and ATPG vectors must be applied to these pins.





### Operating in an AMBA Bus System





Bus Interface

4

# Bus Interface

Figure 3. AMBA Data Buses



<sup>&</sup>lt;u>AIMEL</u>



### Figure 4. Master Control Signals



### Bus Master Interface Description

Granted State Machine The bus master interface consists of a state machine that is used to determine if the master is currently granted the bus, and to control the bus interface of the master.

The granted state machine is used to determine whether or not the bus master has been

granted the bus. It runs on the rising edge of the system clock and has only two states

GRANTED and NOT\_GRANTED. The state diagram is shown below.





The output from the state machine is the internal Granted signal, which is used in the main bus master state machine.

It is important to note that the agnt signal may be asserted for a number of clock cycles, but it is only when agnt is asserted and bwait is low that the bus master actually becomes GRANTED.

An important design consideration is that the state machine may be asynchronously reset into either state depending on the value of the agnt signal. During reset one bus master in the system is set as the default bus master, as indicated by agnt being asserted during reset, and will be reset in to the GRANTED state. All other bus masters will be reset into the NOT\_GRANTED state.

# Bus Interface StateThe main bus interface state machine is falling edge triggered and contains five states. The<br/>entire state diagram, as shown in Figure 7 can be considered in four quadrants.

Figure 6. State Diagram

| No Transfer Request | Transfer Request    |  |
|---------------------|---------------------|--|
| Not Granted         | Not Granted         |  |
| (IDLE)              | (HOLD)              |  |
| No Transfer Request | Transfer Request    |  |
| Granted             | Granted             |  |
| (BUSIDLE)           | (ACTIVE or RETRACT) |  |

The "Transfer Request, Granted" quadrant contains two states, which handle bus turnaround and the retract operation.

The two internal bus master signals Granted and Request control the majority of the transitions around the state diagram. Granted is generated from the simpler state machine described above and Request is generated directly by the bus master. Request is asserted





high when the bus master requires a transfer on the bus and is low when the bus master does not need access to the bus.

The only time when a transition around the state diagram is not controlled by Granted and Request is when the bus master is in the ACTIVE state. In this state the transition to the next state is determined by the transfer response that is received. Wait, Done, Last, Error and Retnext shown in the diagram correspond to the encoding of the transfer response signals.





Note that the state diagram assumes that once the bus master has made a request for a transfer, as indicated by Request, then Request remains asserted until the bus master has performed a transfer.

As the main bus master state machine operates from the falling edge of the clock, it is necessary to use latched versions of the transfer response signals bwait, berror and blast to control the exit from the ACTIVE state.

The reset conditions are not shown on the state diagram and, in a similar manner to the granted state machine, the main bus master state machine has a complex reset term.

During reset (when nreset is low), the bus master enters the IDLE state.

Table 2 indicates the actions that must occur in each state.

| Name    | Description                                                                                                                       | Actions                                                                                                                                             |
|---------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| IDLE    | The master does not require the bus and it is not granted.                                                                        | Internal btran is Address-only<br>Master clock is enabled<br>Master address bus is tri-stated                                                       |
| BUSIDLE | The master does not require the bus, but it has been granted anyway.                                                              | Internal btran as indicated by master<br>Master clock is enabled<br>Master address bus enable is generated from<br>Granted signal                   |
| HOLD    | The master requires the bus, but it has not been granted.                                                                         | Internal btran is Address-only<br>Master clock is disabled<br>Master address bus is tri-stated                                                      |
| ACTIVE  | Active state when data transfers<br>occur.<br>Exiting this state is dependent on<br>the transfer response.                        | Internal btran as indicated by master<br>Master clock enable is derived from BWAIT<br>Master address bus enable is generated from<br>Granted signal |
| RETRACT | Retract state, where the rest of<br>the elements in the system see<br>the transfer finish, but the bus<br>master is not advanced. | Internal btran is Address-only<br>Master clock is disabled<br>Master address bus enable is generated from<br>Granted signal                         |

Table 2. State Actions





### Timing Diagrams

The following diagrams show the timings for the parameters described in this datasheet. See Table 3 and Table 4 for definitions of the timing parameters. For complete timing diagrams, see the datasheet "System Architecture", Literature Number 1353.





In Figure 8, the output is generated to simplify the multiplexing of the control signals generated by the ARM7TDMI core. It indicates that the core is "really granted" on the bus (ASB) and that its control signals must be sent to the slaves.

Thus, mabe is asserted when the core is granted via agnt and there is no transfer being done by another master, i.e. bwait\_in is inactive. Mabe is de-asserted when the core has finished its last transfer, i.e., bwait\_in is inactive.



Figure 9. ASB Bus Master Non-sequential Transfer

For the non-sequential transfer shown in Figure 9, the address and control signals become valid in the system clock high phase before the start of the transfer. An important feature of the AMBA protocol is that it allows for poor output valid times on non-sequential transfers, which is provided through the automatic insertion of a wait state at the start of every non-sequential transfer by the decoder.









A sequential transfer has different timing parameters for the address and control signal valid times. In a typical bus master, the output valid times for sequential transfers are far better than for non-sequential transfers. The output hold times for address, control and data are identical and independent of the transfer type.

The other difference between the sequential and non-sequential transfers is that during a sequential transfer the data may be driven during the first phase of the transfer and hence the data valid parameter is specified from the falling edge of the system clock.

For an address-only transfer the address and control signals may be driven in the clock high phase before the start of the transfer, or in the case of bus master hand-over may only be driven during the clock low phase of the transfer itself. The address and control valid timing parameters are only relevant when the address-only transfer is followed immediately by a sequential transfer and in this case the address and control signals must be driven such that they are valid during the low phase of the address-only transfer, which in turn means they are valid throughout the clock high phase that precedes the Sequential transfer.



Figure 11. ASB Master Address-only Transfer

Figure 12. ASB Bus Master Arbitration and Reset Signals



The nreset\_r signal may be asserted asynchronously and so there is no setup and hold parameter relating to the assertion of the signal. The agnt signal, which is returned from the arbiter changes during the low clock phase.

### Timing Parameters

The timing parameters related to an ASB bus master operating in an AMBA system are also described in the following two tables. The first details the input signals, while the second details output signals.

### Table 3. Input Signal Timing Parameters

| Parameter           | Description                                            |
|---------------------|--------------------------------------------------------|
| t <sub>ISNRES</sub> | nreset de-asserted setup to rising system clock        |
| <sup>t</sup> IHNRES | nreset de-asserted hold after falling system clock     |
| <sup>t</sup> ISRESP | bwait, berror and blast setup to rising system clock   |
| <sup>t</sup> IHRESP | bwait, berror and blast hold after rising system clock |
| <sup>t</sup> ISAGNT | agnt setup to rising system clock                      |
| t <sub>IHAGNT</sub> | agnt hold after falling system clock                   |

### Table 4. Output Signal Timing Parameters

| Parameter           | Description                                                              |
|---------------------|--------------------------------------------------------------------------|
| <sup>t</sup> OVCTIN | for non-sequential transfers, bprot[1:0] valid after rising system clock |
| <sup>t</sup> OVCTLA | for address-only transfers, bprot[1:0] valid after falling system clock  |
| <sup>t</sup> OHCTL  | bprot[1:0] hold after rising system clock                                |
| <sup>t</sup> OVMABE | mabe valid after rising clock                                            |
| <sup>t</sup> SBTRAN | btran valid before falling clock                                         |





### **Atmel Headquarters**

Corporate Headquarters 2325 Orchard Parkway San Jose, CA 95131 TEL (408) 441-0311 FAX (408) 487-2600

#### Europe

Atmel SarL Route des Arsenaux 41 Casa Postale 80 CH-1705 Fribourg Switzerland TEL (41) 26-426-5555 FAX (41) 26-426-5500

#### Asia

Atmel Asia, Ltd. Room 1219 Chinachem Golden Plaza 77 Mody Road Tsimhatsui East Kowloon Hong Kong TEL (852) 2721-9778 FAX (852) 2722-1369

### Japan

Átmel Japan K.K. 9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033 Japan TEL (81) 3-3523-3551 FAX (81) 3-3523-7581

### **Atmel Operations**

Atmel Colorado Springs 1150 E. Cheyenne Mtn. Blvd. Colorado Springs, CO 80906 TEL (719) 576-3300 FAX (719) 540-1759

Atmel Rousset Zone Industrielle 13106 Rousset Cedex France TEL (33) 4-4253-6000 FAX (33) 4-4253-6001

Atmel Smart Card ICs Scottish Enterprise Technology Park East Kilbride, Scotland G75 0QR TEL (44) 1355-357-000 FAX (44) 1355-242-743

#### Atmel Grenoble Avenue de Rochepleine BP 123 38521 Saint-Egreve Cedex France TEL (33) 4-7658-3000 FAX (33) 4-7658-3480

*Fax-on-Demand* North America: 1-(800) 292-8635 International: 1-(408) 441-0732 *e-mail* literature@atmel.com

Web Site http://www.atmel.com

BBS 1-(408) 436-4309

#### © Atmel Corporation 2001.

Atmel Corporation makes no warranty for the use of its products, other than those expressly contained in the Company's standard warranty which is detailed in Atmel's Terms and Conditions located on the Company's web site. The Company assumes no responsibility for any errors which may appear in this document, reserves the right to change devices or specifications detailed herein at any time without notice, and does not make any commitment to update the information contained herein. No licenses to patents or other intellectual property of Atmel are granted by the Company in connection with the sale of Atmel products, expressly or by implication. Atmel's products are not authorized for use as critical components in life support devices or systems.

ARM7TDMI and AMBA are trademarks of ARM Ltd.

Terms and product names in this document may be trademarks of others.

