# ADC Interface FPGA IP

Revision: 1.0

Date: 21/07/2020

# QuickLogic Corporation

## 1 Requirement:

- 1. Interface with Analog devices chip AD7476A (12-bit ADC)
- 2. Fast throughput rate: 1 MSPS

## 2 System Block Diagram:



## 3 Pinout:

| SI.<br>No. | Signal Name | PAD Number | Direction | Description              |
|------------|-------------|------------|-----------|--------------------------|
| ADC Inte   | erface      |            |           |                          |
| 1          | CSn_o       | PAD[4]     | Output    | Slave Select, Active Low |
| 2          | SCLK_o      | PAD[5]     | Output    | SPI Clock                |
| 3          | SDATA_i     | PAD[12]    | Input     | MISO                     |
| UART       |             | •          |           |                          |
| 4          | UART_TX     | PAD[44]    | Output    |                          |
| 5          | UART_RX     | PAD[45]    | Input     |                          |

## **4 FPGA Interrupts:**

| Sl. No. | FPGA Interrupts to M4 | Interrupt Description |
|---------|-----------------------|-----------------------|
| 1       | FB_INTERRUPT_0        | DMA Done INTR         |
| 2       | FB_INTERRUPT_1        | Reserved              |
| 3       | FB_INTERRUPT_2        | UART INTR             |
| 4       | FB_INTERRUPT_3        | Reserved              |

## 5 Address Map Specification

## 5.1 Memory Map

The EOS 3B system maps the FPGA IP into the address range of 0x40020000 to 0x4003FFFF. This address range provides 128K bytes of address range for FPGA based IP. The following tables further define the registers within this range.

Table 1-1: FPGA IP Register Space

| Register                   | Block                        | Space Allocated | Remarks                               |
|----------------------------|------------------------------|-----------------|---------------------------------------|
| 0x40020000 -<br>0x400200FF | FPGA IP Registers            | 256 bytes       |                                       |
| 0x40020100 -<br>0x400201FF | GPIO Controller              | 256 bytes       |                                       |
| 0x400201FF -<br>0x40020FFF | Reserved                     | 0x0             |                                       |
| 0x40021000 -<br>0x400217FF | UART                         | 512 Words       |                                       |
| 0x40021800 -<br>0x4002FFFF | Reserved                     | 0x0             |                                       |
| 0x40030000 -<br>0x40030FFF | DMA control/Status registers | 1024 Words      | Dedicated DMA registers               |
| 0x40031000 -<br>0x40031FFF | DMA CH0 Port register        | 1024 Words      | Dedicated 4KB space for DMA Channel 0 |
| 0x40032000 -<br>0x4003FFFF | Reserved                     | 0x0             |                                       |

## 5.2 Register Address Table

The following sections will outline the expected allocation of registers and describe their operations.

#### **5.2.1** FPGA Registers Address Table

Table 1-2 shows the expected allocation of FPGA Registers address space.

Table 1-2: FPGA IP Register Table

| Register                   | Block                  | Reset Value | Remarks                   |
|----------------------------|------------------------|-------------|---------------------------|
| 0x40020000                 | IP Device ID           | 0xADC1F     | Read only                 |
| 0x40020004                 | IP Revision number     | 0x0100      | Read only<br>Version 1.00 |
| 0x40020008                 | FIFO Flush             | 0x00        |                           |
| 0x4002000C                 | Sensor Enable Register | 0x0         | Read/Write                |
| 0x40020010 -<br>0x400200FF | Not Used               | 0x0         |                           |

#### **5.2.2 GPIO Controller Address Table**

Table 1-2 shows the expected allocation of GPIO Controller address space.

**Table 1-3: GPIO Controller Register Table** 

| Register                   | Block    | Reset Value | Remarks    |
|----------------------------|----------|-------------|------------|
| 0x40020100                 | GPIO In  | 0x0         | Read/Write |
| 0x40020104                 | GPIO Out | 0x0         | Read/Write |
| 0x40020108                 | GPIO OE  | 0x0         | Read/Write |
| 0x4002010C -<br>0x400201FF | Not Used | 0x0         |            |

#### **5.2.3 UART Address Table**

Table 1-3 shows the expected allocation of UART Register address space. This selection reflects the goal of backward compatibility with the UART 16550 commonly used for serial communications.

Table 1-3: UART Register Table

| Register   | Register Name            | Reset Value | Description                                                            |
|------------|--------------------------|-------------|------------------------------------------------------------------------|
| 0x40021000 | Receiver Buffer Register |             | Receive Data (Read Only)  Note: Divisor Latch Access  Bit (DLAB) = "0" |

