

### **Disclaimer**

The information contained in this datasheet is for general information purposes only. The information is provided by Sfards Technology and while we endeavour to keep the information up-to-date and correct, we make no representations or warranties of any kind, express or implied, about the completeness, accuracy, reliability, suitability or availability with respect to the datasheet. Any reliance you place on such information is therefore strictly at your own risk. All users should evaluate the data suitability for each intended application of that data under actual use conditions. In no event will we be liable for any loss or damage including without limitation, indirect or consequential loss or damage, or any loss or damage whatsoever arising from loss of profits arising out of or in connection with the use of this datasheet.

# **Revision History**

| Version | Date       | Comments                 |
|---------|------------|--------------------------|
| 0.5     | 2015.04.20 | Initial release version. |
|         |            |                          |
|         |            |                          |



## **Contents**

| Disclai | imer                                       | 1  |
|---------|--------------------------------------------|----|
| Revisio | on History                                 | 2  |
| Produc  | ct Outline                                 | 4  |
| 1. A    | rchitecture                                | 5  |
| 2. Pı   | rotocol Specification                      | 6  |
| 3. C    | Command Reference                          | 7  |
| 4. R    | egisters Reference                         | 9  |
| 4.1.    | CPM Registers                              | 9  |
| 4.2.    |                                            |    |
| 4.3.    | BTC Registers                              | 17 |
| 5. Fi   | irmware Implementation Reference Guideline | 19 |
| 5.1.    | Workflow                                   | 19 |
| 5.2.    | . Auto Configure                           | 19 |
| 5.3.    |                                            |    |
| 5.4.    |                                            |    |
| 5.5.    | BTC Setting                                | 21 |
| 5.6.    | LTC Setting                                | 22 |
| 5.7.    | Thermal Sensor                             | 23 |
| 6. EI   | lectrical Specifications                   | 24 |
| 6.1.    |                                            |    |
| 6.2.    | PCB Board Design Recommendations           | 24 |
| 6.3.    |                                            |    |
| 6.4.    |                                            |    |
| 7. Pi   | rins And Ballmap                           | 26 |
| 7.1.    |                                            |    |
| 7.2.    |                                            |    |
|         | Package                                    |    |
|         | nformation                                 |    |

### **Product Outline**

SF3301 is high performance and low power SHA256/SCRYPT dual processor designed by SFARDS. With advanced technology and highly integrated design, the SF3301 is targeted to provide multiple functions and a low cost solution in SHA256/SCRYPT application fields.

#### **Specifications:**

- 160 BTC Units
- 31 LTC Units
- BTC mode up to 80GH/s with 0.31W/GH
- LTC mode up to 1.89MH/s with 2.0W/MH
- Dual-Mining mode: 100GH/s BTC & 1.75MH/s LTC
- Highly integrated with PLL and Pre-Calculation Engine of BTC
- 2-wires UART interface
- Support Crystal and Oscillator
- Fully adjustable clock frequency
- Support body-bias adjust
- On-chip thermal sensor

## 1. Architecture



## 2. Protocol Specification

The SF3301 uses two separate groups of uart ports for BTC and LTC. Both BTC and LTC each have two uart ports, one for input from the software or the previous SF3301 in the chain (pins UPRX0 UPRX1) and feedback to software or the previous SF3301 (pins UPTX0 UPTX1), the other for downstream to next SF3301 (pins DNTX0 DNTX1) and feedback from next SF3301 (pins DNRX0 DNRX1).

SF3301 register configuration format includes command header and data.

An 8 bit UART bus is used all the time. Every frame is made of 32 bit command header followed by 32 bit data or multiple 32 bit data if any. All the 32 bit are comprised of 8 bit uart.

Command header is marked by 55, which should be sent firstly, then host send CHIP\_ADDR (8 bits), UNIT\_ADDR (8 bits), REG\_ADDR (8 bits) sequentially.

After command header, host is able to write N\*32 bits data consecutively  $(N \ge 1)$  to REG\_ADDR, REG\_ADDR+1, REG\_ADDR+2, ... REG\_ADDR+N-1.

Whatever command header and data, the order of 32 bits is:

Byte0/Bit [7:0], Byte1/Bit [15:8], Byte2/Bit [23:16], Byte3/Bit [31:24].

Because UART will transmit each byte from bit [0] to bit [7], 32bits data is transmitted from bit [0] to bit [31] on UART.

The command header and data format are reviewed in following table:

|          | Byte3    | Byte2     | Byte1    | Byte0 | Transmit Order | Data@Register |
|----------|----------|-----------|----------|-------|----------------|---------------|
|          |          |           |          |       | 55 CHIP_ADDR   |               |
| Comman   |          |           | CHIP_ADD |       | UNIT_ADDR      |               |
| d Header | REG_ADDR | UNIT_ADDR | R        | 55    | REG_ADDR       |               |
|          |          |           |          |       |                | 0xB3B2B1B0 @  |
| DATA0    | В3       | B2        | B1       | В0    | B0 B1 B2 B3    | REG_ADDR      |
|          |          |           |          |       |                | 0xB7B6B5B4 @  |
| DATA1    | B7       | В6        | B5       | B4    | B4 B5 B6 B7    | REG_ADDR+1    |
|          |          |           |          |       |                | 0xBBBAB9B8 @  |
| DATA2    | ВВ       | ВА        | В9       | B8    | B8 B9 BA BB    | REG_ADDR+1    |

### 3. Command Reference

There are 8bits CHIP\_ID register inside each SF3301 chip. SF3301 only accept register access when CHIP\_ADDR of command header match CHIP\_ID or CHIP\_ADDR is 0xff (It means this is a broadcasting command)

SF3301 supports burst mode for register configuration, so the below 2 sequences have the same function. SF3301 request time interval between 2 commands must longer than UART timeout value.

Sequence 1: Command Header (REG\_ADDR), DATA0 (32bits), DATA1 (32bits), DATA2 (32bits), DATA3 (32bits)

Sequence2: Command Header (REG\_ADDR), DATA0 (32bits) -> Command Header (REG\_ADDR), DATA1 (32bits), DATA2 (32bits), DATA3 (32bits)

SF3301 report format:

1. Store Mode = 1

Report is 32 bits, only have payload for register read data, BTC/LTC result. There is no header on UART upstream.

2. Store Mode = 0

Report is 64 bits, format is

• For Register:

If read the CPM register:

