# Ethernet Protocol Stack Chip CH394

Version: 1.0 https://wch-ic.com

## 1. Overview

CH394 is an Ethernet protocol stack management chip, which is used for Ethernet communication in MCU system. CH394 chip comes with 10/100M Ethernet Media Access Control (MAC) and Physical layer (PHY), which is fully compatible with IEEE802.3 protocol, and has built-in Ethernet protocol stack firmware such as IP, ARP, ICMP, IGMP, UDP and TCP. MCU system can conveniently communicate with the network through CH394 chip. CH394 supports Wake-on-LAN (WOL) and power-down mode.

CH394Q provides SPI interface, CH394L provides SPI interface and 8-bit slave parallel interface. Controllers such as MCU/DSP/MCU/MPU can control CH394Q chip to communicate with Ethernet through SPI interface. Or through SPI interface or 8-bit parallel port to control CH394L chip for Ethernet communication.

The contents of this manual are mainly applicable to CH394Q and CH394L. For details, please refer to the CH394DS2 manual.

The following figure shows the application block diagram of CH394Q.

Figure 1-1 CH394Q application block diagram



## 2. Features

- Built-in Ethernet Media Access Control (MAC) and Physical layer (PHY)
- Support 10/100M, full-duplex/half-duplex adaptation, and is compatible with 802.3 protocol
- Support automatic conversion of MDI/MDIX lines
- Built-in TCP/IP protocol suite. Support IPv4, ARP, ICMP, IGMP, UDP and TCP protocols
- CH394Q supports 8 sockets and CH394L supports 4 sockets. Can transmit and receive data at the same time
- Support MAC RAW mode and IP RAW mode (IP RAW mode is only supported by CH394L)
- Provide a SPI slave interface (SPI mode 0 or 3) up to 40MHz, with the high bit coming first
- The CH394L provides a high-speed 8-bit slave parallel interface that supports a parallel data bus connected to the microcontroller.
- Support network Wake-on-LAN (WOL) and power-down mode
- LED status display (Link, ACT, 10/100M, full-duplex/half-duplex, etc.)
- Built-in 32KRAM can be used for Ethernet data transceiver, and each Socket transceiver buffer can be configured flexibly
- LQFP48 lead-free package is provided.

## 3. Package



Table 3-1 Package description

| Package form | Body size | Pin pitch |         | Package description        | Order model |
|--------------|-----------|-----------|---------|----------------------------|-------------|
| LQFP48       | 7*7mm     | 0.5mm     | 19.7mil | Low Profile Quad Flat Pack | CH394Q      |
| LQFP48       | 7*7mm     | 0.5mm     | 19.7mil | Low Profile Quad Flat Pack | CH394L      |

## 4. CH394Q Pins

| CH394Q                                                     | Pin name     |       | Din description                                                                                                                                                                           |  |
|------------------------------------------------------------|--------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pin No.                                                    | Pin name     | Туре  | Pin description                                                                                                                                                                           |  |
| 1                                                          | MDIRP        | I/O   | Differential input in 10BASE-T/100BASE-TX MDI mode;                                                                                                                                       |  |
| 2                                                          | MDIRN        | 1/0   | Differential output in 10BASE-T/100BASE-TX MDIX mode.                                                                                                                                     |  |
| 5                                                          | MDITP        | I/O   | Differential output in 10BASE-T/100BASE-TX MDI mode;                                                                                                                                      |  |
| 6                                                          | MDITN        | 10    | Differential input in 10BASE-T/100BASE-TX MDIX mode.                                                                                                                                      |  |
| 4                                                          | AVDD33       | Р     | For 3.3V main power input, it is recommended to place $0.1 \text{uF}$ in parallel with 10uF or 4.7uF ground capacitance close to the chip, or a single $1 \text{uF} \sim 4.7 \text{uF}$ . |  |
| 8                                                          | AVDD33       | Р     | 3.3V power input, it is recommended to connect 0.1uF or 1uF capacitor to ground.                                                                                                          |  |
| 20                                                         | AVDDK        | Р     | The external 1uF capacitor to ground is placed close to the chip.                                                                                                                         |  |
| 21、28                                                      | VDDIO        | Р     | For the power input of I/O interface, it is recommended to place 0.1uF or 1uF capacitance to ground close to the chip.                                                                    |  |
| 22                                                         | DVDDK        | Р     | The external 0.1uF or 1uF capacitor to ground is placed close to the chip.                                                                                                                |  |
| 3、9、14、16、19、<br>29、48                                     | GND          | Р     | Analog ground.                                                                                                                                                                            |  |
| 7、10、11、12、13、<br>15、17、18、23、<br>38、39、40、41、<br>42、46、47 | NC           | -     | Reserved, it is recommended to float.                                                                                                                                                     |  |
| 24                                                         | LED_SPD      | Ο     | Network speed indicator LED:<br>Low level indicates 100Mbps,<br>high level indicates 10Mbps.                                                                                              |  |
| 25                                                         | LED_LIN<br>K | 0     | Network connection indication LED:<br>Low level indicates connected,<br>high level indicates not connected.                                                                               |  |
| 26                                                         | LED_DUP      | О     | Duplex indicator LED:<br>Low level indicates full-duplex,<br>high level indicates half-duplex.                                                                                            |  |
| 27                                                         | LED_ACT      | 0     | Carrier induction indicator LED:<br>Low level indicates that there is a carrier induction signal,<br>high level indicates that there is no carrier induction signal.                      |  |
| 30                                                         | XI           | Ι     | Crystal oscillator input requires an external 25MHz crystal end<br>or an external clock input.                                                                                            |  |
| 31                                                         | XO           | Ο     | The inverted output of crystal oscillator needs to be externally connected to the other end of 25MHz crystal.                                                                             |  |
| 32                                                         | SCS          | I, PU | SPI chip select input, active low.                                                                                                                                                        |  |
| 33                                                         | SCK          | Ι     | SPI clock input, supporting mode 0 or 3.                                                                                                                                                  |  |

## Table 4-1 CH394Q pin definition

| 34 | SDO   | О     | SPI serial data output, connected to MISO of SPI host of processor. |                                     |  |
|----|-------|-------|---------------------------------------------------------------------|-------------------------------------|--|
| 35 | SDI   | Ι     | SPI serial data input, connected to MOSI of SPI host of processor.  |                                     |  |
| 36 | INT   | 0     | Interrupt request output, active low.                               |                                     |  |
| 37 | RSTB  | I, PU | Reset input, active                                                 | low.                                |  |
|    |       |       | PHY operation mo                                                    | de selection                        |  |
| 43 | PMOD2 | I, PU | PMOD[2:0]                                                           | Description                         |  |
|    |       |       |                                                                     | 10M half-duplex, auto-negotiation   |  |
|    |       | I, PU | 000                                                                 | disabled.                           |  |
| 44 | PMOD1 |       | 001                                                                 | 10M full-duplex, auto-negotiation   |  |
|    |       |       |                                                                     | disabled.                           |  |
|    |       |       | 010                                                                 | 100M half-duplex, auto-negotiation  |  |
|    |       |       |                                                                     | disabled.                           |  |
|    |       |       |                                                                     | 100M full-duplex, auto-negotiation  |  |
|    |       |       | 011                                                                 | closed.                             |  |
| 45 |       |       | 100                                                                 | 100M half-duplex, auto-negotiation  |  |
| 45 | PMOD0 | I, PU | 100                                                                 | enabled.                            |  |
|    |       |       | 101                                                                 | Reserved                            |  |
|    |       |       | 110                                                                 | Reserved                            |  |
|    |       |       | 111                                                                 | Start auto-negotiation (Recommended |  |
|    |       |       |                                                                     | default mode)                       |  |

Note 1: I = Input; O = Output; I/O = Input/Output;

P = Power supply; PU = Built-in pull-up resistor.

## 5. CH394Q Data Format

The data in this manual have a suffix of B for binary numbers and H for hexadecimal numbers, otherwise they are decimal numbers.

## **5.1 Operation Mode**

CH394Q can share the SPI interface with other SPI devices. The peripheral host only needs to pull down the SCS pin to communicate with CH394Q. The interface can be used by other devices during non-communication period.

## 5.2 Data Frame

#### 5.2.1 Data Frame Format

The CH394Q data frame consists of three parts: A 16-bit offset address, an 8-bit control word, and an N-byte data segment.

The offset address is the CH394Q register address or the offset address of the RX/TX buffer.

The control word is used to define the ownership of the offset area set in the address segment and determine the read/write mode.

Pulling SCS low indicates the start of a new data frame, and pulling SCS high indicates the end of a data frame.

#### Figure 5-1 CH394Q data frame



CH394Q supports continuous reading or writing of data, starting from the starting address. After each transmission of data at an offset address, the offset address will automatically increase by 1 to transmit the next data.

#### 5.2.2 Control Phase

The CH394Q control phase specifies:

1. Ownership of the offset area set in the address segment;

2. SPI read/write mode;

| Bit   | Name                             | Description                                                                                                                                                                                                                                      |               |                 |  |  |  |
|-------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------|--|--|--|
| [7:3] | BS                               | <ul><li>Block selection bits:</li><li>Used to define the ownership of the offset area set in the addre segment.</li><li>CH394Q contains 1 common register, 8 socket registers, and th corresponding socket read and write buffer area.</li></ul> |               |                 |  |  |  |
|       |                                  | BS [7:3                                                                                                                                                                                                                                          | 3]            |                 |  |  |  |
|       | Segment number<br>selection[7:5] | Segment number<br>selection[7:5]                                                                                                                                                                                                                 | Function[4:3] | Description     |  |  |  |
|       |                                  | 000                                                                                                                                                                                                                                              | 00            | Common register |  |  |  |