| Register                   | Register Name                        | Reset Value             | Description                                                                        |
|----------------------------|--------------------------------------|-------------------------|------------------------------------------------------------------------------------|
| 0x40021000                 | Transmit Buffer Register             | mit Buffer Register     |                                                                                    |
| 0x40021000                 | Divisor Latch (LSB)                  | Divisor Latch (LSB)     |                                                                                    |
| 0x40021004                 | Interrupt Enable Register            | terrupt Enable Register |                                                                                    |
| 0x40021004                 | Divisor Latch (MSB)                  |                         | Reference Clock divisor's<br>MSB<br>Note: Divisor Latch Access<br>Bit (DLAB) = "1" |
| 0x40021008                 | Interrupt Identification<br>Register |                         | (Read Only)                                                                        |
| 0x40021008                 | FIFO Control Register                |                         | (Write Only)                                                                       |
| 0x4002100C                 | Line Control Register                |                         |                                                                                    |
| 0x40021010                 | Modem Control Register               |                         |                                                                                    |
| 0x40021014                 | Line Status Register                 |                         |                                                                                    |
| 0x40021018                 | Modem Status Register                |                         |                                                                                    |
| 0x4002101C                 | Scratch Register                     | 0×00                    |                                                                                    |
| 0x40021020 -<br>0x400217FF | Reserved                             | 0x00                    |                                                                                    |

## **5.2.4 DMA Controller Address Table**

Table 1-2 shows the expected allocation of DMA Controller address space.

Table 1-5: DMA Controller Register Table

| Register                   | Block                            | Reset Value | Remarks    |
|----------------------------|----------------------------------|-------------|------------|
| 0x40030000                 | DMA Enable Register              | 0x0         | Read/Write |
| 0x40030004                 | DMA Status Register              | 0x0         | Read only  |
| 0x40030008                 | DMA Interrupt Enable<br>Register | 0x0         | Read/Write |
| 0x4003000C -<br>0x40030FFF | Not Used                         | 0x0         |            |
| 0x40031000                 | DMA Read Port register           | 0x0         | Read only  |
| 0x40031004 -<br>0x40031FFF | Not Used                         | 0x0         |            |
| 0x40032000 -<br>0x4003FFFF | Reserved                         | 0x0         |            |

## 5.3 Description of Registers

The following sections will detail the registers for each address space.

#### 5.3.1 Conventions

| Access Tag | Name      | Meaning                               |  |
|------------|-----------|---------------------------------------|--|
| R          | Read      | field may be read by the user/sw      |  |
| W          | Write     | field may be written by the user/sw   |  |
| U          | Update    | field may be updated by hardware      |  |
| S          | Set       | field may be set by the user          |  |
| С          | Clear     | field may be cleared by the user      |  |
| RO         | Read Only | field can only be read by the user/sw |  |

## **5.3.2 FPGA IP Registers**

#### 5.3.2.1 IP Device ID register

Register Address location: 0x40020000

Reset Value: 0xADC1F

Table 3-2.1: ID Value Register

| Name         | Bit(s)  | Туре | Description          |
|--------------|---------|------|----------------------|
| IP Device ID | [19:0]  | RO   | 0xADC1F : Read only  |
| Not Used     | [31:20] | RO   | Return "0" when read |

## 5.3.2.2 IP revision number register

Register Address location: 0x40020004

**Table 3-2.2: Revision Number Register** 

| Name            | Bit(s)  | Туре | Description          |
|-----------------|---------|------|----------------------|
| Revision Number | [15: 0] | RW   | 0x0100 : Read only   |
| Not Used        | [31:16] | RO   | Return "0" when read |

#### 5.3.2.3 FIFO Reset Register

Register Address location: 0x40020008

Reset Value: 0x0

Table 3-2.3: FIFO Reset Register

| Name       | Bit(s) | Туре | Description                    |
|------------|--------|------|--------------------------------|
| FIFO Reset | [0]    | RW   | RX FIFO Flush<br>HW auto clear |
| Not Used   | [31:1] | RO   | Return "0" when read           |

#### 5.3.2.4 Sensor Enable Register

Register Address location: 0x4002000C

Reset Value: 0x0

**Table 3-2.4: Sensor Enable Register** 

| Name            | Bit(s) | Туре | Description                                     |
|-----------------|--------|------|-------------------------------------------------|
|                 | [0]    |      | 0 – Sensor Disabled                             |
| Sensor 1 Enable |        | R/W  | 1 – Sensor Enabled                              |
|                 |        |      | When enabled the IP starts reading from the ADC |
| Reserved        | [31:4] | R    | Return "0" when read                            |