```
Header = 0x55, Chip_id[7:0], {4'h0, 2'b00, 2'b0}, reg_addr;
```

Else

Header = 0x55, Chip\_id[7:0], {4'h0, 2'b01, 2'b0}, reg\_addr;

Data = reg\_data[31:0]

For BTC:

```
Rpt_length= 1:
```

```
Header = 0x55(Marker), CHIP_ID(8 bits), {RPT_TYP(1: BTC; 0: Reg), mem_remain[6:0]}, {6'h0, taskID[1:0]};
```

Rpt\_length= 0:

```
Header = 0x55(Marker), CHIP_ID(8 bits), {RPT_TYP(1: BTC; 0: Reg), mem_remain[6:0]}, 8'h0;
```

Data = Nonce(32bits)

#### • For LTC:

Header = 0x55(Marker), CHIP\_ID(8 bits), {RPT\_TYP(1: BTC; 0: Reg), mem\_remain[6:0]}, 8'h0;

Data = Nonce(32bits)



# **4. Registers Reference**

The 32 bit registers inside each chip are described as below.

## 4.1. CPM Registers

UNIT\_ADDR=0xF0 (BTC CPM/LTC CPM are physically independent, logically they use 0xF0 address)

| REG<br>ADDR(8<br>bits) | NAME          | Default<br>Value      | Description                                                                                                                                                                                                                                                                                    |
|------------------------|---------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                        | [31]pll_strb  | 0x0                   | Asynchronous strobe input to the output divider. When high, signals to the output divider that new values of pll_OD are to be loaded. Cleared by logic on the next cycle.  This signal is not controlled by cfg_cpm. It only functions when pll is under normal mode. Fix width 480ns=12x40ns. |
|                        | [30]pll_BP    | 0x0                   | PLL Bypass mode select, Fout = Fin                                                                                                                                                                                                                                                             |
| 0x0                    | [29:24]pll_OD | 0x0(ltc)/0x<br>2(btc) | PLL Output divider,  Fout = Fvco/pll_OD (pll_BP = 0)  000000: Fout = Fvco  00001: Fout = Fvco/2  000011: Fout = Fvco/3  000100: Fout = Fvco/4   111110: Fout = Fvco/62  111111: Fout = Fvco/63                                                                                                 |

|  |               |                  | PLL Feedback divider                                                                                                                                                                                       |
|--|---------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |               | 0x1a(for<br>ltc) | Fvco = Fref*pll_F                                                                                                                                                                                          |
|  |               |                  | 000_0XXX: NA                                                                                                                                                                                               |
|  | [00 47]    5  |                  | 000_1000: Fvco = Fref*8                                                                                                                                                                                    |
|  | [23:17]pll_F  | /0x20(for        | 000_1001: Fvco = Fref*9                                                                                                                                                                                    |
|  |               | btc)             |                                                                                                                                                                                                            |
|  |               |                  | 111_1110: Fvco = Fref*126                                                                                                                                                                                  |
|  |               |                  | 111_1111: Fvco = Fref*127                                                                                                                                                                                  |
|  |               |                  | PLL Input divider                                                                                                                                                                                          |
|  |               |                  | Fref = Fin/pll_R                                                                                                                                                                                           |
|  |               |                  | 000: Fref = Fin                                                                                                                                                                                            |
|  |               |                  | 001: Fref = Fin                                                                                                                                                                                            |
|  | [16:14]pll_R  | 0x0              | 010: Fref = Fin/2                                                                                                                                                                                          |
|  | [10.14]pii_N  | OXO              | 011: Fref = Fin/3                                                                                                                                                                                          |
|  |               |                  | 100: Fref = Fin/4                                                                                                                                                                                          |
|  |               |                  | 101: Fref = Fin/5                                                                                                                                                                                          |
|  |               |                  | 110: Fref = Fin/6                                                                                                                                                                                          |
|  |               |                  | 111: Fref = Fin/7                                                                                                                                                                                          |
|  | [13]count_on  |                  | When low, PHI is gated to zero                                                                                                                                                                             |
|  |               | 0x1              | 1'b1: Pll output clock enable                                                                                                                                                                              |
|  |               |                  | 1'b0: Pll output clock disable                                                                                                                                                                             |
|  | [12]Reserved  | -                | х                                                                                                                                                                                                          |
|  | [11]LOCKP10   | RO               | PLL lock state. This signal when high, indicates that the loop is in the state of COARSE LOCK. This signal indicates that the output frequency is within +/-10% (approximately) of the desired frequency.  |
|  | [10]LOCKP3    | RO               | PLL lock state. This signal when high, indicates that the loop is in the state of COARSE LOCK. This signal indicates that the output frequency is within +/-3.5% (approximately) of the desired frequency. |
|  | [9:6]Reserved | -                | х                                                                                                                                                                                                          |

|     |                                               |          | For debug pll clk output.                                                                                                                            |
|-----|-----------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | [5]core clock output divider disable          |          | To debug pil cik output.                                                                                                                             |
|     |                                               | 0x1      | 1'b1: disable core output clock divider                                                                                                              |
|     |                                               |          | 1'b0: enable core output clock divider                                                                                                               |
|     |                                               |          | Outside clock as Default select.                                                                                                                     |
|     | [4]core_clk_sel                               | 0x1      | 1'b1: core clock = external clock                                                                                                                    |
|     |                                               |          | 1'b0: core clock = PLL output clock                                                                                                                  |
|     | [3]pll_enable                                 | 0x1      | When this bit is at 0, PLL will enter power down mode. Write 1 to enter normal mode. If use pll_recfg to reconfig the PLL, this bit should be set 1. |
|     | [2]pll_recfg                                  | 0x0      | Re-config PLL                                                                                                                                        |
|     | [1]Reserved                                   | -        | х                                                                                                                                                    |
|     |                                               |          | Config CPM, Write 1,Clear by HW                                                                                                                      |
|     | [0]cfg_cpm                                    | 0x0      | All pll parameters except pll_strb should be                                                                                                         |
|     |                                               |          | updated until SW sets this bit.                                                                                                                      |
|     | [31:17]Reserved                               | -        | Х                                                                                                                                                    |
|     |                                               |          | DBG pin used for debug. Select between two source:                                                                                                   |
|     | [16]dbg_sel(only in ltc cpm register)         | 0x0      | 1'b1: output core_clock div.                                                                                                                         |
|     |                                               |          | 1'b0: output OSC_OK.                                                                                                                                 |
|     | [15]Reserved                                  | -        | -                                                                                                                                                    |
|     |                                               |          | Xclkout output enable. Low active.                                                                                                                   |
| 0x1 | [14]xclkout_oen(only in ltc cpm register)     | 0x0      | 1'b1: PAD is input mode, need configure the Pull up and pull down.                                                                                   |
|     |                                               |          | 1'b0: PAD output Xclkout.                                                                                                                            |
|     | [13]xclkout_hyst(only in ltc cpm register)    | 0x0      | Xclkout HYST enable. High active.                                                                                                                    |
|     | [12]xclkout_lowemi(o nly in ltc cpm register) | 0x0      | Xclkout LOWEMI enable. High active.                                                                                                                  |
|     | [dalualla                                     |          | Xclkout internal pull down disable                                                                                                                   |
|     | [11]xclkout_pdn(only in ltc cpm register)     | 0x1      | 1'b1: Disable pull down                                                                                                                              |
|     |                                               |          | 1'b0: Enable pull down                                                                                                                               |
|     | ı                                             | <u> </u> |                                                                                                                                                      |

|   |                                           |          | Xclkout internal pull up disable             |
|---|-------------------------------------------|----------|----------------------------------------------|
|   | [10]xclkout_pun(only in ltc cpm register) | 0x1      | 1'b1: Disable pull up                        |
|   | , ,                                       |          | 1'b0: Enable pull up                         |
|   |                                           |          | Downtream Uart Tx internal pull down disable |
|   | [9]dntx_pdn                               | 0x1      | 1'b1: Disable pull down                      |
|   |                                           |          | 1'b0: Enable pull down                       |
|   |                                           |          | Downtream Uart Tx internal pull up disable   |
|   | [8]dntx_pun                               | 0x1      | 1'b1: Disable pull up                        |
|   |                                           |          | 1'b0: Enable pull up                         |
|   | 5-1                                       |          | Downtream Uart Rx internal pull down disable |
|   | [7]dnrx_pdn                               | 0x1      | 1'b1: Disable pull down                      |
|   |                                           |          | 1'b0: Enable pull down                       |
|   | [6]dnrx_pun                               | 0x1      | Downtream Uart Rx internal pull up disable   |
|   |                                           |          | 1'b1: Disable pull up                        |
|   |                                           |          | 1'b0: Enable pull up                         |
|   |                                           |          | Uptream Uart Tx internal pull down disable   |
|   | [5]uptx_pdn                               | 0x1      | 1'b1: Disable pull down                      |
|   |                                           |          | 1'b0: Enable pull down                       |
|   |                                           | <b>V</b> | Uptream Uart Tx internal pull up disable     |
|   | [4]uptx_pun                               | 0x1      | 1'b1: Disable pull up                        |
|   |                                           |          | 1'b0: Enable pull up                         |
|   |                                           |          | Uptream Uart Rx internal pull down disable   |
|   | [3]uprx_pdn                               | 0x1      | 1'b1: Disable pull down                      |
|   |                                           |          | 1'b0: Enable pull down                       |
|   |                                           |          | Uptream Uart Rx internal pull up disable     |
|   | [2]uprx_pun                               | 0x1      | 1'b1: Disable pull up                        |
|   |                                           |          | 1'b0: Enable pull up                         |
| _ |                                           | _        |                                              |

|      |                          |            | Pad_output_mode:                                                                                                          |
|------|--------------------------|------------|---------------------------------------------------------------------------------------------------------------------------|
|      | [1:0]pad_output_mod<br>e | 0x3        | 00: open-drain mode 01: output low 10: open-drain mode, same to 00 11: normal mode                                        |
| 0x2  | core_clk_en[31:0]        | 0xffffffff |                                                                                                                           |
| 0x3  | core_clk_en[63:32]       | 0xfffffff  | DTC care clock N anable NvO 150                                                                                           |
| 0x4  | core_clk_en[95:64]       | 0xfffffff  | BTC core clock N enable; N:0-159  LTC core clock N enable: N: 0-30                                                        |
| 0x5  | core_clk_en[127:96]      | 0xfffffff  | LTC core clock in enable. In: 0-30                                                                                        |
| 0x6  | core_clk_en[159:128]     | 0xffffffff |                                                                                                                           |
| 0x1e | [1] uart_rpt_rstn        | 0x1        | reset uart rpt, low active                                                                                                |
|      | [0] core_rstn            | 0x1        | Reset core, low active                                                                                                    |
|      | [31]uart_update_en       | 0x0        | Uart parameter update enable. Write this bit will generate a pulse to clear uart internal counter.                        |
|      | [30]uart_tsm_slow        | 0x0        | Uart transmitter slow mode                                                                                                |
|      | [29]timeout_en           | 0x1        | Uart timeout enable  Enable UART to clear internal state when timeout happens.                                            |
|      | [28]uart_rev_fast        | 0x1        | Uart receiver fast mode  0: Uart receiver needs to wait 1 bit time on UART after stop bit  1: Uart receiver does not wait |
|      | [27:26]uart_mode         | 0x1        | Baud rate divider mode  10: 4 times oversample  01: 8 times oversample  00: 16 times oversample                           |
| 0x20 | [25:16]uart_divider0     | 10'd130    | Baud rate divider fraction  X.Y = External Clock Frequency/(Target Baudrate*uart_mode)  uart_divider0 = INT(0.Y*1024)     |

|           |                                  |          | De distribute                                                                                                              |
|-----------|----------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------|
|           |                                  |          | Baud rate divider integer                                                                                                  |
|           | [15:8]uart_divider1              | 'd27     | X.Y = External Clock Frequency/(Target Baudrate*uart_brdiv_mode)                                                           |
|           |                                  |          | uart_divider1 = X                                                                                                          |
|           |                                  |          | Uart timeout threshold                                                                                                     |
|           | [7:0]timeout_value               | 'd31     | Time interval between 2 commands.                                                                                          |
|           |                                  |          | The unit is 1 UART bit time.                                                                                               |
|           | [31:24] downstream<br>mode timer | 0x22     | When uart mode changes or uart bps changes, it will effect after this delay, the delay value is downstream mode timer << 8 |
|           | [23:16] upstream<br>mode timer   | 0x11     | When uart sends a report to host, it will insert delay between 2 transactions, the delay value is upstream mode timer << 8 |
|           | [5] store mode                   | 0        | 0: add report header;1: no report header                                                                                   |
| 0x21      | [4] upstream mode                | 0        | 1: Insert delay between reports; 0: Don't insert delay between reports                                                     |
|           | [3:2]                            | reserved |                                                                                                                            |
|           | [1] downstream uart0 disable     | 0        | 1: downstream uart0 disable                                                                                                |
|           | [0] downstream mode              | 0        | 1: bypass mode; 0: forward mode                                                                                            |
| 0x30      | Reserved                         | -        | х                                                                                                                          |
|           | [31:30]Reserved                  | -        | -                                                                                                                          |
|           |                                  | 5'd25    | Thermal sensor clock divider. It needs a clock frequency in 400kHz—800kHz.                                                 |
|           | [29:25]ths_clk_div               |          | Fclk_ths = Fxclk/(ths_clk_div*2)                                                                                           |
|           | [24]ths_ovfl                     | RO       | High indicates overflow of the digital adder.                                                                              |
|           | [23:16]ths_first_data            | RO       | The first output data. Used for calibration.                                                                               |
|           | [15:8]ths_data                   | RO       | 8 bit digital word that indicates junction temperature                                                                     |
| 0x50(Only | [7:6]Reserved                    | -        | -                                                                                                                          |
| in LTC)   | [5:1]ths_correct                 | 5'd16    | Set the offset correction value.                                                                                           |

|                         |                             | 1'b0                | Thermal sensor power down.                                                               |
|-------------------------|-----------------------------|---------------------|------------------------------------------------------------------------------------------|
|                         |                             |                     | 1'b1: Normal work                                                                        |
|                         | [0]ths_pdn                  |                     | 1'b0: Power down mode                                                                    |
| 0x60                    | spare                       | 32'b0               | Reserved register. Can be read and written. No function. The low 8bits is cleaned by HW. |
|                         |                             | 0x4743328<br>B(BTC) | Read-only, DEVICE_ID                                                                     |
|                         |                             | 0x4743328<br>1      |                                                                                          |
| 0x75                    | DEVICE_ID                   | (LTC)               |                                                                                          |
|                         |                             |                     | IsAutoCfgCmd                                                                             |
|                         |                             |                     | Write:                                                                                   |
|                         | [31]unconfig                |                     | 1 means this is AutoCfgCmd                                                               |
|                         |                             |                     | Read:                                                                                    |
|                         |                             |                     | 1: chip is unconfig; 0: chip is config                                                   |
|                         |                             | 0                   | 1: HW switch to bypass mode after                                                        |
| 0x7f                    |                             |                     | AutoCfgCmd                                                                               |
| (configure              | [30]<br>EnUartPipeAfterAuto |                     | 0: HW do not switch to bypass mode after                                                 |
| this register<br>before | Cfg                         |                     | AutoCfgCmd                                                                               |
| access                  | [29:12] Reserved            |                     |                                                                                          |
| other registers,        |                             | wo                  | 1: HW AutoCfgNonce                                                                       |
| and which can be        | [11] AutoCfgNonce           |                     | 0: HW does not AutoCfgNonce                                                              |
| configured              | [10:8] AutoCfgNonce         | WO                  | Nonce_Init=chip_addr<<(24+ AutoCfgNonce                                                  |
| only once)              | Mode                        |                     | Mode), valid when AutoCfgNonce is 1                                                      |
|                         | [7:0]chip_id                | 0                   | CHIP ID                                                                                  |

## 4.2. LTC Registers

UNIT\_ADDR=0x80-0x9E, 0xBF means broadcast to all LTC Units. Only 0x3f is readable

| REG      |      |        | Description |
|----------|------|--------|-------------|
| ADDR     | NAME | DEFAUT |             |
| (8 bits) |      | VALUE  |             |

| 0x0 (reset controlled by hw_rst_n) | INIT_NONCE                | 0          | Initial nonce of LTC units                                                                               |
|------------------------------------|---------------------------|------------|----------------------------------------------------------------------------------------------------------|
| 0x1-0x8                            | D1-D8                     | 0          | LTC Target                                                                                               |
| 0x9-0x10                           | D9-D16                    | 0          | LTC MIDSTATE                                                                                             |
| 0x11-<br>0x23                      | D17-D35                   | 0          | LTC DATA_IN                                                                                              |
| 0x2c                               | [31:16]LTC DLY0           | 16'd2048   | core delay in unit                                                                                       |
|                                    | [15:0] LTC DLY0           | 23*1024/31 | unit delay                                                                                               |
| 0x2d                               | LTC DLY1                  | 1024*23+10 | round delay of unit                                                                                      |
| 0x2f                               | [31:0]Reserved            | -          |                                                                                                          |
|                                    |                           | •          | 1: when starting a new task, the core will be reset automatically.                                       |
|                                    |                           | 1          | 0: when starting a new_ task, the core will not be reset automatically. So before a new task, please use |
|                                    | [31] cfg_done_rstn_enable |            | "stop_cur_task" or "sw_rst_n" to stop the current task                                                   |
|                                    | [30]nonce_mask            | 1'b0       | 1'b1: LTC core nonce will not add step. For bist mode                                                    |
|                                    | [29:21] reserved          |            |                                                                                                          |
|                                    | [20] clk_enable           | 0          | 1'b1: clock enable 1'b0: clock gating                                                                    |
|                                    |                           |            | gate scrypt_core[3 2 1 0] of ltc unit                                                                    |
|                                    | [19:16]gate_scrypt_core   | 0x0        | 1'b1: clock disable                                                                                      |
|                                    | [55,55]8,55_55,7[55]      |            | 1'b0: clock enable                                                                                       |
|                                    | reserved                  |            |                                                                                                          |
|                                    | [3]stop_cur_task          | 0          | Write 1 to Stop the current LTC task, HW will clear this bit automatically after write 1                 |
|                                    | [1] auto_cmp_mode         | 1          | If auto_cmp_mode==1 & LTC_Target0 != 0, LTC will only match unless scrypt result == Target               |
| 0x30                               | [0] ltc_cmp_mode          | 0          | LTC compare mode                                                                                         |

|                        |                          |       | 1'b1: LTC will only match unless scrypt result == Target  1'b0: LTC will only match unless scrypt result <= Target |
|------------------------|--------------------------|-------|--------------------------------------------------------------------------------------------------------------------|
| 0x3e                   | [31:0]bist result        | 0(RO) | Under bist mode, it will indicate the bist result. If the bit is 1, the core is good, otherwise is fault.          |
| 0x3f*(This register is | [10:7] bist_result_level |       | [10] all fault [9] 50%<=GoodCores<80% [8] 80%<=GoodCores<100% [7] GoodCores == 100%                                |
| shared by all LTC      | [6] bist_mode            | 0     | Ltc bist mode                                                                                                      |
| Units)                 | [5] single_shift         | 0     | Register value shifts to compute unit in every single Register access.                                             |
|                        | [3:0]pulse width         | 8     | LTC TOP CFG Pulse Width Cycle Number Should be set to >= 3                                                         |

## 4.3. BTC Registers

UNIT\_ADDR=0x00-0x9F, 0xEF means broadcasting to all BTC units. Only 0x1f is readable.

| REG      |                   |        | Description                                                                                                          |
|----------|-------------------|--------|----------------------------------------------------------------------------------------------------------------------|
| ADDR     | NAME              | DEFAUT |                                                                                                                      |
| (8 bits) |                   | VALUE  |                                                                                                                      |
| 0x0      | INIT_NONCE        | 0      | Initial nonce of BTC units                                                                                           |
| 0x1      | Tgt_diff          | 0      | The tgt[6]                                                                                                           |
| 0x2-0x9  | Midstate 0-7      | 0      | Midstate                                                                                                             |
| 0xa-0xc  | Data2 0-2         | 0      | Data2                                                                                                                |
| 0x1d     | [31:0]bist result | 0(RO)  | Under bist mode, it will indicate the bist result. If the bit is 1, the core is good, otherwise is fault.            |
|          | [31:3] reserved   | -      |                                                                                                                      |
| 0x1e     | [2] btc_task_en   | 0      | Btc task enable:  Default, the core will start when configuration done. If SW need to stop the btc task, it needs to |

|                     |                       |                                                                        | be set to 0                                                                                                                                                                                      |  |  |  |  |  |  |
|---------------------|-----------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                     | [1] cmp_tgt_en        | 1                                                                      | Compare the hash with tgt[6]                                                                                                                                                                     |  |  |  |  |  |  |
|                     | [0] rpt_length        | 1                                                                      | 1: The reported nonce includes taskID  0: The reported nonce excludes taskID                                                                                                                     |  |  |  |  |  |  |
|                     | [31:12]nonce_co<br>mp | ((32*19*p<br>ulse_widt<br>h*2*(160+<br>1) +<br>16*pulse_<br>width*2))/ | If cal_nonce add this value overflows, the BTC will start to load next job.                                                                                                                      |  |  |  |  |  |  |
| 0x1f*(Thi           | [11]rpt_length_to p   | 1                                                                      | This bit must be the same value as 0x1e bit[0] rpt_length.  1'b1: The reported nonce includes taskID, which for btc_top level  1'b0: The reported nonce excludes taskID, which for btc_top level |  |  |  |  |  |  |
| is shared<br>by all | [10:7] bist_level     | 0                                                                      | [10] all fault [9] 50%<=GoodCores<80% [8] 80%<=GoodCores<100% [7] GoodCores == 100%                                                                                                              |  |  |  |  |  |  |
|                     | [6]bist_mode          | 1                                                                      | For bist test                                                                                                                                                                                    |  |  |  |  |  |  |
|                     | [5]single_shift       | 0                                                                      | 1: the job data will shift to core when top receive every data(must include data3)  0: only when the job data is received, then the top can shift the data to core                               |  |  |  |  |  |  |
|                     | [4]force_start        | 0                                                                      | <ol> <li>when the job has been configured, the core will start.</li> <li>only when the current job overflow, the core will start next job.</li> </ol>                                            |  |  |  |  |  |  |
|                     | [3:0]pulse width      | 8                                                                      | The pulse width should set to >= 3                                                                                                                                                               |  |  |  |  |  |  |

## 5. Firmware Implementation Reference Guideline

#### 5.1. Workflow

The workflow of firmware is shown in Fig.1. It is noted that the BTC and LTC should configure independently after a reset because BTC /LTC module are physically independent.



Fig 1. Firmware workflow

### 5.2. Auto Configure

After reset, SF3301 become un-configured mode and CHIP ID is 0, and miner controller send auto configure command, all the chip will be set to configure mode in the chain, and the chip id will auto increase 1 at the next level chip. As the Fig.2 show, when setting auto configure the first SF3301 chip id to  $n(0 \le n \le 0)$ , the following chips id in the chain will set to n+1, n+2, ...,  $n+m(n+m \le 0)$ . After configured, host can access all the register of each chip in the chain by chip id. Auto configuration only does once time after hardware reset.



Fig 2. Auto configure chip id in chain-style net

### 5.3. PLL Setting

The PLL is bypass at default mode, so the clock of the core is from external crystal oscillator (Fin). When reconfigure the PLL, the calculation formula of PLL frequency is as follows:

$$PLLout = Fin/pll\_R*pll\_F/pll\_OD \qquad (PLLout is up to 1200MHz)$$
 
$$1 <= pll\_R <= 7, \ 8 <= pll\_F <= 127, 1 <= pll\_OD <= 63$$

Table 1 list typical PLL setting example:

Table 1. PLL setting example

| Fin(MHz) | pll_R | pll_F | pll_OD | PLLout(MHz) | BTC(Mhash/s) | LTC(Khash/s) |
|----------|-------|-------|--------|-------------|--------------|--------------|
| 25       | 1     | 8     | 8      | 25          | 4000         | 134          |
| 25       | 1     | 32    | 8      | 100         | 16000        | 539          |
| 25       | 1     | 40    | 8      | 125         | 20000        | 673          |
| 25       | 1     | 8     | 1      | 200         | 32000        | 1078         |
| 25       | 1     | 9     | 1      | 225         | 36000        | 1213         |
| 25       | 1     | 12    | 1      | 300         | 48000        | 1617         |
| 25       | 1     | 14    | 1      | 350         | 56000        | 1886         |
| 25       | 1     | 16    | 1      | 400         | 64000        | 2156         |
| 25       | 1     | 18    | 1      | 450         | 72000        | 2426         |
| 25       | 1     | 20    | 1      | 500         | 80000        | 2695         |
| 25       | 1     | 24    | 1      | 600         | 96000        | 3234         |
| 25       | 1     | 28    | 1      | 700         | 112000       | 3773         |
| 25       | 1     | 32    | 1      | 800         | 128000       | 4313         |

When change the PLL setting, the first step should gate the PLL (PLL reg[13]=0), then configure the PLL and disable gating PLL (PLL reg[13]=1).

#### 5.4. Uart Baud Rate Setting

When Fin=25MHz, the default uart baud rate is 115200bps, the recommend baud rate is 2Mbps to meet the high hash rate. The calculation formula of baud rate is as follows:

Baud rate = Fin/ Uart\_mode/(Uart\_Divider1 + Uart\_Divider0/1024)

Table 2 list typical baud rate configuration:

Fin(MHz) Uart\_mode Uart Divider1 Baud rate(bps) Uart Divider0 

Table 2. Uart baud rate typical setting

**Note**: It should be delayed at least 1ms to wait for the uart work normal after uart baud rate is changed.

#### 5.5. BTC Setting

There are two modes to accept the BTC work task, force mode and FIFO mode. In the force mode, the BTC core will start the new work task immediately after all data of new task is received, while in the FIFO mode, the BTC core will start new work task, which is stored in the task FIFO, only the original work task is done (nonce overflow), and the task FIFO depth is 1, so the task feed time interval should be appropriate to avoid the FIFO is too much or too little, according to the BTC hash power.

BTC module provides 2bits task ID to double check which nonce belong to which task hit. If Rpt\_length set to 1, the BTC task header REG\_ADDR[6:5] is used as task ID, and the nonce header byte3[1:0] is used as returned task ID, while Rpt\_length set to 0, the task ID function is disabled.

To filter more invalid nonce at the high network difficulty, the hash target[6] is applied to hash result comparison, and it will improve efficiency of host miner by reducing nonce check and even without nonce check at some network difficulty.

#### BTC configuration example:

//btc auto configure, start chip id = 1 {55 fe f0 7f 01 08 00 c0 }

```
//select pll, gating output

//set pll Fin=25M, pll_R[16:14] = 1, pll_F[23:17]= 32, pll_OD[29:24]=1, =>800M

{55 ff f0 00 09 00 40 01 }

// Pll output enable

{55 ff f0 00 09 20 40 01}

//config btc to force start mode

{55 ff ef 1f 18 08 e7 17}

//set btc initial nonce=0

{55 01 ef 00 00 00 00 00 00}

//send btc task and read nonce

{55 01 ef 01 target[6] midstate[0]- midstate[7] data[16]- data[18]}
```

#### 5.6. LTC Setting

There are two comparison modes of scrypt hash result, the recommend configuration is setting comparison mode 0 (ltc\_cmp\_mode = 0) and disable auto comparison mode (auto\_cmp\_mode =0). Because of low speed of scrypt hash rate, the miner host could set initial LTC nonce of every SF3301 is divided equally 4G hash range in the chain. For example, there are 4 SF3301 chips in the chain, the four initial LTC nonces are 0x00000000, 0x40000000, 0x80000000, 0xc0000000.

Note: LTC module does not support task ID double check and work task FIFO.

#### LTC configuration example:

```
//Itc auto configure, start chip id = 1

{55 fe f0 7f 01 08 00 c0 }

//select pll to 650M, pll output gating

//set pll Fin=25M, pll_R[16:14] = 1, pll_F[23:17]= 16, pll_OD[29:24]=1, =>400M

{55 ff f0 00 09 00 20 01 }

// Pll output enable

{55 ff f0 00 09 20 20 01}

//set Itc cmp mode

{55 ff bf 30 08 00 00 80 }

//set Itc initial nonce=0
```

```
{55 01 bf 00 00 00 00 00 00}
```

//send Itc task and read nonce

{55 ff ef 01 target[0]-target[7] midstate[0]- midstate[7] data[0]- data[18]}

#### 5.7. Thermal Sensor

The thermal sensor provides digital measurement of the junction temperature, and thermal sensor feature as following:

- Temperature measurement range: -40°C to 125°C,
- Resolution: 1°C, accuracy: +/- 6°C (after calibration),
- Input clock frequency: 400 kHz to 800 kHz.

Before using the thermal sensor, the thermal sensor should be calibrated correctly, and the thermal sensor calibration steps are explained in following steps:

- 1. Set the SF3301 in normal temperature environment, at a well-known junction temperature, Tj.
- 2. Set ths correct [5:1] = 16.
- 3. Set the pdn = High. Read the first data [23:16] code at the first DATAREADY pulse.
- 4. Compute temperature as Tm = ths\_first\_data [23:16] 95 [95 is the scaling factor].
- 5. Compute the calibration error using the formula Te = Tm Tj
- 6. Apply new ths\_correct [5:1] = 16 Te.
- 7. The corrected output ths\_data[15:8] still follows the equation, Tj = ths\_data[15:8] 95.

#### **Calibration example**

The calibration starts with Tj = 40, ths\_correct [5:1] = 16

- 1. ths first data [23:16] = 134 at the first DATAREADY pulse
- 2. Measured temperature, Tm (in C) = 134 95 = 39
- 3. Calculate Te = 39 40 = -1
- 4. New ths\_correct [5:1] to be applied = 16 (-1) = 17

Hence, the corrected ths\_data[15:8] = 135

After calibration, the thermal register ths\_data[15:8] - 95 is the actual temperature, and the miner host should regulate the hash rate(PLL) or dissipate heat to ensure the junction temperature not above 65°C.

**Note**: the thermal sensor only can be accessed by LTC uart port.

## **6. Electrical Specifications**

## 6.1. Crystal And Oscillator

| PARAMETER        | MIN | TYP | MAX | UNIT |
|------------------|-----|-----|-----|------|
| Clock Period     |     | 40  |     | ns   |
| Clock Frequency  | 24  | 25  | 30  | MHz  |
| Clock Duty Cycle | 45  | 50  | 55  | %    |
| Clock Jitter     |     |     | 50  | ps   |

### 6.2. PCB Board Design Recommendations

For crystal, the PCB board design require the following items: Max Rm = 50 Ohm, Max Co (shunt capacitance) = 5pF CA/CB= 20pF (+/- 20%)



### 6.3. Operation Condition

| PARAMETER              | MIN  | TYP  | MAX  | UNIT         | Max Current |
|------------------------|------|------|------|--------------|-------------|
| BTC Core Supply Power  | 0.6  | 0.7  | 0.8  | V            | 115A        |
| BTC body-bias negative | 0    | -0.6 | -1.1 | V            | 20MA        |
| BTC body-bias positive | 0    | 0.6  | 1.1  | V            | 20MA        |
| LTC core supply Power  | 0.8  | 0.9  | 1.1  | V            | 12A         |
| PLL Supply Power       | 1.62 | 1.8  | 1.98 | V            | 0.2A        |
| IO Supply Power        | 1.62 | 1.8  | 1.98 | V            | 0.2A        |
| THS supply power       | 1.62 | 1.8  | 1.98 | V            | 0.2A        |
| OSC supply power       | 1.62 | 1.8  | 1.98 | V            | 0.2A        |
| CPS supply power       | 1.62 | 1.8  | 1.98 | V            | 0.2A        |
| Operating Temperature  | 0    | 25   | 125  | $^{\circ}$ C |             |

## 6.4. Power Consumption

For the power consumption of the SF3301, please refer to "SF3301 power report.pdf".



# 7. Pins And Ballmap

## **7.1.** Ballmap

| (Do o | lana Ta            | p View)         |         |                  |                 |         | 1               |                    |         |         |                 |         |                    |         |         |                    |                    |         |         | 1                  |                    |                       | <u> </u>         | T            |
|-------|--------------------|-----------------|---------|------------------|-----------------|---------|-----------------|--------------------|---------|---------|-----------------|---------|--------------------|---------|---------|--------------------|--------------------|---------|---------|--------------------|--------------------|-----------------------|------------------|--------------|
| (I ac | nage 10            | 2               | 3       | 1                | 5               | 6       | 7               | 8                  | 9       | 10      | 11              | 12      | 13                 | 14      | 15      | 16                 | 17                 | 18      | 19      | 20                 | 21                 | 22                    | 23               | +'           |
| Λ Τ   | T CND              |                 | BTC GND | DTC VDD          | BTC GND         | Ü       | BTC GND         | ů                  | BTC GND |         |                 |         |                    |         | BTC GND |                    | BTC GND            |         | BTC GND |                    |                    | AVDD THS              |                  | _            |
| A     | OTC_GND            | _               |         | BTC_VDD          |                 | BTC_VDD |                 | BTC_VDD BTC GND    | _       | BTC_VDD | BTC_GND         |         | BTC_GND            | _       | _       |                    | _                  | _       |         | BTC_GNDS_0 BTC_GND |                    |                       | BTC_GND AGND THS |              |
| В     | OTC_VDD            | BTC_GND BTC_VDD | BTC_VDD | _                | BTC_VDD BTC GND | _       | BTC_VDD         | _                  | BTC_VDD | _       | BTC_VDD BTC GND |         | BTC_VDD<br>BTC GND | BTC_GND |         | BTC_GND<br>BTC_VDD |                    | _       | BTC_VDD | _                  | BTC GND            | _                     | BTC GND          |              |
|       | BTC_GND            | BTC_VDD         | _       | BTC_VDD          | _               |         | BTC_GND         |                    | _       |         | _               |         | BTC_GND            |         |         | BTC_VDD            |                    | BTC_VDD | _       | BTC_VDD            | DI C_OND           | ESDSUB_ANA ESDSUB_ANA |                  | <u> </u>     |
| р     | BTC_VDD            | _               | BTC_VDD | _                | BTC_VDD         | _       | BTC_VDD         | _                  | BTC_VDD | _       | BTC_VDD         |         | BTC_VDD            | _       |         | BTC_GND            |                    | _       | BTC_VDD | _                  |                    | BTC GND               |                  | -            |
| E     |                    | BTC_VDD BTC GND |         | BTC_VDD          | _               | PIC_AND | DIC_GND         | DIC_AND            | DIC_GND | PIC_AND | DIC_GND         | DIC_VDD | DIC_GND            | PIC_AND | DIC_GND | DIC_AND            | DIC_GND            | DIC_AND |         |                    |                    | GNDA OSC              |                  | <del>-</del> |
| Г     | BTC_VDD            | _               | BTC_VDD | _                |                 |         | BTC GND         | BTC VDD            | BTC GND | DTC VDD | BTC GND         | DTC VDD | DTC CND            | DTC VDD | BTC GND | BTC VDD            | BTC GND            |         | BTC_VDD |                    | _                  | VDDA OSC              |                  | С            |
| G I   |                    | BTC_VDD         |         | BTC_VDD          | _               |         |                 | BTC_VDD            |         | BTC_VDD | _               |         | BTC_GND<br>BTC_VDD |         | _       | BTC_VDD            |                    |         | _       |                    | BTC_GND            | _                     | GNDE             | 11           |
| H     |                    | _               | BTC_VDD | _                |                 |         | BTC_VDD         | _                  | BTC_VDD | _       | BTC_VDD         |         |                    | _       |         | _                  | _                  |         | _       | _                  | BTC_VDD            | _                     |                  | H<br>T       |
| J     | BTC_GND            | BTC_VDD         |         | BTC_VDD          | _               |         | _               | BTC_VDD BTC_GND    | _       | BTC_VDD | _               |         | BTC_GND            | _       | BTC_GND | _                  | _                  |         | BTC_GND | BTC_VDD            | _                  |                       | UPTX0            | J            |
| N I   |                    | _               |         | _                |                 |         | BTC_VDD         |                    |         |         |                 | BTC_GND |                    | BTC_GND |         | BTC_GND            | _                  |         |         |                    |                    |                       | XCLKOUT          | I.           |
| Ь І   | BTC_GND            |                 | BTC_GND |                  | _               |         | BTC_GND         | _                  | BTC_GND |         | BTC_GND         |         | BTC_GND            | _       | _       |                    | BTC_GND            |         | BTC_GND |                    | BTC_GND            |                       | UPRX1            | L<br>M       |
| M     |                    | BTC_GND         |         | BTC_GND          |                 |         | _               | BTC_GND            |         | BTC_GND | _               | _       | BTC_VDD            | _       |         | BTC_GND            |                    |         | _       | _                  | BTC_VDD            | _                     | RSTN             | M            |
| N I   | BTC_GND            |                 | BTC_GND | _                | BTC_GND         |         | BTC_GND         | _                  | BTC_GND | _       | BTC_GND         | _       | BTC_GND            | _       | BTC_GND |                    | BTC_VDD            |         |         |                    | BTC_GND            | _                     | VDDE             | IN IN        |
| P     | BTC_GNDS_1 BTC GND |                 | BTC_VDD | BTC_GND BTC_VDD  | _               |         | BTC_VDD LTC GND | BTC_GND<br>LTC_VDD | LTC GND | BTC_GND | LTC GND         | BTC_GND | LTC GND            | BTC_GND | LTC GND | BTC_GND            | BTC_VDD<br>LTC GND |         |         |                    | BTC_GND<br>LTC GND |                       | OSC_BP<br>DNTX0  | P            |
| Т     |                    | BTC_VDD         |         | BTC_VDD          | _               |         | _               | LTC_VDD            | _       | LTC_VDD |                 | LTC_VDD |                    | LTC_VDD | _       | LTC_VDD            | _                  |         | _       | LTC GND            |                    | GNDE                  | VDDE             | Т            |
| 1 1   | BTC_VDD            | _               | BTC_VDD |                  |                 |         |                 |                    | LTC_VDD | _       | _               |         | _                  |         | _       |                    | _                  |         | LTC_VDD |                    | LTC_VDD            |                       | DNTX1            | 1            |
| V     | TC_GND             | _               |         | BTC_VDD  LTC GND |                 |         | LTC_GND         | LIC_VDD            | LIC_GND | LIC_VDD | LTC_GND         | LIC_VDD | LTC_GND            | LIC_VDD | LTC_GND | LIC_AND            | LTC_GND            |         | _       | LTC_VDD            | _                  | LTC GND               | DBG              | V            |
| W     | LTC_VDD            | _               | LTC_VDD |                  | LTC_VDD         | LTC VDD | LTC GND         | LTC VDD            | LTC GND | LTC VDD | LTC CND         | LTC VDD | LTC CND            | LTC VDD | LTC_GND | LTC VDD            | LTC CND            | LTC VDD | LTC_VDD |                    | LTC_VDD            |                       | VDDE             | W            |
| V     |                    | LTC_VDD         |         | LTC_VDD          | _               | _       | LTC_GND         | _                  | _       | LTC_VDD | LTC_VDD         | LTC_VDD | LTC_UDD            | LTC_VDD |         | LTC_VDD            | LTC_GND            |         |         | LTC_VDD            | _                  |                       | VDDE             | V            |
| Λ Λ Ι |                    |                 |         |                  |                 |         |                 |                    |         |         |                 |         |                    |         |         |                    |                    |         |         |                    |                    |                       | ANAREXTPAD       | Λ Λ          |
| AA    | TC_VDD             | _               | LTC_GND | _                | LTC_WDD         | _       | LTC_GND         |                    | LTC_GND | _       | LTC_VDD         |         | LTC_UDD            |         | LTC_GND |                    | LTC_GND            |         | LTC_GND |                    | LTC_GND            | GNDE<br>VDDE          |                  |              |
| AB I  | TC_VDD             | Bro_onb         | LTC_VDD | LTC_GND          |                 | LTC_GND |                 | LTC_GND            |         | LTC_GND | _               | LTC_WDD |                    | LTC_GND |         | LTC_GND            | _                  | LTC_GND | _       | LTC_GND            |                    | 1000                  | GNDBGCOMP        | AB<br>AC     |
| AC 1  | LTC_GND            | LTC_VDD 2       | LIC_GND | LIC_VDD          | LTC_GND 5       | 6       | LTC_GND         | LTC_VDD<br>8       | LTC_GND | 10      | LTC_GND         | _       | LTC_GND            | _       | LTC_GND | _                  | LTC_GND            | _       | LTC_GND | _                  | LTC_GND            | GNDE                  | VDDE             | AC           |
|       | 1                  | ۷               | 3       | 4                | Э               | б       | 1               | δ                  | 9       | 10      | 11              | 12      | 13                 | 14      | 15      | 16                 | 1 (                | 18      | 19      | 20                 | 21                 | 22                    | 23               | Щ            |

## 7.2. Pins

The pins can be described as followed:

| Name        | Description                                                               |
|-------------|---------------------------------------------------------------------------|
| ANAREXT     | It should be floating                                                     |
| GNDBG       | Dedicated ground for the reference cells.                                 |
| AVDD_CPS    | 1.8V Supply                                                               |
| AVSS_CPS    | 1.8V GND                                                                  |
| AVDD_PLL0   | 1.8V Supply                                                               |
| AVSS_PLL0   | 1.8V GND                                                                  |
| AVDD_PLL1   | 1.8V Supply                                                               |
| AVSS_PLL1   | 1.8V GND                                                                  |
| XCLKIN      | In Oscillation mode, crystal needs to be connected to this pin and ZO. In |
|             | Bypass mode, single-end CMOS level clock needs to be applied to this pin. |
| OSC_ZO      | In Oscillation mode, crystal needs to be connected to this pin and A.     |
| AVDD_OSC    | 1.8V Supply                                                               |
| AVSS_OSC    | 1.8V GND                                                                  |
| DVDD_OSC    | Digital VDD. 0.8V-1.10V                                                   |
| DVSS_OSC    | Digital GND                                                               |
| AGNDSUB_OSC | Ground for substrate.                                                     |
| AVDD_THS    | 1.8V Supply                                                               |
| AVSS_THS    | 1.8V GND                                                                  |
| AVDD_IO     | 1.8V Supply                                                               |
| AVSS_IO     | 1.8V GND                                                                  |
| DVDD_BTC    | Digital VDD. 0.6V—0.8V                                                    |
| DVSS_BTC    | Digital VDD                                                               |
| DVDD_LTC    | Digital VDD. 0.8V—1.10V                                                   |
| DVSS_LTC    | Digital GND                                                               |
| RSTN        | Reset input pin. Active Low.                                              |
| UPRX0       | Upstream UARTO receive pin                                                |
| UPRX1       | Upstream UART1 receive pin                                                |
| UPTX0       | Upstream UARTO transmit pin                                               |
| UPTX1       | Upstream UART1 transmit pin                                               |
| DNRX0       | Downstream UARTO receive pin                                              |
| DNRX1       | Downstream UART1 receive pin                                              |
| DNTX0       | Downstream UART0 transmit pin                                             |
| DNTX1       | Downstream UART1 transmit pin                                             |
| DBG         | For debug.                                                                |
| XCLKOUT     | Output clock is the same as the input clock XCLK                          |
| OSC_BP      | When high, internal oscillator is by passed.                              |

# 8.Package



## 9.Information

For more information, please visit SFARDS On Github: <a href="http://github.com/sfards">http://github.com/sfards</a>