|       |          | 000                     | 01   | Socket 0 register  |  |  |
|-------|----------|-------------------------|------|--------------------|--|--|
|       |          | 000                     | 10   | Socket 0 TX buffer |  |  |
|       |          | 000                     | 11   | Socket 0 RX buffer |  |  |
|       |          | 001                     | 00   | Meaningless        |  |  |
|       |          | 001                     | 01   | Socket 1 register  |  |  |
|       |          | 001                     | 10   | Socket 1 TX buffer |  |  |
|       |          | 001                     | 11   | Socket 1 RX buffer |  |  |
|       |          | 010                     | 00   | Meaningless        |  |  |
|       |          | 010                     | 01   | Socket 2 register  |  |  |
|       |          | 010                     | 10   | Socket 2 TX buffer |  |  |
|       |          | 010                     | 11   | Socket 2 RX buffer |  |  |
|       |          | 011                     | 00   | Meaningless        |  |  |
|       |          | 011                     | 01   | Socket 3 register  |  |  |
|       |          | 011                     | 10   | Socket 3 TX buffer |  |  |
|       |          | 011                     | 11   | Socket 3 RX buffer |  |  |
|       |          | 100                     | 00   | Meaningless        |  |  |
|       |          | 100                     | 01   | Socket 4 register  |  |  |
|       |          | 100                     | 10   | Socket 4 TX buffer |  |  |
|       |          | 100                     | 11   | Socket 4 RX buffer |  |  |
|       |          | 101                     | 00   | Meaningless        |  |  |
|       |          | 101                     | 01   | Socket 5 register  |  |  |
|       |          | 101                     | 10   | Socket 5 TX buffer |  |  |
|       |          | 101                     | 11   | Socket 5 RX buffer |  |  |
|       |          | 110                     | 00   | Meaningless        |  |  |
|       |          | 110                     | 01   | Socket 6 register  |  |  |
|       |          | 110                     | 10   | Socket 6 TX buffer |  |  |
|       |          | 110                     | 11   | Socket 6 RX buffer |  |  |
|       |          | 111                     | 00   | Meaningless        |  |  |
|       |          | 111                     | 01   | Socket 7 register  |  |  |
|       |          | 111                     | 10   | Socket 7 TX buffer |  |  |
|       |          | 111                     | 11   | Socket 7 RX buffer |  |  |
|       |          | Read/write selection b  | oit: |                    |  |  |
| 2     | RW       | 0: SPI read;            |      |                    |  |  |
|       |          | 1: SPI write.           |      |                    |  |  |
| [1:0] | Reserved | Reserved, default is 0. |      |                    |  |  |

## **5.3 Data Frame Example**

The CH394Q registers use big-end mode for data storage. In memory, the low byte is placed in the high address bit while the high byte is located in the low address bit.

## 5.3.1 Data Frame Example

(1) Read 2-byte data

Read 2-byte of unreachable port information from the common register (Assuming the unreachable port is 0x03e8):

MOSI: 0x00,0x2c,0x00,0x00,0x00 MISO: - ,- ,- ,0x03,0xe8 (2) Write 6-byte data Configure the Socket5 destination MAC as 0x11:0x22:0x33:0x44:0x55:0x66: MOSI: 0x00,0x06,0xac,0x11,0x22,0x33,0x44,0x55,0x66 MISO: - ,- ,- ,- ,- ,- ,- ,- ,- ,-

## 6. CH394Q Register and Buffer

CH394Q has 1 common register area, 8 socket register areas, 8 receive buffer areas and 8 transmit buffer areas.

There are multiple configurable registers in each register area. Each register in the same area has a different offset address. The register to be read or written is determined by the different offset addresses in the address segment. The BS bit of the control word is used to define which register area the offset address set in the address segment belongs to.

CH394Q has a total of 16K transmit buffer, 8 sockets each default 2K; 16K receive buffer, 8 sockets each default 2K.

When reading/writing the socket receive/transmit buffer, the offset address in the address segment (Obtained by querying the RD/WR register) represents the starting address of the data storage, and the BS bit in the control word controls the specific receive/transmit buffer to be read/written.

## 6.1 Register Table

#### 6.1.1 Common Register Table

The CH394Q common register configures the CH394Q mode, IP, MAC, etc. To read/write the common register, you need to fill in the offset address corresponding to the register in the offset address part of the data frame, and set the BS part of the control word to 00000B.

| Offset address | Name   | Access | Description                       | Reset value |
|----------------|--------|--------|-----------------------------------|-------------|
| 0x0000         | MODE   | RW     | Mode register                     | 0x00        |
| 0x0001         | GWIP0  |        |                                   | 0x00        |
|                |        | RW     | Gateway address register          |             |
| 0x0004         | GWIP3  |        |                                   | 0x00        |
| 0x0005         | SMIP0  |        |                                   | 0x00        |
|                |        | RW     | Subnet mask register              |             |
| 0x0008         | SMIP3  |        |                                   | 0x00        |
| 0x0009         | MAC0   |        |                                   | 0xXX        |
|                |        | RW     | MAC address register              |             |
| 0x000E         | MAC5   |        |                                   | 0xXX        |
| 0x000F         | IP0    |        |                                   | 0x00        |
|                |        | RW     | Source IP address register        |             |
| 0x0012         | IP3    |        |                                   | 0x00        |
| 0x0013         | IIT0   | RW     | Interment interval times assisted | 0x00        |
| 0x0014         | IIT1   | ĸw     | Interrupt interval time register  | 0x00        |
| 0x0015         | GINT   | RW     | Global interrupt register         | 0x00        |
| 0x0016         | GINTE  | RW     | Global interrupt enable register  | 0x00        |
| 0x0017         | SINT   | RO     | Socket interrupt register         | 0x00        |
| 0x0018         | SINTE  | RW     | Socket interrupt enable register  | 0x00        |
| 0x0019         | RTIME0 | DW     | Define entire in the entire       | 0x07        |
| 0x001A         | RTIME1 | RW     | Retransmission time register      | 0xD0        |
| 0x001B         | RCNT   | RW     | Retransmission count register     | 0x08        |
| 0x001C         | -      | -      | Reserved                          | -           |

Table 6-1 Common register table

| 0x0027 |         |    |                            |      |
|--------|---------|----|----------------------------|------|
| 0x0028 | UNIP0   |    |                            | 0x00 |
|        |         | RO | Unreachable IP register    |      |
| 0x002B | UNIP3   |    |                            | 0x00 |
| 0x002C | UNPORT0 | RO | Unreachable port register  | 0x00 |
| 0x002D | UNPORT1 | KU |                            | 0x00 |
| 0x002E | PHY_CFG | RW | PHY configuration register | 0xB8 |
| 0x002F |         |    |                            |      |
|        | -       | -  | Reserved                   | -    |
| 0x0038 |         |    |                            |      |
| 0x0039 | CHIPV   | RO | Chip version register      | 0xXX |

### 6.1.2 Socket Register Table

CH394Q provides 8 Sockets, each Socket corresponds to a Socket register area, the register area corresponding to Socket n ( $0 \le n \le 7$ ) is selected by the BS bit of the control word (Refer to 5.2.2 for details), and the register of Socket n to be read/written is determined by the offset address.

| Offset address | Name          | Access                                | Description                            | Reset value |
|----------------|---------------|---------------------------------------|----------------------------------------|-------------|
| 0x0000         | Sn_MODE       | RW                                    | Socket n mode register                 | 0x00        |
| 0x0001         | Sn_CTRL       | RW                                    | Socket n control register              | 0x00        |
| 0x0002         | Sn_INT        | RW                                    | Socket n interrupt register            | 0x00        |
| 0x0003         | Sn_STA        | RO                                    | Socket n status register               | 0x00        |
| 0x0004         | Sn_PORT0      | RW                                    |                                        | 0x00        |
| 0x0005         | Sn_PORT1      | KW                                    | Socket n source port register          | 0x00        |
| 0x0006         | Sn_DMAC0      |                                       |                                        | 0x00        |
|                |               | RW                                    | Socket n destination MAC register      |             |
| 0x000B         | Sn_DMAC5      |                                       |                                        | 0x00        |
| 0x000C         | Sn_DIP0       |                                       |                                        | 0x00        |
|                |               | RW                                    | Socket n destination IP register       |             |
| 0x000F         | Sn_DIP3       |                                       |                                        | 0x00        |
| 0x0010         | Sn_DPORT0     | RW Socket n destination port register |                                        | 0x00        |
| 0x0011         | Sn_DPORT1     | KW                                    | Socket in destination port register    | 0x00        |
| 0x0012         | Sn_MTU0       | RW                                    | Socket n maximum transfer unit         | 0x00        |
| 0x0013         | Sn_MTU1       | KW                                    | register                               | 0x00        |
| 0x0014         | -             | -                                     | Reserved                               | -           |
| 0x0015         | Sn_TOS        | RW                                    | Socket n IP service type register      | 0x00        |
| 0x0016         | Sn_TTL        | RW                                    | Socket IP time-to-live register        | 0x80        |
| 0x0017         |               |                                       |                                        |             |
|                | -             | -                                     | Reserved                               | -           |
| 0x001D         |               |                                       |                                        |             |
| 0x001E         | Sn_RXBUF_SIZE | RW                                    | Socket n receive buffer size register  | 0x02        |
| 0x001F         | Sn_TXBUF_SIZE | RW                                    | Socket n transmit buffer size register | 0x02        |
| 0x0020         | Sn_TX_FS0     | RO                                    | Socket n idle transmit buffer length   | 0x08        |

| 0x0021 | Sn_TX_FS1    |    | register                               | 0x00 |
|--------|--------------|----|----------------------------------------|------|
| 0x0022 | Sn_TX_RD0    | RO | Socket n transmit buffer read pointer  | 0xXX |
| 0x0023 | Sn_TX_RD1    | KO | register                               | υχλλ |
| 0x0024 | Sn_TX_WR0    | RW | Socket n transmit buffer write pointer | 0xXX |
| 0x0025 | Sn_TX_WR1    |    | register                               | ΟΧΛΛ |
| 0x0026 | Sn_RX_RS0    | RO |                                        |      |
| 0x0027 | Sn_RX_RS1    | KO | Socket n receive data length register  | 0x00 |
| 0x0028 | Sn_RX_RD0    | RW | Socket n receive buffer read pointer   | 0xXX |
| 0x0029 | Sn_RX_RD1    | KW | register                               | UXAA |
| 0x002A | Sn_RX_WR0    | RO | Socket n receive buffer write pointer  | 0xXX |
| 0x002B | Sn_RX_WR1    | KO | register                               | UXAA |
| 0x002C | Sn_INTE      | RW | Socket n interrupt enable register     | 0xFF |
| 0x002D | Sn_IPF0      | RW | Socket a ID for growt as gister        | 0x40 |
| 0x002E | Sn_IPF1      |    | Socket n IP fragment register          | 0x00 |
| 0x002F | Sn_KEEPALIVE | RW | Socket n KeepAlive time register       | 0x00 |