#### 5.3.3 GPIO Controller Registers

#### 5.3.3.1 GPIO Input Register

The following registers allow the fabric IP to sample an external pin. **Error! Reference source not found.** shows the current assignments for each register bit. However, each of these pins can be assigned to any fabric I/O pad.

Register Address location: 0x40020100

Table 3-3.1: GPIO Input Register

| Name    | Bit(s) | Туре | Description         |
|---------|--------|------|---------------------|
| GPIO[0] | [0]    | R    | Assigned to PAD[18] |
| GPIO[1] | [1]    | R    | Assigned to PAD[21] |
| GPIO[2] | [2]    | R    | Assigned to PAD[22] |
| GPIO[3] | [3]    | R    | Assigned to PAD[26] |

#### 5.3.3.2 GPIO Output Register

The following registers allow the fabric IP to drive an external pin. A write will set the value used to drive the external. A read will read the value of the register and not the external pin.

Table shows the current allocation for each of register bit. However, each of these pins can be assigned to any fabric I/O pad.

Register Address location: 0x40020104

**Table 3-3.2: GPIO Output Register** 

| Name    | Bit(s) | Туре | Description         |
|---------|--------|------|---------------------|
| GPIO[0] | [0]    | R/W  | Assigned to PAD[18] |
| GPIO[1] | [1]    | R/W  | Assigned to PAD[21] |
| GPIO[2] | [2]    | R/W  | Assigned to PAD[22] |
| GPIO[3] | [3]    | R/W  | Assigned to PAD[26] |

#### 5.3.3.3 GPIO Output Enable Register

The following registers allow the fabric IP to drive an external pin. A write to each bit will set the value used to either drive the external pin or tri-state the pin.

**Error! Reference source not found.** shows the current allocation for each register bit. Each of these pins can be assigned to any fabric I/O pad.

Register Address location: 0x40020108

Reset Value: 0x00

**Table 3-3.3: GPIO Output Enable Register** 

| Name        | Bit(s) | Туре  | Description                              |
|-------------|--------|-------|------------------------------------------|
| GPIO_OE[0]  | [0]    | R/W   | Assigned to PAD[18] 0 – Tri-State Output |
| GFIO_OE[0]  | ĮΟJ    | IN/VV | 1 – Drive Output                         |
| 0010 05 141 | F41    | R/W   | Assigned to PAD[21] 0 – Tri-State Output |
| GPIO_OE [1] | [1]    |       | 1 – Drive Output                         |
|             |        | R/W   | Assigned to PAD[22]                      |
| GPIO_OE [2] | [2]    |       | 0 – Tri-State Output<br>1 – Drive Output |
|             |        | R/W   | Assigned to PAD[26]                      |
| GPIO_OE [3] | [3]    | 1,7,7 | 0 – Tri-State Output                     |
|             |        |       | 1 – Drive Output                         |

#### **5.3.4 UART Registers**

#### 5.3.4.1 Receive Buffer Register / Transmitter Holding Register

Data received by the UART's Rx logic may be read from this location. Data for transmission by the UART's Tx logic should be written to this location.

Note: These registers are only available if the "Divisor Latch Access Bit" (DLAB) of the Line Control Register (Ref. 0x4002100C) is set to "0".

Register Address location: 0x40021000

Reset Value: 0x00

Table 3-4.1: Receive Buffer/Transmission Holding Register

| Name                | Bit(s) | Туре | Description                            |
|---------------------|--------|------|----------------------------------------|
| Receive Buffer      | [7:0]  | R    | Receive Data from the Rx logic         |
| Transmitter Holding | [7:0]  | W    | Data for transmission by the Tx logic. |
| Reserved            | [31:8] | R    | Returns "0"                            |

### 5.3.4.2 Divisor Latch (LSB) Register

The Divisor Latch (LSB) register holds the lower byte of the reference clock divisor.

Note: These registers are only available if the "Divisor Latch Access Bit" (DLAB) of the Line Control Register (Ref. 0x4002100C) is set to "1".

Register Address location: 0x40021000

Table 3-4.2: Divisor Latch (LSB) Register

| Name                | Bit(s) | Туре | Description                       |
|---------------------|--------|------|-----------------------------------|
| Divisor Latch (LSB) | [7:0]  | R/W  | Reference Clock divisor LSB byte. |
| Reserved            | [31:8] | R    | Returns "0"                       |

#### 5.3.4.3 Interrupt Enable Register

This register enables/disables various interrupt conditions.

Note: These registers are only available if the "Divisor Latch Access Bit" (DLAB) of the Line Control

Register (Ref. 0x4002100C) is set to "0".

Register Address location: 0x40021004

Reset Value: 0x00

**Table 3-4.3: Interrupt Enable Register** 

| Name                 | Bit(s) | Туре | Description                                         |
|----------------------|--------|------|-----------------------------------------------------|
| Received Data        | [0]    | R/W  | Enable Received Data Available Interrupt            |
| Transmit Data        | [1]    | R/W  | Enable Transmitter Holding Register Empty Interrupt |
| Receiver Line Status | [2]    | R/W  | Enable Receiver Line Status Interrupt               |
| Modem Status         | [3]    | R/W  | Enable Modem Status Interrupt                       |
| Reserved             | [31:4] | R    | Returns "0"                                         |

#### 5.3.4.4 Divisor Latch (MSB) Register

The Divisor Latch (MSB) register holds the lower byte of the reference clock divisor.

Note: These registers are only available if the "Divisor Latch Access Bit" (DLAB) of the Line Control Register (Ref. 0x4002100C) is set to "1".

Register Address location: 0x40021004

Table 3-4.4: Divisor Latch (MSB) Register

| Name                | Bit(s) | Туре | Description                       |
|---------------------|--------|------|-----------------------------------|
| Divisor Latch (MSB) | [7:0]  | R/W  | Reference Clock divisor MSB byte. |
| Reserved            | [31:8] | R    | Returns "0"                       |

#### 5.3.4.5 Interrupt Identification Register

The Interrupt Identification register returns the status of various interrupt sources. More specifically, this register provides the user with four interrupt status bits. Performing a read cycle on the Interrupt Identification register will provide the user with the highest pending interrupt level to be serviced. No other interrupts are acknowledged until the pending interrupt is serviced. Whenever the interrupt status register is read, the interrupt status is cleared. However, it should be noted that only the currently pending interrupt is cleared by the read. A lower level interrupt may be seen after re-reading the interrupt status bits. Table shows the data values (bits [3:0] of the Interrupt Identification Register) for the four prioritized interrupt levels and the interrupt sources associated with each of these interrupt levels.

**Table 3-4.5: Interrupt Sources** 

| Priority | Bit [3] | Bit [2] | Bit [1] | Bit [0] | Source of Interrupt                |
|----------|---------|---------|---------|---------|------------------------------------|
| -        | 0       | 0       | 0       | 1       | None                               |
| 1        | 0       | 1       | 1       | 0       | Receiver Line Status Register      |
| 2        | 0       | 1       | 0       | 0       | Received Data Ready                |
| 2        | 1       | 1       | 0       | 0       | Received Data Time-Out             |
| 3        | 0       | 0       | 1       | 0       | Transmitter Holding Register Empty |
| 4        | 0       | 0       | 0       | 0       | Modem Status Register              |

Register Address location: 0x40021008

**Table 3-4.5a: Interrupt Identification Register** 

| Name                     | Bit(s) | Туре | Description                                             |
|--------------------------|--------|------|---------------------------------------------------------|
| Interrupt Pending        | [0]    | R    | "0" when an interrupt is pending (i.e. Bit[0] in Table) |
| Interrupt ID             | [3:1]  | R    | Selects interrupt sources (i.e. Bit [3:1] in Table )    |
| Reserved                 | [4]    | R    | Returns "0"                                             |
| 512 Byte FIFO<br>Enabled | [5]    | R    | Enable Modem Status Interrupt                           |
| FIFOs Enabled            | [7:6]  | R    |                                                         |
| Reserved                 | [31:8] | R    | Returns "0"                                             |

## 5.3.4.6 FIFO Control Register

The FIFO Control register enables the FIFO operation of the UART.

Register Address location: 0x40021008

Reset Value: 0x00

**Table 3-4.6: Interrupt Identification Register** 

| Name                | Bit(s) | Туре | Description                                                                                      |
|---------------------|--------|------|--------------------------------------------------------------------------------------------------|
| FIFO Enable         | [0]    | W    | Enables FIFO operations<br>0 – FIFOs Disabled<br>1 – FIFOs Enabled                               |
| Receive FIFO Reset  | [1]    | W    | Selects interrupt sources                                                                        |
| Transmit FIFO Reset | [2]    | W    | Returns "0"                                                                                      |
| DMA Mode Select     | [3]    | W    | Enable the use of the Tx Ready and Rx Ready signals in conjunction with the each FIFO operation. |
| Reserved            | [4]    | W    |                                                                                                  |
| 512 FIFO Enabled    | [5]    | W    | Enables extended FIFO operation<br>0 – 16-Byte Mode<br>1 – 512 Byte Mode                         |
| Receive Trigger     | [7:6]  | W    | Selects the FIFO level for trigging an interrupt Refer to Table.                                 |
| Reserved            | [31:8] | R    | Returns "0"                                                                                      |