## 6.2 RX/TX Buffer

| 0x3FFF   |                                 | 0x3FFF 🖛 |                                |
|----------|---------------------------------|----------|--------------------------------|
| 0x3FFF   | Socket7 transmit<br>buffer(2KB) | 0x3800   | Socket7 receive<br>buffer(2KB) |
| 0x3000   | Socket6 transmit<br>buffer(2KB) | 0x3000   | Socket6 receive<br>buffer(2KB) |
| 0x2800   | Socket5 transmit<br>buffer(2KB) | 0x2800   | Socket5 receive<br>buffer(2KB) |
| 0x2000   | Socket4 transmit<br>buffer(2KB) | 0x2000   | Socket4 receive<br>buffer(2KB) |
| 0x2000   | Socket3 transmit<br>buffer(2KB) | 0x1800   | Socket3 receive<br>buffer(2KB) |
| 0x1800   | Socket2 transmit<br>buffer(2KB) | 0x1800   | Socket2 receive<br>buffer(2KB) |
| 0x0800   | Socket1 transmit<br>buffer(2KB) |          | Socket1 receive<br>buffer(2KB) |
|          | Socket0 transmit<br>buffer(2KB) | 0×0800 - | SocketO receive<br>buffer(2KB) |
| 0x0000 I |                                 | 0×0000 └ |                                |

### Figure 6-1 RX/TX buffer

16K Socket receive buffer

16K Socket transmit buffer

Each socket (n =  $0 \sim 7$ ) of bit CH394Q provides an independent transmitting and receiving memory buffer, with a total of 16K receiving buffer and 16K transmitting buffer.

In the initial state, the transmitting and receiving buffers of each Socket are allocated to 2KB (The receiving buffer is 16KB in total and the transmitting buffer is 16KB in total). Users can reallocate the 16KB memory resources to each Socket by configuring the Socket transmit buffer size register (Sn\_TXBUF\_SIZE) and the Socket receive buffer size register (Sn\_RXBUF\_SIZE) as required, but it is necessary to ensure that the sum of the receive buffer and transmit buffer sizes of all sockets does not exceed 16KB to prevent data transmission errors.

## 7. CH394Q Register Description

Socket Pair contains a quadruple of source IP, source port, destination IP and destination port, which can uniquely identify the two connected parties in the Internet. This manual is referred to as Socket for short. CH394Q can provide 8 Socket at the same time, and their index values are 0, 1, 2, 3 ....

The high and low bytes of IP and MAC addresses agreed in this manual may be different from some documents, just for convenience:

For example, the IP address is 192.168.1.2, where 192 is the highest byte and 2 is the lowest byte.

For example, the MAC address is 0x11:0x22:0x33:0x44:0x55:0x66, where 0x11 is the highest byte and 0x66 is the lowest byte.

## 7.1 Common Register Description

CH394Q register uses big terminal mode for data storage. In memory, the low byte is placed in the high address bit, while the high byte is placed in the low address bit.

## 7.1.1 Mode Register (MODE) [0x0000]

This register is used to control the operation mode.