Table 3-4.6a: RX FIFO Trigger Level Selection

| ECD[7] | I CDICI | RX FIFO Trigger Levels (Bytes) |                    |  |  |  |
|--------|---------|--------------------------------|--------------------|--|--|--|
| FCR[7] | LCR[6]  | 16-Byte Operation              | 512-Byte Operation |  |  |  |
| 0      | 0       | 1                              | 1                  |  |  |  |
| 0      | 1       | 4                              | 128                |  |  |  |
| 1      | 0       | 8                              | 256                |  |  |  |
| 1      | 1       | 14                             | 496                |  |  |  |

#### 5.3.4.7 Line Control Register

Register Address location: 0x4002100C

**Table3-4.7: Line Control Register** 

| Name               | Bit(s) | Туре | Description |
|--------------------|--------|------|-------------|
| Word Length Select | [1:0]  | R/W  | Word Length |

|                             |        |       | These two bits specify the word length to be transmitted or received. (Refer to Table )                                                                                                                        |
|-----------------------------|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |        |       | Stop Bit(s)                                                                                                                                                                                                    |
| Number of Stop Bits         | [2]    | R/W   | The length of Stop bits is specified by this bit in conjunction with the word length. (Refer to Table)                                                                                                         |
|                             |        |       | Parity Enable                                                                                                                                                                                                  |
| Parity Enable               | [3]    | R/W   | 0 – No Parity                                                                                                                                                                                                  |
| r anty Litable              | اوا    | TX/VV | <ul> <li>1 – A parity bit is generated during the transmission,<br/>receiver checks the data and parity for transmission<br/>errors.</li> </ul>                                                                |
|                             |        |       | Even parity.                                                                                                                                                                                                   |
|                             |        |       | If the parity bit is enabled with LCR[3] set to a logic 1, LCR[4] selects the even or odd parity format. (Refer to Table)                                                                                      |
| Even Parity Select          | [4]    | R/W   | <ul> <li>0 – Odd parity is generated by forcing an odd number<br/>of logic 1s in the transmitted data. The receiver<br/>must be programmed to check the same format<br/>(normal default condition).</li> </ul> |
|                             |        |       | 1 – Even parity is generated by forcing an even number                                                                                                                                                         |
|                             |        |       | of logic 1s in the transmitted data. The receiver must be programmed to check the same format.                                                                                                                 |
|                             | [5]    |       | Set parity.                                                                                                                                                                                                    |
|                             |        |       | If the parity bit is enabled, LCR[5] selects the forced parity format. (Refer to Table)                                                                                                                        |
|                             |        |       | Programs the parity conditions as follows:                                                                                                                                                                     |
| Stick Parity                |        | R/W   | 0 – parity is not forced (normal default condition)                                                                                                                                                            |
|                             |        |       | LCR[5] – logic 1 and LCR[4] = logic 0: parity bit is forced to a logic 1 for the transmit and receive data                                                                                                     |
|                             |        |       | LCR[5] – logic 1 and LCR[4] = logic 1: parity bit is forced to a logic 0 for the transmit and receive data                                                                                                     |
|                             |        |       | Set Break.                                                                                                                                                                                                     |
| Break Control               | [6]    | R/W   | When enabled, the Break control bit causes a break condition to be transmitted (the TX output is forced to a logic 0 state). This condition exists until disabled by setting LCR[6] to a logic 0.              |
|                             |        |       | 0 - no TX break condition (normal default condition)                                                                                                                                                           |
|                             |        |       | 1 – forces the transmitter output (TX) to a logic 0 for alerting the remote receiver to a line break condition                                                                                                 |
|                             |        |       | Divisor latch enable.                                                                                                                                                                                          |
| Divisor Latch Access<br>Bit | [7]    | R/W   | The internal baud rate counter latch and Enhanced Feature mode enable.                                                                                                                                         |
|                             |        |       | O – Divisor latch disabled (normal default condition)     1 – Divisor latch and enhanced feature register enabled                                                                                              |
| Reserved                    | [31:8] | R     | Returns "0"                                                                                                                                                                                                    |

**Table 3-4.7a: Parity Selection** 

| LCR[5] | LCR[4] | LCR[3] | Parity Selection |
|--------|--------|--------|------------------|
| Х      | Х      | 0      | No Parity        |
| 0      | 0      | 1      | Odd Parity       |
| 0      | 1      | 1      | Even Parity      |
| 1      | 0      | 1      | Force Parity "1" |
| 1      | 1      | 1      | Force Parity "0" |

Table 3-4.7b: Stop Bit Length

| LCR[2] | Word Length (Bits) | Stop Bit Length (Bit Times) |
|--------|--------------------|-----------------------------|
| 0      | 5, 6, 7, 8         | 1                           |
| 1      | 5                  | 1 ½                         |
| 1      | 6, 7, 8            | 2                           |

Table 3-4.7c: Word Length

| LCR[1] | LCR[0] | Word Length (Bits) |
|--------|--------|--------------------|
| 0      | 0      | 5                  |
| 0      | 1      | 6                  |
| 1      | 0      | 7                  |
| 1      | 1      | 8                  |

## 5.3.4.8 Modem Control Register

Register Address location: 0x40021010

**Table 3-4.8: Modem Control Register** 

| Name                | Bit(s) | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Terminal Ready | [0]    | R/W  | DTRn 0 – Force DTR output to a logic 1 (normal default condition) 1 – Force DTR output to a logic 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Request To Send     | [1]    | R/W  | RTSn 0 – Force RTS output to a logic 1 (normal default condition) 1 – Force RTS output to a logic 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Out[1]              | [2]    | R/W  | OUTn [1].  This bit is used in the Loopback mode only. In the Loopback mode, this bit is used to write the state of the modem RIn interface signal via OUTn [1].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Out[2]              | [3]    | R/W  | OUTn[2], INT enable.  Used to control the modem DCD signal in the Loopback mode.  0 – Set OUTn[2] to HIGH. In the Loopback mode, sets OUTn[2] (DCDn) internally to a logic 1.  1 – Set OUTn[2] to LOW. In the Loopback mode, sets OUTn[2] (DCDn) internally to a logic 0.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Loop                | [4]    | R/W  | Loopback.  Enable the local Loopback mode (diagnostics). In this mode the transmitter output (ROUT) and the receiver input (RIN), CTSn, DSRn, DCDn, and RIn are disconnected from the UART's I/O pins. Internally the modem data and control pins are connected into a loopback data configuration. In this mode, the receiver and transmitter interrupts remain fully operational. The Modem Control Interrupts are also operational, but the interrupts' sources are switched to the lower four bits of the Modem Control. Interrupts continue to be controlled by the IER register.  0 – Disable Loopback mode (normal default condition)  1 – Enable local Loopback mode (diagnostics) |
| Flow Control Enable | [5]    | R/W  | AFE.  This bit is the auto flow control enable. When this bit is set, the auto flow control is enabled. Refer to Table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Reserved            | [31:6] | R    | Returns "0"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

**Table 3-4.8a: Flow Control Configuration** 

| MCR[5] (AFE) | MCR[1] (RTSn) | Flow Configuration          |
|--------------|---------------|-----------------------------|
| 1            | 1             | auto RTSn and CTSn enabled  |
| 1            | 0             | auto CTSn only enabled      |
| 0            | X             | auto RTSn and CTSn disabled |

## 5.3.4.9 Line Status Register

Register Address location: 0x40021014

Table 3-4.9: Line Status Register