| Bit | Name     | Description                                                                                                                                                                                                                                                                                                  | Access | Default value |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|
| 7   | RST      | Set 1 for software reset, and it will be cleared automatically after the reset is completed.                                                                                                                                                                                                                 | RW, SC | 0             |
| 6   | Reserved | Reserved                                                                                                                                                                                                                                                                                                     | RO     | 0             |
| 5   | WOL      | <ul> <li>Wake on LAN enabled:</li> <li>0: Disable WOL mode;</li> <li>1. Enable WOL mode.</li> <li>CH394Q integrates the magic packet WOL mode. After enabling the magic packet wake-up, CH394Q will pull down the INT pin after receiving the magic packet (0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF</li></ul> | RW     | 0             |
| 4   | РВ       | PING packet block enabled:<br>0: Disable PING block;<br>1: Enable PING block.                                                                                                                                                                                                                                | RW     | 0             |
| 3   | Reserved | Reserved                                                                                                                                                                                                                                                                                                     | RO     | 0             |
| 2   | Reserved | Reserved                                                                                                                                                                                                                                                                                                     | RO     | 0             |
| 1   | FARP     | <ul> <li>Forced ARP enable:</li> <li>0: Disable forced ARP mode;</li> <li>1: Enable forced ARP mode.</li> <li>Turn on forced ARP mode. When forced ARP is turned on, an ARP request will be forced to be sent before each UDP packet is sent.</li> </ul>                                                     | RW     | 0             |
| 0   | Reserved | Reserved                                                                                                                                                                                                                                                                                                     | RO     | 0             |

#### Table 7-1 Mode Register

#### 7.1.2 Gateway IP Address Register (GWIP) [0x0001-0x0004]

This register is used to set the gateway address, and the low byte address stores the high byte of the gateway address. For example: The gateway IP is 192.168.1.1.

| Address | 0x0001 | 0x0002 | 0x0003 | 0x0004 |
|---------|--------|--------|--------|--------|
| Data    | 0xC0   | 0xA8   | 0x01   | 0x01   |

### 7.1.3 Subnet Mask IP Address Register (SMIP) [0x0005-0x0008]

This register is used to set the subnet mask address, and the low byte address stores the high byte of the subnet mask address.

For example: Subnet mask IP 255.255.255.0

| Address | 0x0005 | 0x0006 | 0x0007 | 0x0008 |
|---------|--------|--------|--------|--------|
| Data    | 0xFF   | 0xFF   | 0xFF   | 0x00   |

## 7.1.4 MAC Address Register (MAC) [0x0009-0x000E]

This register is used to set the MAC address of CH394Q, and the low byte address stores the high byte of the MAC address.

The CH394Q chip has burned the MAC address assigned by IEEE when it leaves the factory. Please do not set the MAC address unless it is necessary.

For example: The MAC address is 0x38:0x3B:0x26:0x11:0x22:0x33

| Address | 0x0009 | 0x000A | 0x000B | 0x000C | 0x000D | 0x000E |
|---------|--------|--------|--------|--------|--------|--------|
| Data    | 0x38   | 0x3B   | 0x26   | 0x11   | 0x22   | 0x33   |

## 7.1.5 Source IP Address Register (IP) [0x000F-0x0012]

This register is used to set the IP address of CH394Q, and the low byte address stores the high byte of the IP address. For example: The source address is 192.168.1.100

| Address | 0x000F | 0x0010 | 0x0011 | 0x0012 |
|---------|--------|--------|--------|--------|
| Data    | 0xC0   | 0xA8   | 0x01   | 0x64   |

## 7.1.6 Interrupt Interval Register (IIT) [0x0013-0x0014]

This register is used to set the waiting time for the interrupt to take effect, and the default value is 0. When an interrupt event is handled, the INT signal line will return to high level, and it will take a set IIT interval time before CH394Q will notify the next interrupt and pull the INT signal line low.

The formula for calculating the interval time is: Time = 1/12000000\*4\*(IIT+1).

For example, if the register value is set to 1000, then the interval time is about 33.3us

| Address | 0x0013 | 0x0014 |
|---------|--------|--------|
| Data    | 0x03   | 0xE8   |

## 7.1.7 Global Interrupt Register (GINT) [0x0015]

This register is used to obtain the global interrupt status. When an interrupt event occurs, the corresponding bit in the GINT register will be set to 1. Writing a 1 to this bit can clear the interrupt flag bit. If the enable bit of this interrupt in GINTE is also 1, the level of the INT pin becomes low. Thereafter, once the corresponding bit of the event is cleared or the corresponding interrupt enable bit is set to 0, and the SINT is 0, the INT pin is restored to high level.

| Bit   | Name          | Description                                                                                                                                                                                                                                                                                                                                                                  | Access | Default value |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|
| 7     | IP_CONFL<br>I | IP conflict interrupt:<br>This interrupt occurs when CH394Q detects that its<br>own IP address is the same as that of other network<br>devices in the same network segment.                                                                                                                                                                                                  | RW     | 0             |
| 6     | UNREACH       | Unreachable interrupt:<br>When CH394Q receives the ICMP unreachable<br>interrupt message, it saves the IP address, port and<br>protocol type of the unreachable IP packet in the<br>unreachable information table, and then generates this<br>interrupt.<br>After receiving this interrupt, MCU can query UNIP<br>and UNPORT registers to obtain unreachable<br>information. | RW     | 0             |
| 5     | Reserved      | Reserved                                                                                                                                                                                                                                                                                                                                                                     | RO     | 0             |
| 4     | MP            | Magic packet wake-up interrupt:<br>This interrupt occurs when the Magic Packet function<br>is enabled and the Magic Packet WOL mode is received<br>through UDP.                                                                                                                                                                                                              | RW     | 0             |
| [3:0] | Reserved      | Reserved                                                                                                                                                                                                                                                                                                                                                                     | RO     | 0             |

| Table 7-2 | Global | interru | ot register |
|-----------|--------|---------|-------------|
|           | Global | muchu   | JUICEISICI  |

## 7.1.8 Global Interrupt Enable Register (GINTE) [0x0016]

This register is used to control which interrupt sources can trigger interrupts, and each interrupt event enable bit corresponds to one bit of the global interrupt register (GINT).

When the interrupt event is generated, only when the corresponding bit in GINTE is 1, CH394Q will pull down the INT pin and generate an interrupt.

| Bit   | Name          | Description                                                                                                               | Access | Default value |
|-------|---------------|---------------------------------------------------------------------------------------------------------------------------|--------|---------------|
| 7     | IP_CONFL<br>I | IP conflict interrupt enable bit:<br>Enable this bit allows IP collision interrupts to be<br>generated.                   | RW     | 0             |
| 6     | UNREACH       | Unreachable interrupt enable bit:<br>Enable this bit allows unreachable interrupts to be<br>generated.                    | RW     | 0             |
| 5     | Reserved      | Reserved                                                                                                                  | RO     | 0             |
| 4     | MP            | Magic Packet Wake-up Interrupt Enable Bit:<br>Enable this bit allows the generation of Magic Packet<br>Wake-up Interrupt. | RW     | 0             |
| [3:0] | Reserved      | Reserved                                                                                                                  | RO     | 0             |

 Table 7-3 Global interrupt enable register

## 7.1.9 Socket Interrupt Register (SINT) [0x0017]

This register is used to obtain the socket interrupt status. When an interrupt event occurs on socket n, the corresponding bit of the Sn INT register will be 1 and the nth bit of SINT will be 1, and the INT pin will be pulled

low. When Sn\_INT is 0, the corresponding bit of SINT will also be cleared. The INT pin is pulled high when both SINT and GINT are '0x00'.

| Bit | Name   | Description       | Access | Default value |
|-----|--------|-------------------|--------|---------------|
| 7   | S7_INT | Socket7 interrupt | RO     | 0             |
| 6   | S6_INT | Socket6 interrupt | RO     | 0             |
| 5   | S5_INT | Socket5 interrupt | RO     | 0             |
| 4   | S4_INT | Socket4 interrupt | RO     | 0             |
| 3   | S3_INT | Socket3 interrupt | RO     | 0             |
| 2   | S2_INT | Socket2 interrupt | RO     | 0             |
| 1   | S1_INT | Socket1 interrupt | RO     | 0             |
| 0   | S0_INT | Socket0 interrupt | RO     | 0             |

Table 7-4 Socket interrupt register

## 7.1.10 Socket Interrupt Enable Register (SINTE) [0x0018]

This register is used to control which Sockets can trigger interrupts, and each enable bit corresponds to one bit of the socket interrupt register (SINT).

When the Socket interrupt event is generated, only when the corresponding bit in SINTE is 1, CH394Q will pull down the INT pin and generate an interrupt.

| Bit | Name   | Description                                                                                         | Access | Default value |
|-----|--------|-----------------------------------------------------------------------------------------------------|--------|---------------|
| 7   | S7_INT | Socket7 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 7<br>interrupts. | RW     | 0             |
| 6   | S6_INT | Socket6 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 6<br>interrupts. | RW     | 0             |
| 5   | S5_INT | Socket5 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 5<br>interrupts. | RW     | 0             |
| 4   | S4_INT | Socket4 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 4<br>interrupts. | RW     | 0             |
| 3   | S3_INT | Socket3 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 3<br>interrupts. | RW     | 0             |
| 2   | S2_INT | Socket2 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 2<br>interrupts. | RW     | 0             |
| 1   | S1_INT | Socket1 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 1<br>interrupts. | RW     | 0             |
| 0   | S0_INT | Socket0 interrupt enable bit:<br>Enabling this bit allows the generation of Socket 0                | RW     | 0             |

Table 7-5 Socket interrupt enable register

|  | intownsets  |  |
|--|-------------|--|
|  | interrubts. |  |
|  |             |  |
|  |             |  |

#### 7.1.11 Retransmission Time Register (RTIME) [0x0019-0x001A]

This register is used to set the retransmission time in TCP communication and the retransmission time of ARP. If TCP transmission or ARP request does not receive a response from the other party within the RTIME time, a retransmission operation will be performed or a timeout interrupt will be triggered.

RTIME requires a two-byte time value with a unit of 0.1ms. The default value is 2000 (0x07D0), i.e. 200ms (2000\*0.1ms). Note that the RTIME value must be a multiple of 1000.

For example: Set retransmission time as 5000 (0x1388), i.e. 500ms.

| Address | 0x0019 | 0x001A |
|---------|--------|--------|
| Data    | 0x13   | 0x88   |

#### 7.1.12 Retransmission Count Register (RCN) [0x001B]

This register is used to set the retransmission timeout count. The retransmission timeout count refers to the maximum number of times a packet is retransmitted without a response, and the default value is 8. When the retransmission exceeds the set number of times, the corresponding socket timeout interrupt bit will be set to 1.

#### 7.1.13 Unreachable IP Register (UNIP) [0x0028-0x002B]

This register is used to obtain an unreachable IP address. When CH394Q transmits data to an unreachable port, the other party will reply with an ICMP packet (Destination port unreachable). After receiving the unreachable message, CH394Q will generate an unreachable interrupt. The microcontroller can use this command to obtain the unreachable address.

For example: Unreachable IP is 192.168.1.200

| Address | 0x0028 | 0x0029 | 0x002A | 0x002B |
|---------|--------|--------|--------|--------|
| Data    | 0xC0   | 0xA8   | 0x01   | 0xC8   |

#### 7.1.14 Unreachable Port Register (UNPORT) [0x002C-0x002D]

This register is used to obtain an unreachable port. When CH394Q transmits data to an unreachable port, the other party will reply with an ICMP packet (Destination port unreachable). After receiving the unreachable message, CH394Q will generate an unreachable interrupt. The microcontroller can use this command to obtain the unreachable port.

For example: Unreachable Port is 2000

| Address | 0x002C | 0x002D |
|---------|--------|--------|
| Data    | 0x07   | 0xD0   |

#### 7.1.15 PHY Configuration Register (PHY\_CFG) [0x002E]

This register configures status of PHY, and it indicates the current PHY connection status.

| Bit | Name | Description                                                                                                     | Access | Default value |
|-----|------|-----------------------------------------------------------------------------------------------------------------|--------|---------------|
| 7   | RST  | Reset:<br>0: PHY reset;<br>1: Normal work.<br><i>Note: This bit needs to be set to 1 manually after the PHY</i> | RW     | 1             |

#### Table 7-6 PHY configuration register

|       |       | reset is comp                                                                                                                         | leted                                      |      |     |
|-------|-------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|------|-----|
|       |       |                                                                                                                                       | bde selection bit:                         |      |     |
|       |       | -                                                                                                                                     | the PHY mode through hardware pin          | s    |     |
|       |       | (PMOD[2:0])                                                                                                                           |                                            |      |     |
|       |       |                                                                                                                                       | the PHY mode via the PHY Configuratio      | n    |     |
|       |       | Register [5:3                                                                                                                         |                                            |      |     |
|       |       |                                                                                                                                       | 4Q is powered on or reset by RSTB pin,     | t    |     |
|       |       |                                                                                                                                       | vel status of PMOD[2:0] pin to set the PHY |      |     |
|       |       | operation mo                                                                                                                          |                                            |      |     |
| 6     | OPWD  | -                                                                                                                                     | er wants to control the PHY mode throug    | RW   | 0   |
|       |       |                                                                                                                                       | s necessary to:                            |      |     |
|       |       |                                                                                                                                       | OPWD as 1;                                 |      |     |
|       |       |                                                                                                                                       | OPMDC to the desired mode value.           |      |     |
|       |       |                                                                                                                                       | ser wants to use the level state of th     | e    |     |
|       |       |                                                                                                                                       | bin to set the PHY operation mode again, h |      |     |
|       |       |                                                                                                                                       | o set the OPWD bit from 1 to 0 withou      |      |     |
|       |       | -                                                                                                                                     | or resetting it again.                     |      |     |
|       |       |                                                                                                                                       |                                            |      |     |
|       |       | [5:3]                                                                                                                                 | Description                                |      |     |
|       |       | []                                                                                                                                    | 10M half-duplex, auto-negotiation          |      |     |
|       |       | disabled                                                                                                                              |                                            |      |     |
|       |       |                                                                                                                                       | 10M full-duplex, auto-negotiation          |      |     |
|       |       | 001                                                                                                                                   | disabled                                   |      |     |
|       |       |                                                                                                                                       | 100M half-duplex, auto-negotiation         |      |     |
|       |       | OPMDC     010     disabled       011     100M full-duplex, auto-negotiation disabled       100     100M half-duplex, auto-negotiation | RW                                         | 111b |     |
| [5:3] | OPMDC |                                                                                                                                       |                                            |      |     |
|       |       |                                                                                                                                       |                                            |      | l   |
|       |       |                                                                                                                                       |                                            |      |     |
|       |       |                                                                                                                                       | enabled                                    |      |     |
|       |       | 101                                                                                                                                   | Reserved                                   |      |     |
|       |       | 110                                                                                                                                   | Power-down mode                            |      |     |
|       |       | 111                                                                                                                                   | Enable auto-negotiation                    |      |     |
|       |       |                                                                                                                                       | onfiguration bit                           |      |     |
|       |       | Duplex status                                                                                                                         |                                            |      |     |
| 2     | DUPS  | 0: half-duplex                                                                                                                        |                                            | RO   | 0   |
| -     |       | 1: full-duplex                                                                                                                        |                                            |      | U   |
|       |       |                                                                                                                                       |                                            |      |     |
| 1     | SPDS  | Speed status<br>0: 10Mb/s;                                                                                                            |                                            | RO   | 0   |
| -     | ~     | 1: 100Mb/s.                                                                                                                           |                                            |      | -   |
|       |       | Link status                                                                                                                           |                                            |      |     |
| 0     | LINKS |                                                                                                                                       | al layer does not establish a link;        | RO   | 0   |
| Ŭ     |       |                                                                                                                                       | al layer establishes the link.             |      | , v |
|       | _     |                                                                                                                                       | J                                          |      | l   |

## 7.1.16 Chip Version Register (CHIPV) [0x0039]

This register is used to obtain the chip version.

## 7.2 Socket Register Description

## 7.2.1 Socket n Mode Register (Sn\_MODE) [0x0000]

This register is used to configure the operation mode of Socket n.

| Bit | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Access | Default value |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------|
| 7   | MUL_MFE<br>N | <ul> <li>When Socket n works in UDP mode:</li> <li>0: Disable multicast mode;</li> <li>1: Enable multicast mode.</li> <li>When using multicast mode, you need to configure the multicast IP, multicast MAC, and port number through Sn_DIP and Sn_DPORT in advance before the socket is opened.</li> <li>When Socket n is operating in MAC RAW mode:</li> <li>0: Disables MAC address filtering;</li> <li>1: Enables MAC address filtering.</li> <li>When MAC RAW mode is used, with MAC address filtering turned on, Socket n will only receive packets on the network whose destination MAC is the CH394Q's own MAC address as well as the broadcast address.</li> </ul>                                                                                  | RW     | 0             |
| 6   | BCASTB       | <ul><li>Broadcast blocking shielding bit:</li><li>0: Disable broadcast blocking;</li><li>1: Enable broadcast blocking.</li><li>After this position 1, in UDP and MAC RAW mode,</li><li>Socket n will not receive broadcast blocking on the network.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RW     | 0             |
| 5   | NA_MV_M<br>M | <ul> <li>When Socket n is operating in TCP mode:</li> <li>0: Disable no-delay ACK;</li> <li>1: Enable no-delay ACK.</li> <li>After enabling no-delay ACK, Socket n will reply to</li> <li>ACK as soon as possible after receiving the packet from</li> <li>the opposite end without delay; otherwise, it will wait</li> <li>for 10ms before replying to ACK.</li> <li>When Socket n is operating in UDP multicast mode:</li> <li>0: Use IGMP version 2;</li> <li>1: Use IGMP version 1.</li> <li>When Socket n is operating in MAC RAW mode:</li> <li>0: Disable multicast blocking;</li> <li>1: Enable multicast blocking.</li> <li>When this position is set to 1, in MACRAW mode,</li> <li>Socket n will not receive multicast packets on the</li> </ul> | RW     | 0             |

network.

| 4       UCASTB_       When Socket n is operating in UDP multicast mode:         4       UCASTB_       Socket n will not receive unicast packets on the network. | 0 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 4 UCASTB 1: Enable unicast blocking.<br>UCASTB RW                                                                                                               | 0 |
| 4 When this position is set to 1, in UDP multicast mode,<br>Socket n will not receive unicast packets on the<br>network. RW                                     | 0 |
| 4 UCASTB Socket n will not receive unicast packets on the network. RW                                                                                           | 0 |
| 4 UCASTB_ network. RW                                                                                                                                           | 0 |
| A network. RW                                                                                                                                                   | 0 |
|                                                                                                                                                                 |   |
| MIP6B When Socket n is working in MAC RAW mode:                                                                                                                 |   |
| 0: Disable IPv6 blocking;                                                                                                                                       |   |
| 1: Enable IPv6 blocking.                                                                                                                                        |   |
| After this position 1, in MAC RAW mode, Socket n                                                                                                                |   |
| will not receive IPv6 packets on the network.                                                                                                                   |   |
| Set Socket operation mode:                                                                                                                                      |   |
| [3:0] Description                                                                                                                                               |   |
| 0000 OFF                                                                                                                                                        |   |
| [3:0] PMD 0001 TCP RW                                                                                                                                           | 0 |
| 0010 UDP                                                                                                                                                        |   |
| 0100 MAC RAW                                                                                                                                                    |   |
| Note: Only Socket 0 can use MAC RAW mode.                                                                                                                       |   |

## 7.2.2 Socket n Control Register (Sn\_CTRL) [0x0001]

This register is used to set the control command of Socket n. After configuring this register, the register will be automatically cleared. After setting the control command, the control command usually takes a certain amount of time to execute. Users can judge the command execution status through the Sn\_INT or Sn\_STA register.

|      | Table 7-8 Socket if mode register |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                             |                     |                 |
|------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|---------------------|-----------------|
| Code | Name                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Descr                                                                       | iption              |                 |
|      |                                   | can query the c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | en Socket n according t<br>ommand execution st<br>euted successfully, the c | atus through Sn_STA | A, and when the |
| 01H  | OPEN                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Sn_MODE[3:0]                                                                | Sn_STA              |                 |
|      |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0000 (OFF)                                                                  | -                   |                 |
|      |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0001 (TCP)                                                                  | 0x13 (INIT)         |                 |
|      |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0010 (UDP)                                                                  | 0x22 (UDP)          |                 |
|      |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0100 (MAC RAW)                                                              | 0x42 (MAC RAW)      |                 |
| 02H  | LISTEN                            | Set Socket n to the listening state:         This command takes effect only when Socket n is in TCP mode and is in the         INIT state.         When Socket n is set to LISTEN state, Socket n is in TCP Sever mode and waits         for the client to connect, and the Sn_STA register becomes 0x14 (LISTEN).         After the client connects successfully, the Sn_STA register value becomes 0x17         (ESTABLISHED) and Sn_INT[0] is set to 1.         If the connection fails the Sn_STA register value becomes 0x00 (CLOSE) and         Sn INT[3] is set to 1. |                                                                             |                     |                 |

| Table 7-8 Socket | n mode | register |
|------------------|--------|----------|
|------------------|--------|----------|

|       |            | Enable Socket n to enter connection mode:                                          |
|-------|------------|------------------------------------------------------------------------------------|
|       |            | This command takes effect only when Socket n is in TCP mode and is in INIT         |
|       |            | state.                                                                             |
|       |            | Enabling Socket to enter connection mode means TCP Client mode. When this          |
|       |            | command is executed, Socket n connects to the server according to the values       |
|       |            | set by Sn_DIP and Sn_DPORT, and the value of Sn_STA register changes to            |
|       |            | 0x17 (ESTABLISHED) and Sn_INT[0] is set to 1 when the connection is                |
|       |            | successful.                                                                        |
| 04H   | CONNECT    | When the socket connection fails:                                                  |
|       |            | 1: ARP failure, cannot get the destination MAC address (Sn_INT[3] set to 1);       |
|       |            | 2: Connection timeout, cannot receive SYN/ACK packet from the other party          |
|       |            | after transmitting SYN packet, after retransmission timeout (Sn_INT[3] set to      |
|       |            | 1);                                                                                |
|       |            | 3: Receiving RST packet, being disconnected by the other party on its own          |
|       |            | initiative.                                                                        |
|       |            | The Sn STA register value becomes 0x00 (CLOSE) when the above situation            |
|       |            | occurs.                                                                            |
|       |            | Socket n disconnect:                                                               |
|       | DISCONNECT | This command is effective only when Socket n is in TCP mode.                       |
|       |            | Active close: Actively transmit a FIN packet to the other end device;              |
|       |            | Passive close: After receiving a FIN packet from the other end, execute this       |
| 08H   |            | command to reply a FIN packet to the other end.                                    |
|       |            | If the FIN packet does not receive the ACK response from the other side, after     |
|       |            | the retransmission timeout, Sn INT[3] is set to 1, and the value of Sn STA         |
|       |            | register becomes 0x00(CLOSE).                                                      |
|       |            | Close Socket n:                                                                    |
|       |            | If Socket n is in UDP or MAC RAW mode, this command will directly close            |
|       |            | Socket.                                                                            |
| 10H   | CLOSE      | If Socket n is in TCP mode, this command will transmit a RST packet to close       |
|       |            | the Socket. Unlike the standard TCP closing process, this command will not         |
|       |            |                                                                                    |
|       |            | transmit a FIN packet when it is closed.                                           |
| 2011  | CENID      | Socket n transmitting data:                                                        |
| 20H   | SEND       | Transmitting the data in the Socket n transmitting buffer. See section 11.2.2 Data |
|       |            | transmitting process for details.                                                  |
|       |            | Socket n transmits data without ARP:                                               |
| 0.111 |            | This command only takes effect when Socket n is in UDP mode.                       |
| 21H   | SNED_MAC   | The SEND process is the same as the transmit command, but the MAC address          |
|       |            | of the opposite end is not obtained through ARP before the contract is sent, and   |
|       |            | the MAC address set by Sn_DMAC is used directly.                                   |
|       |            | Socket n transmits KeepAlive package:                                              |
|       |            | This command only takes effect when Socket n is in TCP mode.                       |
| 22H   | SEND_KEEP  | Actively transmit a heartbeat packet to the opposite device. If no reply is        |
|       |            | obtained after the timeout, Sn_INT[3] is set to 1, and the value of Sn_STA         |
|       |            | register becomes 0x00(CLOSE).                                                      |

|     |      | Socket n receiving data:                                                    |
|-----|------|-----------------------------------------------------------------------------|
| 40H | RECV | Complete the process of Socket n receiving data. For detailed steps, please |
|     |      | refer to Chapter 11.2.1 Data Receiving Process.                             |

### 7.2.3 Socket n Interrupt Register (Sn\_INT) [0x0002]

This register is used to obtain the interrupt status of Socket n. When the Socket n interrupt event occurs, the corresponding bit of the Sn\_INT register will be set to 1, and writing a 1 to this bit can clear the interrupt flag bit.

| Bit   | Name               | Description                                                                                                                    |    | Default value |
|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------|----|---------------|
| [7:5] | Reserved           | Reserved                                                                                                                       | RO | 0             |
| 4     | INT_SEND_SUC       | Transmit completion interrupt:<br>This interrupt is generated when the Socket n<br>SEND command is completed.                  |    | 0             |
| 3     | INT_TIMEOUT        | Timeout interrupt:<br>This interrupt is generated when Socket n ARP<br>times out or TCP retransmission times out.              | RW | 0             |
| 2     | INT_RECV           | Receive interrupt:<br>This interrupt is generated when Socket n receives<br>a packet.                                          | RW | 0             |
| 1     | INT_DISCONNE<br>CT | Disconnect interrupt:<br>This interrupt is generated when Socket n receives<br>the other party's FIN or FIN/ACK or RST packet. | RW | 0             |
| 0     | INT_CONNECT        | Connection interrupt:<br>This interrupt is generated when the Socket n is<br>successfully connected with the opposite end.     | RW | 0             |

## 7.2.4 Socket n Status Register (Sn\_STA) [0x0003]

This register is used to obtain the current state of Socket n and the temporary state in operation.

| Table 7-10 Socket n | status values |
|---------------------|---------------|
|---------------------|---------------|

| Code | Name        | Description                                                                        |  |
|------|-------------|------------------------------------------------------------------------------------|--|
| 00H  | CLOSE       | Close:                                                                             |  |
| 001  | CLOSE       | Socket n is in the closed state.                                                   |  |
|      |             | TCP Ready:                                                                         |  |
| 13H  | INIT        | When Socket n is in TCP mode and open is successful, Socket n is in INIT           |  |
| 13П  |             | state. Only when Socket n is in INIT state, users can use LISTEN or                |  |
|      |             | CONNECT command to make the next connection.                                       |  |
|      |             | TCP Listening:                                                                     |  |
| 14H  | LISTEN      | This status indicates that Socket n is in listening state as a TCP server, waiting |  |
| 1411 | LISTEN      | for TCP client connection.                                                         |  |
|      |             | Sn_STA will become 0x17 (ESTABLISHED) after successful connection.                 |  |
|      |             | Socket establishes connection:                                                     |  |
| 17H  | ESTABLISHED | When Socket is in the LISTEN state, it is connected successfully by the            |  |
|      |             | opposite TCP client as a TCP server mode; Or use the CONNECT command               |  |

|     |                                                     | as a TCP client to connect successfully, and Sn_STA will become 0x17(ESTABLISHED). |  |  |
|-----|-----------------------------------------------------|------------------------------------------------------------------------------------|--|--|
|     |                                                     | When Sn STA is 0x17 (ESTABLISHED), the connection is successful, and               |  |  |
|     |                                                     | data transmission can be carried out normally at this time.                        |  |  |
|     |                                                     | Close Waiting:                                                                     |  |  |
|     |                                                     | When Socket n is in TCP mode and receives a disconnect request packet (FIN         |  |  |
| 1CH | CLOSE_WAIT                                          | packet) from the other party, Sn_STA will become 0x10(CLOSE_WAIT). At              |  |  |
| ПСП |                                                     | this time, the TCP connection is in a semi-disconnected state. If you want to      |  |  |
|     |                                                     | completely disconnect, you need to use DISCONNT command, and if you                |  |  |
|     |                                                     | want to CLOSE it directly, you can use Close command.                              |  |  |
| 22H |                                                     | UDP mode:                                                                          |  |  |
| 22П | UDP         Indicates that Socket n is in UDP mode. |                                                                                    |  |  |
|     | MAC_RAW                                             | MAC RAW mode:                                                                      |  |  |
| 42H |                                                     | Indicates that Socket n is in MAC RAW mode.                                        |  |  |
|     |                                                     | Note: Only Socket 0 can use MAC RAW mode.                                          |  |  |

Temporary state during TCP connection:

| Table 7-11 Socket n TCP temporary status value |
|------------------------------------------------|
|------------------------------------------------|

| Code | Name                                                                                                                                                                                                                                                                        | Description                                                                                                                                                                                                           |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 15H  | SYN_SENT                                                                                                                                                                                                                                                                    | 0x17(ESTABLISHED).<br>If there is no reply to the SYN/ACK packet at the opposite end, after the SY<br>request retransmission times out, Sn_INT[3] is set to 1, and the value of Sn_S<br>register becomes 0x00(CLOSE). |  |  |
| 16H  | SYN request received:         When Socket n is in TCP Sever mode in listening state, Sn_STA becomes SYN_RECV after receiving the connection request packet from the opposite of the At this time. Socket n will reply the SYN/ACK packet to the opposite end. At this time. |                                                                                                                                                                                                                       |  |  |
| 18H  | FIN_WAIT                                                                                                                                                                                                                                                                    | These states all indicate that Socket n is closing.                                                                                                                                                                   |  |  |
| 1AH  | CLOSING                                                                                                                                                                                                                                                                     | Generally, there is no need to care about these States in application, and the chip                                                                                                                                   |  |  |
| 1BH  | TIME_WAIT                                                                                                                                                                                                                                                                   | will automatically process and update.                                                                                                                                                                                |  |  |
| 1DH  | DHLAST_ACKWhen the Socket n is closed successfully, or after the timeout (Sn_INT[3]1), the value of Sn_STA register becomes 0x00(CLOSE).                                                                                                                                    |                                                                                                                                                                                                                       |  |  |

### 7.2.5 Socket n Source Port Register (Sn\_PORT) [0x0004-0x0005]

This register is used to set the source port number of Socket n. If two or more Socket use the same mode, the source

port numbers must not be the same. For example, Socket0 is in UDP mode, the source port is 600, and Socket1 is also in UDP mode. You can't use the source port 600 again, otherwise it may lead to opening failure.

For example: The source port number is 2000.

| Address | 0x0004 | 0x0005 |
|---------|--------|--------|
| Data    | 0x07   | 0xD0   |

### 7.2.6 Socket n Destination MAC Register (Sn\_DMAC) [0x0006-0x000B]

This register is used to get or set the destination MAC address of Socket n. This register can be used in two ways: 1: Get the target MAC address. After ARP is successful, this register stores the MAC address obtained in the process of Socket n ARP.

2: Set the target MAC address. SNED\_MAC command in UDP mode will be sent directly according to the set MAC address.

For example: The MAC address is 0x38:0x3B:0x26:0x44:0x55:0x66.

| Address | 0x0006 | 0x0007 | 0x0008 | 0x0009 | 0x000A | 0x000B |
|---------|--------|--------|--------|--------|--------|--------|
| Data    | 0x38   | 0x3B   | 0x26   | 0x44   | 0x55   | 0x66   |

### 7.2.7 Socket n Destination IP Register (Sn\_DIP) [0x000C-0x000F]

This register is used to get or set the destination IP address of Socket n. This register can be used in two ways:

1. Get the target IP address. In TCP Sever mode, after the connection is successful, this register stores the IP address of the TCP client.

2: Set the destination IP address, which must be set in UDP and TCP Client modes.

For example: The destination IP address is 192.168.1.200.

| Address | 0x000C | 0x000D | 0x000E | 0x000F |
|---------|--------|--------|--------|--------|
| Data    | 0xC0   | 0xA8   | 0x01   | 0xC8   |

## 7.2.8 Socket n Destination Port Register (Sn\_DPORT) [0x0010-0x0011]

This register is used to get or set the destination IP port of Socket n. There are two ways to use this register:

1. Get the destination port. In TCP Sever mode, after the connection is successful, this register stores the port number of the TCP client.

2: Set the destination port, which must be set in UDP and TCP Client modes.

For example: The target port number is 3000.

| l | Address | 0x0010 | 0x0011 |
|---|---------|--------|--------|
|   | Data    | 0x0B   | 0xB8   |

## 7.2.9 Socket n Maximum Transfer Unit Register (Sn\_MTU) [0x0012-0x0013]

This register is used to set the maximum transmission unit (MTU) of Socket n, which takes effect in TCP mode and UDP mode. When the transmission length of user data exceeds the preset MTU size, the CH394Q built-in protocol stack will automatically perform data segmentation to ensure that each packet of data does not exceed the set value of MTU.

For example: Set MTU as 1000.

| Address | 0x0012 | 0x0013 |
|---------|--------|--------|
| Data    | 0x03   | 0xE8   |

#### 7.2.10 Socket n IP Service Type Register (Sn\_TOS) [0x0015]

This register is used to set the TOS service field in the IP header of the IP layer, which should be set before the Socket n OPEN. The default value is 0, and it does not need to be set by default.

### 7.2.11 Socket n IP Time-to-Life Register (Sn\_TTL) [0x0016]

This register is used to set the TTL service field in the IP header of the IP layer and should be set before Socket n OPEN. The default value is 0x80, the default value is not required, and the maximum value is 128.

#### 7.2.12 Socket n RX Buffer Size Register (Sn\_RXBUF\_SIZE) [0x001E]

This register is used to set the receive buffer size of Socket n, and the default value is 2(2KB). The register value can be set from 0 to 16, corresponding to 0 to 16KB. CH394Q allocates 2K space for each Socket by default.

| Socket 0 re | ceive buffer | Socket 1 re | ceive buffer | Socket 7 receive buf |          |
|-------------|--------------|-------------|--------------|----------------------|----------|
| Block 0     | Block 1      | Block 2     | Block 3      | <br>Block 14         | Block 15 |
| 2           | K            | 2           | K            | 2К                   |          |

The default allocation of the internal receiving buffer of CH394Q is as shown in the figure above, which consists of 16 blocks in total, and the length of each block is 1024 bytes. MCU can freely allocate the size of each Socket receiving buffer. After the configuration of Sn\_RXBUF\_SIZE is completed, the receive buffer will be reallocated in the order of Socket0 0 to 7. When setting the receiving buffer, it should be noted that the sum of all Socket receiving buffers cannot exceed 16KB.

### 7.2.13 Socket n TX Buffer Size Register (Sn\_TXBUF\_SIZE) [0x001F]

This register is used to set the transmit buffer size of Socket n, and the default value is 2(2KB). The register value can be set from 0 to 16, corresponding to 0 to 16KB. CH394Q allocates 2K space for each Socket by default.

| Socket 0 re | ceive buffer | Socket 1 re | ceive buffer | Socket 7 receive |          |
|-------------|--------------|-------------|--------------|------------------|----------|
| Block 0     | Block 1      | Block 2     | Block 3      | <br>Block 14     | Block 15 |
| 2           | K            | 2           | K            | 2K               |          |

The default allocation of CH394Q's internal transmit buffer is as shown above, which consists of 16 blocks, each of which is 1024 bytes long. MCU can freely allocate the size of each Socket transmitting buffer. After the configuration of Sn\_TXBUF\_SIZE is completed, the TX buffer will be reallocated in the order of Socket0 0 to 7. When setting the transmit buffer, it should be noted that the sum of all Socket transmit buffers cannot exceed 16KB.

## 7.2.14 Socket n TX Free Size Register (Sn\_TX\_FS) [0x0020-0x0021]

This register is used to obtain the size of the free space in the transmit buffer of Socket n. When no packet is sent, the free length is the size of the transmitted buffer of Socket n.

Before transmitting data, the user must query this register to obtain the size of the free space (See section 11.2.2 for details), and the length of the transmitted packet shall not be greater than the size of the free space.

For example: The length of the free buffer is 1000.

| Address | 0x0020 | 0x0021 |
|---------|--------|--------|
| Data    | 0x03   | 0xE8   |

## 7.2.15 Socket n TX Buffer Read Pointer Register (Sn\_TX\_RD) [0x0022-0x0023]

This register is used to obtain the transmitting and reading pointer of Socket n, which indicates the current position of the transmitting and reading pointer of CH394Q internal protocol stack. Users generally don't need to care about

the value of this register, and CH394Q automatically manages the update.

After successful initialization of Socket n, this register points to the initial address of Socket n transmit buffer. After the user finishes writing the data into the SEND buffer and updates the pointer of Sn\_TX\_WR, CH394Q will automatically process the data transmission from Sn\_TX\_RD to Sn\_TX\_WR by transmitting the SEND command. See section 11.2.2 for the detailed operation.

### 7.2.16 Socket n TX Buffer Write Pointer Register (Sn\_TX\_WR) [0x0024-0x0025]

This register is used to get or set the transmitting and writing pointer of Socket n. It is necessary to get the transmitting and writing pointer of the current Socket n before each transmitting data process, and update the register value after writing the data to be transmitted. For details, please refer to Section 11.2.2 data transmitting process. For example: The Socket n TX buffer write pointer is 2048.

| Address | 0x0024 | 0x0025 |
|---------|--------|--------|
| Data    | 0x08   | 0x00   |

## 7.2.17 Socket n RX Size Register (Sn\_RX\_RS) [0x0026-0x0027]

This register is used to obtain the size of data received by Socket n. Refer to Section 11.2.1 receiving data flow for details.

For example: Socket n receives data with a length of 1024.

|         | U      |        |
|---------|--------|--------|
| Address | 0x0026 | 0x0027 |
| Data    | 0x04   | 0x00   |

## 7.2.18 Socket n RX Buffer Read Pointer Register (Sn\_RX\_RD) [0x0028-0x0029]

This register is used to get or set the Socket n receiving buffer reading pointer, indicating the current position of the user receiving the buffer reading pointer.

It is necessary to obtain the reading pointer of the current Socket n before receiving the data flow every time, and update the register value after reading the data. Refer to Section 11.2.1 receiving data flow for details.

For example: The read pointer of Socket n receiving buffer is 2048.

| Address | 0x0028 | 0x0029 |
|---------|--------|--------|
| Data    | 0x08   | 0x00   |

## 7.2.19 Socket n RX Buffer Write Pointer Register (Sn\_RX\_WR) [0x002A-0x002B]

This register is used to obtain the receiving buffer write pointer of Socket n, which indicates the current position of the receiving data write pointer of CH394Q internal protocol stack. Users generally don't need to care about the value of this register, and CH394Q automatically manages the update.

After successful initialization of Socket n, this register points to the initial address of Socket n receiving buffer. When CH394Q receives the required data from Ethernet and loads it into the receiving buffer, it will update the Sn\_RX\_WR pointer accordingly. Refer to Section 11.2.1 Receiving Data Flow for details.

## 7.2.20 Socket n Interrupt Enable Register (Sn\_INTE) [0x002C]

This register is used to control which interrupt sources in Socket n can trigger interrupts. The default value is 0xFF. Each interrupt event enable bit corresponds to one bit of the Socket n interrupt register (Sn\_INT).

When the interrupt event is generated, only when the corresponding bit in Sn\_INTE is 1 and the nth bit of SINTE is 1 (Socket n interrupt is enabled) will CH394Q pull down the INT pin and generate an interrupt.

| Bit   | Name               | Description                                                                                                | Access | Default value |
|-------|--------------------|------------------------------------------------------------------------------------------------------------|--------|---------------|
| [7:5] | Reserved           | Reserved                                                                                                   | RO     | -             |
| 4     | INT_SEND_SUC       | Transmit complete interrupt:<br>Enabling this bit allows the generation of transmit<br>complete interrupt. | RW     | 1             |
| 3     | INT_TIMEOUT        | Timeout interrupt:<br>Enabling this bit allows a timeout interrupt to be<br>generated.                     | RW     | 1             |
| 2     | INT_RECV           | Receive Interrupt:<br>Enabling this bit allows a receive interrupt to be<br>generated.                     | RW     | 1             |
| 1     | INT_DISCONNE<br>CT | Disconnect Interrupt:<br>Enabling this bit allows disconnection interrupt to<br>be generated.              | RW     | 1             |
| 0     | INT_CONNECT        | Connection Interrupt:<br>Enabling this bit allows connection interruption.                                 | RW     | 1             |

Table 7-12 Socket n interrupt enable register

#### 7.2.21 Socket n IP Fragment Register (Sn\_IPF) [0x002D-0x002E]

This register is used to set the Socket n IP fragmentation field, and the default value is 0x4000.

For example: The Socket n IP fragmentation field is 0x4000 (No fragmentation).

| Address | 0x002D | 0x002E |
|---------|--------|--------|
| Data    | 0x40   | 0x00   |

## 7.2.22 Socket n Keep Alive Time Register (Sn\_KEEPALIVE) [0x002F]

This register is used to set the Socket n Keep Alive time, which only takes effect in TCP mode. The default value is 0, indicating that the Keep Alive function is not activated. To enable auto Keep Alive, you need to set the value of this register to be greater than zero. The unit time of the register is 5 seconds, that is, when the register value is 1, the Keep Alive interval is 5 seconds, when it is 2, it is 10 seconds, and so on.

When Socket n is in TCP mode and enters the idle (No data circulation) state after successfully establishing a connection with the opposite end (Sn\_STA state is 0x17), the system will automatically transmit Keep Alive packets at the time interval specified by Sn\_KEEPALIVE.

If the Keepalive packet is continuously sent without acknowledgement from the other party, the system will trigger a timeout interrupt after the retransmission time limit is exceeded.

When Sn\_KEEPALIVE is 0, users can manually transmit Keep Alive packets through the SEND\_KEEP command. When Sn\_KEEPALIVE is not 0, the SEND\_KEEP command does not take effect.

For example: Socket n Keep Alive time registration is 4 (a Keep Alive packet is automatically sent every 20 seconds when it is idle).

| Address | 0x002F |
|---------|--------|
| Data    | 0x04   |

## 8. CH394Q Function Description

## 8.1 SPI Serial Interface

SPI synchronous serial interface signal line includes SPI chip selection input pin SCS, serial clock input pin SCK, serial data input pin SDI and serial data output pin SDO. Through SPI interface, CH394Q can be connected to the SPI serial bus of various MCUs, DSP and MCU with less wires, or make long-distance point-to-point connection. SCS pin of CH394Q chip is driven by SPI chip selection output pin or common output pin of MCU, SCK pin is driven by SPI clock output pin SCK of MCU, SDI pin is driven by SPI data output pin SDO or MOSI of MCU, and SDO pin is connected to SPI data input pin SDI or MISO of MCU. For the hardware SPI interface, it is suggested that the SPI setting is CPOL=CPHA=0 or CPOL=CPHA=1, and the order of data bits is MSB first. The SPI interface of CH394Q also supports the MCU to communicate with the ordinary I/O pin analog SPI interface.

The SPI interface of CH394Q supports SPI mode 0 and SPI mode 3. CH394Q always inputs data from the rising edge of SPI clock SCK, and outputs data from the falling edge of SCK when output is allowed. The order of data bits is high, and 8 bits count as one byte.

When reading and writing the same register, after writing the register value, you need to wait for a  $t_{RI}$  processing time, which is about 0.7us. During the processing time, the host is forbidden to operate the register again.

The interval between each byte of SPI is at least one  $t_{SD}$  time, about 50ns; The interval between the control word and the data is at least one  $t_{SC}$  time, about 100ns, as shown in Figure 8-1 below.



Figure 8-1 SPI serial interface diagram

## 8.1.1 SPI Operation Steps

- ① SPI chip selection of CH394Q chip generated by MCU is effective at low level;
- ② MCU transmits data according to SPI output mode. CH394Q always takes the first two bytes received after SPI chip SCS is valid as offset address, the third byte as control word, and the subsequent bytes as data;
- ③ If it is a write operation, after the MCU transmits the offset address and control word, it continues to transmit several bytes of data to be written, and CH394Q receives them in turn until the MCU prohibits SPI chip selection;
- ④ If it is a read operation, after the MCU transmits the offset address and control word, it reads several bytes of data from CH394Q until the MCU prohibits SPI chip selection;
- (5) MCU prohibits SPI chip selection of CH394Q chip to end the current SPI operation.

## 8.2 Other Hardware

The CH394Q chip internally integrates 10M/100M Ethernet PHY and MAC, SPI-Slave controller, SRAM, high-speed MCU, firmware program, crystal oscillator and PLL multiplier, power supply power-on reset circuit, etc. The CH394Q chip supports MDI/MDIX lines.

The MDIRP, MDIRN, MDITP, and MDITN of CH394Q chip are the signal lines for Ethernet. PHY of CH394Q supports automatic conversion of MDI/MDIX lines.

The CH394Q chip has a built-in power-on reset circuit, which normally does not require external reset. RSTB pin is used to input an asynchronous reset signal from the outside; when the RSTB pin is low, the CH394Q chip is reset; when the RSTB pin returns to a high level, the CH394Q will continue to delay reset for about 10ms, and the host is prohibited from operating the CH394Q during this period of time. In order to reliably reset the CH394Q during power-up and reduce external interference, a capacitor with a capacity of about 0.1uF can be connected across the RSTB pin and ground.

## 9. CH394Q Parameters

## 9.1 Absolute Maximum Ratings

(Critical or exceeding the absolute maximum value will probably cause the chip to work improperly or even be damaged)

| Name                  | Parameter description                                         | Min. | Max.                    | Unit |
|-----------------------|---------------------------------------------------------------|------|-------------------------|------|
| T <sub>A</sub>        | Ambient operating temperature                                 | -40  | 85                      | °C   |
| TJ                    | Junction temperature range                                    | -40  | 100                     | °C   |
| Ts                    | Ambient temperature during storage                            | -55  | 150                     | °C   |
| AV <sub>DD33</sub>    | Operating power supply voltage                                | -0.4 | 4.0                     | V    |
| V <sub>DDIO</sub>     | I/O supply voltage                                            | -0.4 | 4.0                     | V    |
| AV <sub>DDK</sub>     | Power decoupling end of core analog circuit                   | -0.4 | 1.5                     | V    |
| DV <sub>DDK</sub>     | Power decoupling end of core digital circuit                  | -0.4 | 1.5                     | V    |
| V <sub>ETH</sub>      | Voltage on ETH physical signal pin                            | -0.4 | AV <sub>DD33</sub> +0.4 | V    |
| V <sub>IN</sub>       | Input voltage on pin                                          | -0.4 | V <sub>DDIO</sub> +0.4  | V    |
| V <sub>ESD(HBM)</sub> | ESD electrostatic discharge voltage (HBM) for common I/O pins | 4K   |                         | V    |
| Т                     | Input current on I/O pin                                      |      | 20                      | mΛ   |
| I <sub>IO</sub>       | Output current on I/O pin                                     |      | 20                      | mA   |

Table 9-1 Absolute maximum value

## 9.2 Electrical Parameters

Table 9-2 Electrical Parameter (AVDD33 = 3.3V, VDDIO = 3.3V, TA = 25°C)

| Name                  | Parameter des                                | Parameter description                 |                     |                     | Max.              | Unit |
|-----------------------|----------------------------------------------|---------------------------------------|---------------------|---------------------|-------------------|------|
| AV <sub>DD33</sub>    | Operating power supply volta                 | Operating power supply voltage        |                     | 3.3                 | 3.4               | V    |
| V <sub>DDIO</sub>     | I/O supply voltage                           |                                       | 1.7                 | 3.3                 | 3.6               | V    |
| V                     | I/O pin, input low voltage.                  | $V_{DDIO} = 3.3V$                     | 0                   |                     | 0.8               | V    |
| V <sub>IL</sub>       |                                              | $V_{DDIO} = 1.8V$                     | 0                   |                     | 0.6               | V    |
| N7                    | V <sub>IH</sub> I/O pin, input high voltage. | $V_{DDIO} = 3.3V$                     | 2.0                 |                     | V <sub>DDIO</sub> | N    |
| V <sub>IH</sub>       |                                              | $V_{DDIO} = 1.8V$                     | 1.2                 |                     | V <sub>DDIO</sub> | V    |
| Vol                   | Low level output voltage                     |                                       |                     | 0.4                 | 0.6               | V    |
| V                     | III. 1 1                                     |                                       | V <sub>DDIO</sub> - | V <sub>DDIO</sub> - |                   | V    |
| V <sub>OH</sub>       | High level output voltage                    |                                       | 0.6                 | 0.4                 |                   | v    |
| V <sub>hys</sub>      | Voltage hysteresis of I/O Schr               | nitt trigger                          |                     | 150                 |                   | mV   |
| CIO                   | I/O pin capacitance                          |                                       |                     | 5                   |                   | pF   |
| R <sub>PU</sub>       | Pull up equivalent resistance                |                                       | 30                  | 40                  | 55                | kΩ   |
| R <sub>PD</sub>       | Pull down equivalent resistance              |                                       | 30                  | 40                  | 55                | kΩ   |
| t <sub>f(IO)out</sub> | Fall time of output high to low              | Fall time of output high to low level |                     |                     | 6.5               | ns   |
| t <sub>r(IO)out</sub> | Rise time of output low to hig               | gh level                              |                     |                     | 6.5               | ns   |

## 9.3 Power Consumption

| Symbol          | Parameter                               | Condition<br>(All current, with network regulator)                                                                                                                                              | Typical | Unit |
|-----------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|
|                 | Supply current in transfer status       | The link of 100BASE-TX path is successful and<br>there are packets on the transceiver channel.<br>The link of 10BASE-TX path is successful and<br>there are packets on the transceiver channel. | 77.4    | mA   |
| I <sub>DD</sub> | Supply current in idle                  | The link of 100BASE-TX path is successful and there are no data packets on the transceiver                                                                                                      | 76.9    | mA   |
| JUD             |                                         | there are no data packets on the transceiver channel.                                                                                                                                           |         |      |
|                 | Supply current in disconnect status     | 100BASE-TX and 10BASE-TX paths are not<br>linked successfully and PHY is in auto-<br>negotiation state.                                                                                         | 58.1    | mA   |
|                 | Supply current in PHY power-down status |                                                                                                                                                                                                 | 18.6    |      |

#### Table 9-3 Power consumption (AVDD33 = 3.3V, VDDIO = 3.3V, TA = 25°C)

## 9.4 AC Electrical Characteristic and Timing

## 9.4.1 SPI Timing

Figure 9-1 SPI mode 0 timing figure







Table 9-4 SPI parameter table (AVDD33 = 3.3V, VDDIO = 3.3V, TA =  $25^{\circ}C$ )

| Symbol                             | Parameter                                                        | Condition                                                        | Min. | Max. | Unit |
|------------------------------------|------------------------------------------------------------------|------------------------------------------------------------------|------|------|------|
| f <sub>SCK</sub> /t <sub>SCK</sub> | SPI clock frequency                                              |                                                                  |      | 40   | MHz  |
| t <sub>SU(SCS)</sub>               | SCS setup time                                                   |                                                                  | 17   |      | ns   |
| t <sub>h(SCS)</sub>                | SCS holding time                                                 |                                                                  | 17   |      | ns   |
| t <sub>SU(SDI)</sub>               | Data input setup time                                            |                                                                  | 4    |      | ns   |
| t <sub>h(SDI)</sub>                | Data input holding time                                          |                                                                  | 2    |      | ns   |
| t <sub>a(SDO)</sub>                | Data output access time                                          |                                                                  | 0    | 8    | ns   |
| t <sub>dis(SDO)</sub>              | Data output disable time                                         |                                                                  | 0    | 10   | ns   |
| t <sub>SC</sub>                    | Required interval between SPI transmission control word and data |                                                                  | 100  |      | ns   |
| t <sub>SD</sub>                    | Required interval between SPI transmission data                  |                                                                  | 50   |      | ns   |
| t <sub>RI</sub>                    | Interval required for data frame operation                       | Write the same address<br>first and then read it.<br>Other cases | 0.7  |      | us   |

## 9.4.2 Oscillator and Crystal Oscillator Timing

Table 9-5 Parameters table of oscillator and crystal oscillator timing

| Symbol | Parameter              | Condition          | Min.   | Тур. | Max.   | Unit |
|--------|------------------------|--------------------|--------|------|--------|------|
| TCKF   | Crystal frequency      | Recommended within | 24.999 | 25   | 25.001 | MHz  |
|        |                        | 30ppm              |        |      |        |      |
| TPWH   | High clock pulse width |                    | 15     | 20   | 25     | ns   |
| TPWL   | Low clock pulse width  |                    | 15     | 20   | 25     | ns   |

Note: The XI and XO pins have built-in two oscillation capacitors required by an external crystal with a load capacitor of 12pF, and only the crystal is needed externally; If an external crystal with a load capacitance of 20pF

is selected, XI and XO need an additional oscillation capacitance of 15pF to the ground respectively.

## 9.4.3 Reset Timing

| Symbol                | Parameter                                     | Min. | Тур. | Max. | Unit |  |  |
|-----------------------|-----------------------------------------------|------|------|------|------|--|--|
| t <sub>RSTTEMPO</sub> | RSTB low level width                          | 1    |      |      | us   |  |  |
| t <sub>RSTTEMP1</sub> | RSTB high to host operable.                   | 7    | 9    | 13   | ms   |  |  |
|                       | Power on and reset to the host for operation. | 27   | 30   | 35   | ms   |  |  |

Table 9-6 Reset timing parameter table

## 10. CH394Q Package

Note: All dimensions are in millimeters.

*Pin center spacing is nominal with no error, except for dimensional error of no more than*  $\pm 0.2$ *mm.* 

## 10.1 LQFP48

## 11. CH394Q Application

## **11.1** Application Base

CH394Q integrates IPv4, ARP, ICMP, IGMP, UDP, TCP and other protocols.

TCP and UDP are two important transport layer protocols, both of which use IP as the network layer protocol.

TCP is a connection-oriented transmission, which can provide reliable byte stream transmission service.

UDP is a simple datagram-oriented transport layer protocol. Unlike TCP, UDP can't guarantee that the datagram can reach its destination accurately.

TCP provides highly reliable communication for network devices. Its work includes dividing the data handed to it by the application program into appropriate small pieces and handing it to the lower network layer, confirming the received packets, setting the timeout clock, etc. Because the transport layer provides highly reliable end-to-end communication, the application layer customers ignore all the details. UDP, on the other hand, provides a very simple service for the application layer, which is faster than TCP. It only transmits datagrams from one network terminal to another, but it does not guarantee that the datagrams can reach the other end. Any necessary reliability must be provided by the application layer.

IP is a protocol on the network layer, which is used by both TCP and UDP. Each set of data of TCP and UDP is transmitted in the network through the IP layer.

ICMP is an accessory protocol of IP protocol, which is used by IP layer to exchange error messages or other important information with other hosts or routers. For example, when CH394Q generates unreachable interrupt, it is through ICMP that error message switching is performed. PING also uses the ICMP protocol.

IGMP is an Internet group management protocol, which is mainly used to multicast a UDP datagram to multiple hosts.

ARP is an address resolution protocol, which is used to convert the addresses used by IP layer and network interface layer.

## 11.2 Application Reference Steps

This chapter introduces the operation process of transmitting and receiving data, and can refer to the routine for details.

#### 11.2.1 Receive Data Process

When receiving data, we must:

1. Read the received data length register (Sn\_RX\_RS) of Socket n to obtain the length of the received data;

2. Read the read pointer register (Sn\_RX\_RD) of the Socket n receiving buffer, and determine the starting address of the received data in the buffer;

3. The host reads data from the address;

4. Write the updated address (Starting address of received data+read length) into the read pointer register (Sn RX RD) in the Socket n receiving buffer.

5. Set the RECV bit of Sn\_CTRL register of Socket n to complete the receiving operation.

## 11.2.2 Transmit Data Process

When transmitting data, it is necessary to:

- 1. Read the idle transmitting buffer length register (Sn\_TX\_FS) of Socket n to ensure that the buffer area has enough space;
- 2. Read the transmitting and writing pointer register (Sn\_TX\_WR) of Socket n, and determine the effective address of the buffer where the current data to be sent should be written;

- 3. The host writes the data to be transmitted to the address;
- 4. Write the updated address (the starting address of transmitting data+the length of transmitting data) into the transmitting and writing pointer register (sn \_ tx \_ wr) of Socket n;
- 5. Set the SEND bit of Sn\_CTRL register of Socket n to transmit data.

## 11.3 CH394Q Hardware Circuit Design





Note:

1.CH394Q has built-in partial oscillation capacitance of crystal Y1, and C5 and C6 can be adjusted according to crystal parameters. For Y1 with a load capacitance of 12pF, C5 and C6 are not needed; For Y1, C5 and C6 with a load capacitance of 20pF, 15pF each is recommended.

2.CH394Q has built-in Ethernet 50 $\Omega$  impedance matching resistor, so don't connect 49.9 $\Omega$  or 50 $\Omega$  resistor externally, which is equivalent to voltage driving.

3.71 is an ethernet network transformer, and its center tap is grounded through capacitors C8 and C9 respectively, so don't connect any power supply.