| Name             | Bit(s) | Туре    | Description                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |        |         | Receive data ready.                                                                                                                                                                                                                                                                                                                                                              |
| Data Ready       | [0]    | R/W     | <ul> <li>0 – no data in receive holding register or FIFO (normal default condition)</li> </ul>                                                                                                                                                                                                                                                                                   |
|                  |        |         | 1 – data has been received and is saved in the receive holding register or FIFO                                                                                                                                                                                                                                                                                                  |
|                  |        |         | Overrun error.                                                                                                                                                                                                                                                                                                                                                                   |
|                  |        |         | 0 - No overrun error (normal default condition)                                                                                                                                                                                                                                                                                                                                  |
|                  |        |         | 1 – Overrun error.                                                                                                                                                                                                                                                                                                                                                               |
| Overrun Error [1 | [1]    | R/W     | A data overrun error occurred in the receive shift register. This happens when additional data arrives while the FIFO is full. In this case, the previous data in the shift register is overwritten. Note that under this condition, the data byte in the receive shift register is not transferred into the FIFO, therefore the data in the FIFO is not corrupted by the error. |
|                  |        | R/W     | Parity error.                                                                                                                                                                                                                                                                                                                                                                    |
|                  |        |         | 0 – No parity error (normal default condition)                                                                                                                                                                                                                                                                                                                                   |
| Parity Error     | [2]    |         | 1 – Parity error.                                                                                                                                                                                                                                                                                                                                                                |
| [E]              |        |         | The receive character does not have correct parity information and is suspect. In the FIFO mode, this error is associated with the character at the top of the FIFO.                                                                                                                                                                                                             |
|                  |        |         | Framing error.                                                                                                                                                                                                                                                                                                                                                                   |
|                  |        |         | 0 - No framing error (normal default condition)                                                                                                                                                                                                                                                                                                                                  |
| Framing Error    | [3]    | R/W     | 1 – Framing error.                                                                                                                                                                                                                                                                                                                                                               |
| Ū                |        |         | The receive character did not have a valid stop bit(s). In the FIFO mode, this error is associated with the character at the top of the FIFO.                                                                                                                                                                                                                                    |
| Break Interrupt  | [4]    | R/W     | Break interrupt.                                                                                                                                                                                                                                                                                                                                                                 |
| ыеак іпістирі    | [4]    | 17/ 7 7 | logic 0 – No break condition (normal default condition)                                                                                                                                                                                                                                                                                                                          |

|                                 |        |     | logic 1 – Break Condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                 |        |     | The receiver received a break signal (RX was a logic 0 for one character frame time). In the FIFO mode, only one break character is loaded into the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Transmitter Holding<br>Register | [5]    | R/W | THR empty.  This bit is the Transmit Holding Register Empty indicator. This bit indicates that the UART is ready to accept a new character for transmission. In addition, this bit causes the UART to issue an interrupt to CPU when the THR interrupt enable is set. The THR bit is set to a logic 1 when a character is transferred from the transmit holding register into the transmitter shift register. The bit is reset to a logic 0 concurrently with the loading of the transmitter holding register by the CPU. In the FIFO mode, this bit is set when the transmit FIFO is empty; it is cleared when at least 1 byte is written to the transmit FIFO. |
| Transmitter Empty               | [6]    | R/W | THR and TSR empty. This bit is the Transmit Empty indicator. This bit is set to a logic 1 whenever the transmit holding register and the transmit shift register are both empty. It is reset to logic 0 whenever either the THR or TSR contains a data character. In the FIFO mode, this bit is set to logic 1 whenever the transmit FIFO and transmit shift register are both empty.                                                                                                                                                                                                                                                                            |
| Error in Receiver FIFO.         | [7]    | R/W | FIFO data error.  0 – No error (normal default condition)  1 – FIFO Data Error  At least one parity error, framing error or break indication is in the current FIFO data. This bit is cleared when LSR register is read.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Reserved                        | [31:8] | R   | Returns "0"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

## 5.3.4.10 Modem Status Register

Register Address location: 0x40021018

Table 3-4.10: Modem Status Register

| Name                    | Bit(s) | Туре | Description                                                                                                                                                                                     |
|-------------------------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Delta Clear To Send     | [0]    | R/W  | ΔCTSn  logic 0 – no CTSn change (normal default condition)  logic 1 – the CTSn input to the UART has changed state since the last time it was read. A modem Status Interrupt will be generated. |
| Delta Data Set<br>Ready | [1]    | R/W  | ΔDSRn logic 0 – no DSRn change (normal default condition) logic 1 – the DSRn input to the UART has changed state                                                                                |

|                                 |        |     | since the last time it was read. A modem Status Interrupt will be generated.                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Trailing Edge Ring<br>Indicator | [2]    | R/W | ΔRIn 0 – No RIn change (normal default condition) 1 – The RIn input to the UART has changed from a logic 0 to a logic 1. A modem Status Interrupt will be generated.                                                                                                                                                                                                                                                                                                                           |
| Delta Data Carrier<br>Detect    | [3]    | R/W | ΔDCDn  0 – No DCDn change (normal default condition)  1 – The DCDn input to the UART has changed state since the last time it was read. A modem Status Interrupt will be generated.                                                                                                                                                                                                                                                                                                            |
| Clear To Send                   | [4]    | R/W | Clear To Send. CTS.  CTSn functions as hardware flow control signal input if it is enabled via MCR[5]. Flow control (when enabled) allows starting and stopping the transmissions based on the external modem CTSn signal. A logic 1 at the CTSn pin will stop UART transmissions as soon as the current character has finished transmission. Normally, MSR[4] is the complement of the CTSn input. However, in the Loopback mode, this bit is equivalent to the RTSn bit in the MCR register. |
| Data Set Ready                  | [5]    | R/W | Data Set Ready. DSR (active HIGH, logic 1).  Normally, this bit is the complement of the DSRn input. In Loopback mode this bit is equivalent to the DTR bit in the MCR register.                                                                                                                                                                                                                                                                                                               |
| Ring Indicator                  | [6]    | R/W | Ring Indicator. RI (active HIGH, logic 1).  Normally, this bit is the complement of the RIn input. In the Loopback mode, this bit is equivalent to the OUT [1] bit in the MCR register.                                                                                                                                                                                                                                                                                                        |
| Data Carrier Detect             | [7]    | R/W | Data Carrier Detect. DCD (active HIGH, logic 1).  Normally this bit is the complement of the DCDn input. In the Loopback mode this bit is equivalent to the OUT [2] bit in the MCR register.                                                                                                                                                                                                                                                                                                   |
| Reserved                        | [31:8] | R   | Returns "0"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

## **5.3.5 DMA Registers**

#### 5.3.5.1 DMA Enable Register

Register Address location: 0x40030000

Reset Value: 0x00

Table 3-5.1: DMA Enable Register

| Name           | Bit(s) | Туре | Description                                                                                                                        |
|----------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------|
| DMA CH0 Enable | [0]    | R/W  | DMA Enable For channel 0 0 - Disable 1 – Enable HW clears this bit when the DMA transfer is done. DMA for reading the Sensor data. |
| Reserved       | [31:1] | R    | Returns "0"                                                                                                                        |

## 5.3.5.2 DMA Status Register

Register Address location: 0x40030004

Reset Value: 0x00

Table 3-5.2: DMA Status Register

| Name               | Bit(s) | Туре | Description                                                                |
|--------------------|--------|------|----------------------------------------------------------------------------|
| DMA Done Interrupt | [0]    | R/W  | DMA Read Done Interrupt FW needs to clear the interrupt, write 0 to clear. |
| Reserved           | [31:1] | R    | Returns "0"                                                                |

## 5.3.5.3 DMA Interrupt Enable Register

Register Address location: 0x40030008

Table 3-5.3: DMA Interrupt Enable Register

| Name                         | Bit(s) | Туре | Description                |
|------------------------------|--------|------|----------------------------|
| DMA Done Interrupt<br>Enable | [0]    | R/W  | 0 – disable<br>1 – enable. |
| Reserved                     | [31:1] | R    | Returns "0"                |

## 5.3.5.4 DMA CHO Data Port Register (Read Port)

Register Address location: 0x40031000

Table 3-5.4: DMA CHO Data Port Register (Read Port)

| Name         | Bit(s) | Туре | Description                                |
|--------------|--------|------|--------------------------------------------|
| DMA CH0 Port | [31:0] | R    | DMA CH0 Port (Read Port) RX FIFO Read Port |

## 6 Programming steps:

- 1. Reset FIFO
- 2. M4 sets up DMA CH0 (FPGA Channel12) for Reading the Sensor data
- 3. M4 Enables the DMA for CH0
- 4. M4 Programs the Sensor Enable Register (0x4002000C)
- 5. When Sensor Enabled, FPGA IP reads the data from the AD7476A device and writes into the RX FIFO.
- 6. FPGA IP generates DREQ to the SDMA controller to read the data
- 7. When Read DMA is complete DMA Done Interrupt is generated
- 8. M4 repeats step 2 to 3 to set up the next DMA and capture the sensor data
- 9. FPGA IP continues to read the Data from AD7476A device till the Sensor is Enabled

## 7 Data Format (32 -bit DMA):

Sensor data:

| Sensor Data1 [15:0] | Sensor Data0 [15:0] |
|---------------------|---------------------|
| Sensor Data3 [15:0] | Sensor Data2 [15:0] |
| Sensor Data5 [15:0] | Sensor Data4 [15:0] |
| Sensor Data7 [15:0] | Sensor Data6 [15:0] |
| •                   | •                   |
| •                   | •                   |

## **8 Revision History**

| Date       | Revision | Author            | Description     |
|------------|----------|-------------------|-----------------|
| 21-07-2020 | 1.0      | Rakesh Moolacheri | Initial Release |

## 9 Copyright and Trademark Information

All trademarks and / or trade names are property of their respective owners.

The information in this specification has been carefully reviewed for technical accuracy. However, QuickLogic does not take the responsibility for the accuracy of the included information. Quicklogic will not be held liable for damages which result from relying on the accuracy of the information contained in this specification. This specification is subject to change without notification.

If you find any errors or require additional explanation, please inform Quicklogic. All trademarks and / or trade names are property of their respective owners.

Copyright © 2016 QuickLogic All rights reserved.

QuickLogic Corporation 1277 Orleans Drive Sunnyvale CA. 94089-1138, USA