# Ethernet Protocol Stack Chip CH395

Datasheet 1 Version: 2.2 https://wch-ic.com

# 1. Overview

CH395 is an Ethernet protocol stack management chip, which is used for Ethernet communication in MCU system.

CH395 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, UDP and TCP. MCU system can conveniently communicate with the network through CH395 chip.

CH395 supports 3 communication interfaces: 8-bit parallel port, SPI interface and UART. Controllers such as MCU/DSP/MCU/MPU can control the CH395 chip for Ethernet communication through any of the above communication interfaces.

The following figure shows the application block diagram of CH395.

Figure 1-1 CH395 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 IEEE802.3 protocol
- Support automatic conversion of MDI/MDIX lines
- I/O port supports 3.3V, 2.5V and 1.8V power supply, and is compatible with various voltage standards MCU.
- Built-in network port pull-up resistor, crystal oscillator matching capacitor, simplify peripheral circuits.
- Built-in TCP/IP protocol suite. Support IPv4, ARP, ICMP, UDP and TCP protocols
- Support DHCP to automatically obtain IP address.
- Provide 8 independent Socket pairs, which can transmit and receive data simultaneously.
- Support MACRAW mode and IPRAW mode.
- Provide a SPI slave interface (SPI mode 0 or 3) up to 40MHz, with the high bit coming first
- Provide high-speed 8-bit passive parallel interface and support parallel data bus connected to MCU.
- Provide UART with speeds up to 10Mbps, supports serial port connected to MCU, and supports dynamic adjustment of communication baud rate
- CH395F serial port supports RS485 automatic switching, and supports hardware flow control
- Support Sleep mode
- Built-in 24K RAM can be used for Ethernet data transceiver, and each Socket transceiver buffer can be configured flexibly
- Built-in 4KB EEPROM
- Support 8-channel GPIO
- Provide QFN32, LQFP64M and LQFP128 lead-free packages.

# 3. Package



| Package Form | Body Size | Pin Pitch     |  | Package Description           | Order Model |
|--------------|-----------|---------------|--|-------------------------------|-------------|
| QFN32        | 4*4mm     | 0.4mm 15.7mil |  | Quad Flat No-leads Package    | CH395F      |
| LQFP64M      | 10*10mm   | 0.5mm 19.7mil |  | Low-profile Quad Flat Package | CH395A      |
| LQFP128      | 14*14mm   | 0.4mm 15.7mil |  | Low-profile Quad Flat Package | CH395P      |

Note: 1. It is recommended to use smaller package CH395F for new design.

2 CH395A based on CH395Q upgrade, CH395P based on CH395L upgrade, the pin is basically compatible, replacement needs to adjust the peripheral circuit.

3. CH395Q, CH395L maintain the supply but not recommended for new designs.

# 4. CH395F Pins

# 4.1 CH395F Pin Definition

| CH395F  |           |                     |                                                                                                                 |  |  |
|---------|-----------|---------------------|-----------------------------------------------------------------------------------------------------------------|--|--|
| Pin No. | Pin Name  | Type <sup>(1)</sup> | Pin Description <sup>(2)</sup>                                                                                  |  |  |
| 2       | RXP       |                     | Differential input in 10BASE-T/100BASE-TX MDI mode;                                                             |  |  |
| 3       | RXN       | I/()                | Differential output in 10BASE-T/100BASE-TX MDI mode,                                                            |  |  |
| 4       | ТХР       |                     | Differential output in 10BASE-T/100BASE-TX MDIX mode;                                                           |  |  |
| 5       | TXN       | I/O                 | Differential input in 10BASE-T/100BASE-TX MDI mode,                                                             |  |  |
| 5       | 1211      |                     | 3.3V power supply input, it is recommended to place 0.1uF parallel 10uF                                         |  |  |
| 6       | VCC33     | Р                   | or 4.7uF ground capacitor close to the core.                                                                    |  |  |
| 19      | VCCIO     | Р                   | For the power input of I/O interface, it is recommended to place 0.1uF capacitance to ground close to the chip. |  |  |
| 9       | VDDK      | Р                   | The external 1uF ground capacitor is placed close to the chip.                                                  |  |  |
| 0       | GND       |                     | Common ground.                                                                                                  |  |  |
| 1/7/8   | NC        |                     | Reserved, suggested suspension.                                                                                 |  |  |
| 1///0   | 110       |                     | The crystal oscillator input needs an external 25MHz crystal end or an                                          |  |  |
| 12      | XI        | Ι                   | external clock input with a built-in crystal oscillator matching capacitor.                                     |  |  |
|         |           |                     | The inverted output of the crystal oscillator needs to be externally                                            |  |  |
| 13      | XO        | 0                   | connected to the other end of the 25MHz crystal, and a crystal oscillator                                       |  |  |
| 10      | no        |                     | matching capacitor is built in.                                                                                 |  |  |
| 10      | RSTI      |                     | External reset input, active low, built-in pull-up resistor.                                                    |  |  |
| 11 TNOW |           | 0                   | Transmit status output, which is used to control RS485 transceiver                                              |  |  |
|         |           |                     | switching of serial port.                                                                                       |  |  |
| 14      | RST       | 0                   | Reset and external reset output, active high.                                                                   |  |  |
| 15      | INT#      | 0                   | Interrupt request output, active low.                                                                           |  |  |
|         |           |                     | Network connection indicator LED output:                                                                        |  |  |
| 16      | ELINK#    | 0                   | Low level indicates that Ethernet PHY is connected;                                                             |  |  |
|         |           |                     | High level indicates that Ethernet PHY is not connected.                                                        |  |  |
| 17      | CEI       | יותו                | Used as an interface configuration input during internal chip reset. For                                        |  |  |
| 17      | SEL       | I,PU                | details on the specific configuration method, please refer to Chapter 6.1.                                      |  |  |
| 10      | ЕАСТ#     | 0                   | Carrier sensing indicator LED output:                                                                           |  |  |
| 18      | EACT# O   |                     | LED flashes indicate a carrier sensing signal.                                                                  |  |  |
| 20      | GPIO0     | I/O                 | General input and output pin 0, configured as input by default.                                                 |  |  |
|         |           |                     | A0: Address input of parallel port, distinguishing command port from                                            |  |  |
|         |           |                     | data port, built-in pull-up resistor; When A0=1, you can write commands,                                        |  |  |
| 21      | A0/GPIO1  |                     | and when A0=0, you can read and write data.                                                                     |  |  |
|         |           |                     | GPIO1: General-purpose input and output pin 1, configured as input by                                           |  |  |
|         |           |                     | default.                                                                                                        |  |  |
| 22      | RD#/GPIO2 | I/O,PU              | RD#: The parallel port read gate input, active low, built-in pull-up                                            |  |  |
| 22      |           | 10,10               | resistor.                                                                                                       |  |  |

Table 4-1 CH395F pin definition

|    |                    |        | GPIO2: General-purpose input and output pin 2, configured as input by                                         |
|----|--------------------|--------|---------------------------------------------------------------------------------------------------------------|
|    |                    |        | default.                                                                                                      |
|    |                    |        | WR#: The parallel port write gate input, active low, built-in pull-up resistor.                               |
| 23 | WR#/GPIO3/RD<br>Y# | I/O,PU | GPIO3: General-purpose input and output pin 3, configured as input by default.                                |
|    | 1 77               |        | RDY#: Output low level after CH395F reset is completed; RDY#                                                  |
|    |                    |        | function is not effective in parallel port mode.                                                              |
|    |                    |        | PCS#: Chip selection control signal input of parallel port, active low level, built-in pull-up resistor.      |
| 24 | PCS#/GPIO4         | I/O,PU | GPIO4: General-purpose input and output pin 4, configured as input by                                         |
|    |                    |        | default.                                                                                                      |
|    |                    |        | D0: The 0th bit in the 8-bit bidirectional data bus with a parallel port,                                     |
| 25 | D0/GPIO5           | I/O,PU | built-in pull-up resistor.                                                                                    |
| 25 | D0/01105           | 10,10  | GPIO5: General-purpose input and output pin 5, configured as input by                                         |
|    |                    |        | default.                                                                                                      |
|    |                    |        | D1: The first bit in the 8-bit bidirectional data bus with a parallel port, with a built-in pull-up resistor. |
| 26 | D1/GPIO6           | I/O,PU | GPIO6: General-purpose input and output pin 6, configured as input by                                         |
|    |                    |        | default.                                                                                                      |
|    |                    |        | RXD: Serial data input of UART, built-in pull-up resistor;                                                    |
|    | RXD/D2/GPIO7       | I/O,PU | D2: The second bit in the 8-bit bidirectional data bus with a parallel port,                                  |
| 27 |                    |        | built-in pull-up resistor.                                                                                    |
|    |                    |        | GPIO7: General-purpose input and output pin 7, configured as input by                                         |
|    |                    |        | default.<br>During the internal reset of the chip, the interface configuration input is                       |
|    |                    |        | input, and the built-in pull-up resistor is used in Chapter 6.1. After the                                    |
| •  | TXD/D3             | I/O,PU | chip reset is completed, use it as an interface pin.                                                          |
| 28 |                    |        | TXD: Serial data output of asynchronous serial port.                                                          |
|    |                    |        | D3: The third bit in the 8-bit bidirectional data bus with a parallel port,                                   |
|    |                    |        | built-in pull-up resistor.                                                                                    |
|    |                    |        | SCS: Chip-select input SCS of the SPI interface, active low, built-in                                         |
| 29 | SCS/D4             | I/O,PU | pull-up resistor.                                                                                             |
|    |                    |        | D4: The 4th bit in the 8-bit bidirectional data bus with a parallel port, built-in pull-up resistor.          |
|    |                    |        | SCK: The serial clock input SCK of the SPI interface, built-in pull-up                                        |
|    |                    |        | resistor.                                                                                                     |
|    |                    |        | CTS: Clear the send input, built-in pull-up resistor. If it is high, the serial                               |
|    | SCK/CTS/D5         |        | port blocks the next data transmission when the current data transmission                                     |
| 30 |                    | I/O,PU | is over. You can connect to the countertop RTS to achieve hardware flow                                       |
|    |                    |        | control (the serial port flow control function is turned off by default and                                   |
|    |                    |        | can be turned on through the CMD_SET_FUN_PARA command).                                                       |
|    |                    |        | D5: The 5th bit in the 8-bit bidirectional data bus with a parallel port, built-in pull-up resistor.          |
|    |                    |        | ount-in puil-up rosisior.                                                                                     |

|           |               |            |                                                                           | SDI: Serial data input to SDI of the SPI interface, built-in pull-up resistor.   |  |
|-----------|---------------|------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|
| 31 SDI/D6 | SDI/D6        | I/O,PU     | D6: The 6th bit in the 8-bit bidirectional data bus with a parallel port, |                                                                                  |  |
|           |               |            |                                                                           | built-in pull-up resistor.                                                       |  |
|           | 32 SDO/RTS/D7 |            | SDO: Serial data output as SPI interface.                                 |                                                                                  |  |
|           |               |            | I/O,PU                                                                    | RTS: Transmit request output. If it is low, it indicates that the serial port is |  |
|           |               |            |                                                                           | ready to receive data. You can connect to the countertop CTS to achieve          |  |
|           |               | SDO/RTS/D7 |                                                                           | hardware flow control (the serial port flow control function is turned off       |  |
|           |               |            |                                                                           | by default and can be turned on through the CMD_SET_FUN_PARA                     |  |
|           |               |            |                                                                           | command).                                                                        |  |
|           |               |            |                                                                           | D7: The 7th bit in the 8-bit bidirectional data bus with a parallel port,        |  |
|           |               |            |                                                                           | built-in pull-up resistor.                                                       |  |

*Note 1: Table abbreviation explanation:* 

*I* = *Input*; *O* = *Output*; *I*/*O* = *Input*/*Output*;

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

Note 2: The specific function of the alternate pin of the CH395F depends on the currently selected interface mode. When the alternate pin is used for the interface function, its GPIO function will be occupied, causing its GPIO function to fail, and at the same time, the corresponding bits in the GPIO register have no practical significance.

# 4.2 CH395A Pin Definition

| Table 4-2 CH395A pin definition | n definition | e 4-2 CH395A pi |
|---------------------------------|--------------|-----------------|
|---------------------------------|--------------|-----------------|

| CTION 5                                            |                |                     |                                                                                                                                                                                |  |
|----------------------------------------------------|----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CH395A<br>Pin No.                                  | Pin Name       | Type <sup>(1)</sup> | Pin Description <sup>(2)</sup>                                                                                                                                                 |  |
| 4                                                  | RXP            | I/O                 | Differential input in 10BASE-T/100BASE-TX MDI mode;                                                                                                                            |  |
| 5                                                  | RXN            | 1/0                 | Differential output in 10BASE-T/100BASE-TX MDIX mode.                                                                                                                          |  |
| 7                                                  | ТХР            | I/O                 | Differential output in 10BASE-T/100BASE-TX MDI mode;                                                                                                                           |  |
| 8                                                  | TXN            |                     | Differential input in 10BASE-T/100BASE-TX MDIX mode.                                                                                                                           |  |
| 2/12                                               | VCC33          | Р                   | 3.3V power supply input, it is recommended that 0.1uF parallel 10uF or 4.7uF ground capacitor be placed close to the chip.                                                     |  |
| 21/29/40/45/63                                     | VCCIO          | Р                   | For the power input of the I/O interface, it is recommended to place the 0.1uF ground capacitor close to the chip.                                                             |  |
| 19                                                 | VDDK           | Р                   | The external 1uF ground capacitor is placed close to the chip.                                                                                                                 |  |
| 28/43                                              | VDDK           | Р                   | The external 0.1uF ground capacitor is placed close to the chip.                                                                                                               |  |
| 3/9/13/18/20/37/<br>41/44                          | GND            | Р                   | Common ground.                                                                                                                                                                 |  |
| 1/6/14/15/16/17/<br>30/31/38/39/42/<br>51/53/54/64 | NC             | -                   | Reserved, suggested suspension.                                                                                                                                                |  |
| 10                                                 | XI             | Ι                   | The crystal oscillator input needs an external 25MHz crystal end or an external clock input with a built-in crystal oscillator matching capacitor.                             |  |
| 11                                                 | ХО             | О                   | The inverted output of the crystal oscillator needs to be externally connected to the other end of the 25MHz crystal, and a crystal oscillator matching capacitor is built in. |  |
| 22                                                 | GPIO0          | I/O                 | General-purpose input and output pin 0, configured as input by default.                                                                                                        |  |
| 23                                                 | GPIO1          | I/O                 | General-purpose input and output pin 1, configured as input by default.                                                                                                        |  |
| 24                                                 | GPIO2          | I/O                 | General-purpose input and output pin 2, configured as input by default.                                                                                                        |  |
| 25                                                 | GPIO3/RDY<br># | I/O                 | GPIO3: General-purpose input and output pin 3, configured as input by default.<br>RDY#: After CH395A is reset, the output is low.                                              |  |
| 26                                                 | RST            | 0                   | Power-on reset and external reset output, active high level.                                                                                                                   |  |
| 27                                                 | SEL            | I,PU                | Used as an interface configuration input during internal chip reset. For details on the specific configuration method, please refer to Chapter 6.1.                            |  |
| 32                                                 | GPIO4          | I/O                 | General-purpose input and output pin 4, configured as input by default.                                                                                                        |  |
| 33                                                 | GPIO5/A0       | I/O,PU              | GPIO5: General-purpose input and output pin 5, configured as input b<br>default.<br>A0: The address input of the parallel port is distinguished from th                        |  |
| 34                                                 | GPIO6          | I/O                 |                                                                                                                                                                                |  |
|                                                    |                |                     |                                                                                                                                                                                |  |

| 35 | GPIO7  | I/O    | General-purpose input and output pin 7, configured as input by default.                                                                                                                                                                                                                                      |  |
|----|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 36 | RSTI   | I,PU   | External reset input, active low, built-in pull-up resistor.                                                                                                                                                                                                                                                 |  |
| 46 | RD#    | I,PU   | The parallel port read gate input, active low, built-in pull-up resistor.                                                                                                                                                                                                                                    |  |
| 47 | WR#    | I,PU   | The parallel port write gate input, active low, built-in pull-up resistor.                                                                                                                                                                                                                                   |  |
| 49 | INT#   | 0      | Interrupt request output, active low.                                                                                                                                                                                                                                                                        |  |
| 50 | PCS#   | I,PU   | The chip select control input of parallel port, active low, built-in pull-up resistor.                                                                                                                                                                                                                       |  |
| 55 | D0     | I/O,PU | The 0th bit in the 8-bit bidirectional data bus with a parallel port, built-in pull-up resistor.                                                                                                                                                                                                             |  |
| 56 | D1     | I/O,PU | The 1st bit in the 8-bit bidirectional data bus with a parallel port, built-in pull-up resistor.                                                                                                                                                                                                             |  |
| 57 | RXD/D2 | I/O,PU | RXD: Serial data input of UART, built-in pull-up resistor;<br>D2: The 2nd bit in the 8-bit bidirectional data bus with a parallel port,<br>built-in pull-up resistor.                                                                                                                                        |  |
| 58 | TXD/D3 | I/O,PU | During the internal reset of the chip, the interface configuration inpinput, and the built-in pull-up resistor is used in Chapter 6.1. After chip reset is completed, use it as an interface pin.<br>TXD: Serial data output of UART.<br>D3: The 3rd bit in the 8-bit bidirectional data bus with a parallel |  |
| 59 | SCS/D4 | I/O,PU | built-in pull-up resistor.<br>SCS: Chip-select input SCS of the SPI interface, active low level,<br>built-in pull-up resistor.<br>D4: The 4th bit in the 8-bit bidirectional data bus with a parallel port,<br>built-in pull-up resistor.                                                                    |  |
| 60 | SCK/D5 | I/O,PU | SCK: Serial clock input SCK of SPI interface, built-in pull-up resistor.<br>D5: The 5th bit in the 8-bit bidirectional data bus with a parallel port<br>built-in pull-up resistor.                                                                                                                           |  |
| 61 | SDI/D6 | I/O,PU | SDI: Serial data input SDI of SPI interface, built-in pull-up resistor.<br>D6: The 6th bit in the 8-bit bidirectional data bus with a parallel port,<br>built-in pull-up resistor.                                                                                                                           |  |
| 62 | SDO/D7 | I/O,PU | SDO: Serial data output as SPI interface.<br>J D7: The 7th bit in the 8-bit bidirectional data bus with a parallel por<br>built-in pull-up resistor.                                                                                                                                                         |  |
| 48 | ELINK# | О      | Network connection indicator LED output:<br>Low level indicates that Ethernet PHY is connected;<br>High level indicates that Ethernet PHY is not connected.                                                                                                                                                  |  |
| 52 | EACT#  | 0      | Carrier induction indicates LED output:<br>LED flashing indicates carrier induction signal.                                                                                                                                                                                                                  |  |

*Note 1: Table abbreviation explanation:* 

I = Input; O = Output; I/O = Input/Output;

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

Note 2: The specific function of the CH395A's alternate pins depends on the currently selected interface mode. When the alternate pin is used for the interface function, its GPIO function will be occupied, resulting in its GPIO function being invalid and the corresponding bit in the GPIO register having no practical meaning.

# 4.3 CH395P Pin Definition

| CH395P<br>Pin No.                                                                                                                                                                                                                                                 | Pin Name | Type <sup>(1)</sup> | Pin Description                                                                                                                                                                |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 10                                                                                                                                                                                                                                                                | RXP      |                     | Differential input in 10BASE-T/100BASE-TX MDI mode;                                                                                                                            |  |  |  |  |
| 11                                                                                                                                                                                                                                                                | RXN      | I/O                 | Differential output in 10BASE-T/100BASE-TX MDIX mode.                                                                                                                          |  |  |  |  |
| 14                                                                                                                                                                                                                                                                | TXP      |                     | Differential output in 10BASE-T/100BASE-TX MDI mode;                                                                                                                           |  |  |  |  |
| 15                                                                                                                                                                                                                                                                | TXN      | I/O                 | Differential input in 10BASE-T/100BASE-TX MDIX mode.                                                                                                                           |  |  |  |  |
| 7/21                                                                                                                                                                                                                                                              | VCC33    | Р                   | 3.3V power supply input, it is recommended to place 0.1uF parallel<br>10uF or 4.7uF ground capacitor close to the core.                                                        |  |  |  |  |
| 39/56/70/83/101<br>/122                                                                                                                                                                                                                                           | VCCIO    | Р                   | For the power input of I/O interface, it is recommended to place 0.1uF capacitance to ground close to the chip.                                                                |  |  |  |  |
| 28                                                                                                                                                                                                                                                                | VDDK     | Р                   | The external 1uF ground capacitor is placed close to the chip.                                                                                                                 |  |  |  |  |
| 54/82                                                                                                                                                                                                                                                             | VDDK     | Р                   | The external 0.1uF ground capacitor is placed close to the chip.                                                                                                               |  |  |  |  |
| 2/9/16/17/22/27/<br>29/55/64/71/109                                                                                                                                                                                                                               | GND      | Р                   | Common ground.                                                                                                                                                                 |  |  |  |  |
| 1/3/4/5/6/8/12/1<br>3/18/23/24/25/2<br>6/30/31/32/33/3<br>4/35/36/37/38/4<br>0/41/42/43/44/4<br>5/46/47/57/58/6<br>5/66/67/68/69/7<br>2/73/74/75/76/7<br>7/78/79/80/81/8<br>4/85/86/87/88/8<br>9/90/91/92/93/9<br>5/96/97/102/103<br>/105/108/110/11<br>1/127/128 | NC       | -                   | Reserved, suggested suspension.                                                                                                                                                |  |  |  |  |
| 19                                                                                                                                                                                                                                                                | XI       | Ι                   | The crystal oscillator input needs an external 25MHz crystal end or an external clock input with a built-in crystal oscillator matching capacitor.                             |  |  |  |  |
| 20                                                                                                                                                                                                                                                                | ХО       | О                   | The inverted output of the crystal oscillator needs to be externally connected to the other end of the 25MHz crystal, and a crystal oscillator matching capacitor is built in. |  |  |  |  |
| 48                                                                                                                                                                                                                                                                | GPIO0    | I/O                 | General-purpose input and output pin 0, configured as input by default.                                                                                                        |  |  |  |  |
| 49                                                                                                                                                                                                                                                                | GPIO1    | I/O                 | General-purpose input and output pin 1, configured as input by default.                                                                                                        |  |  |  |  |
| 50                                                                                                                                                                                                                                                                | GPIO2    | I/O                 | General-purpose input and output pin 2, configured as input by default.                                                                                                        |  |  |  |  |

|         |           |        | GPIO3: General-purpose input and output pin 3, configured as input          |  |  |  |
|---------|-----------|--------|-----------------------------------------------------------------------------|--|--|--|
| 51      | GPIO3/RDY | I/O    | by default.                                                                 |  |  |  |
| 51      | #         |        | RDY#: After CH395P is reset, the output is low.                             |  |  |  |
| 52      | RST       | 0      | Power-on reset and external reset output, active high level.                |  |  |  |
| 52      | KST       |        | Used as an interface configuration input during internal chip reset. For    |  |  |  |
| 53      | SEL       | I,PU   | details on the specific configuration method, please refer to Chapter       |  |  |  |
| 55      | SEE       | 1,1 0  | 6.1.                                                                        |  |  |  |
|         |           |        | General-purpose input and output pin 4, configured as input by              |  |  |  |
| 59      | GPIO4     | I/O    | default.                                                                    |  |  |  |
| 60      | GPIO5     | I/O    | General-purpose input and output pin 5, configured as input by              |  |  |  |
| 00      |           |        | default.                                                                    |  |  |  |
| 61      | GPIO6     | I/O    | General-purpose input and output pin 6, configured as input by              |  |  |  |
|         |           |        | default.                                                                    |  |  |  |
| 62      | GPIO7     | I/O    | General-purpose input and output pin 7, configured as input by              |  |  |  |
|         |           |        | default.                                                                    |  |  |  |
| 63      | RSTI      | I,PU   | External reset input, active low, built-in pull-up resistor.                |  |  |  |
| 98      | INT#      | 0      | Interrupt request output, active low.                                       |  |  |  |
|         | A0        | I,PU   | Address input of parallel port, distinguishing command port from data       |  |  |  |
| 99      |           |        | port, built-in pull-up resistor;                                            |  |  |  |
|         |           |        | When A0=1, the command can be written, and when A0=0, the data              |  |  |  |
|         |           |        | can be read and written.                                                    |  |  |  |
| 100     | PCS#      | I,PU   | Chip selection control input of parallel port, active low, built-in         |  |  |  |
|         |           |        | pull-up resistor.                                                           |  |  |  |
| 106     | RD#       | I,PU   | Read strobe input of parallel port, active low, built-in pull-up resistor.  |  |  |  |
| 107     | WR#       | I,PU   | Write strobe input of parallel port, active low, built-in pull-up resistor. |  |  |  |
| 112     | RXD       | I,PU   | Serial data input of UART with built-in pull-up resistor.                   |  |  |  |
|         |           |        | During the internal reset of the chip, the input is configured for the      |  |  |  |
|         |           |        | interface, and the pull-up resistor is built in. For the configuration      |  |  |  |
| 113     | TXD       | I/O    | method, please refer to Chapter 6.1.                                        |  |  |  |
|         |           |        | After the chip reset is completed, it is the serial data output of          |  |  |  |
|         |           |        | asynchronous serial port.                                                   |  |  |  |
| 114     | SCS       | I,PU   | Chip selection input of SPI interface, active low, built-in pull-up         |  |  |  |
|         |           | -,     | resistor.                                                                   |  |  |  |
| 115     | SCK       | I,PU   | Serial clock input of SPI interface, built-in pull-up resistor.             |  |  |  |
| 116     | SDI       | I,PU   | Serial data input of SPI interface, built-in pull-up resistor.              |  |  |  |
| 117     | SDO       | 0      | Serial data output of SPI interface.                                        |  |  |  |
| 118~121 | D0 ~ D7   | I/O,PU | PU Parallel port 8-bit bidirectional data bus, built-in pull-up resistor.   |  |  |  |
| 123~126 |           |        |                                                                             |  |  |  |
|         |           |        | Network connection indicator LED output:                                    |  |  |  |
| 94      | ELINK#    | 0      | Low level indicates that Ethernet PHY is connected;                         |  |  |  |
|         |           |        | High level indicates that Ethernet PHY is not connected.                    |  |  |  |
| 104     | EACT#     | Ο      | Carrier induction indicates LED output:                                     |  |  |  |
|         | EAU1#     |        | LED flashing indicates carrier induction signal.                            |  |  |  |

Note 1: Table abbreviation explanation:

*I* = *Input; O* = *Output; I/O* = *Input/Output; P* = *Power supply; PU* = *Built-in pull-up resistor.* 

## 5. Command

The data in this datasheet, the suffix B or b is a binary number, and the suffix H is a hexadecimal number, otherwise it is a decimal number.

The double-word data with the lower byte in front (Little-Endian) (32 bits in total) refers to: first the lowest byte (bits 7 to 0), then the lower byte (bits 15 to 8), then the higher byte (bits 23 to 16), and finally the highest byte (bits 31 to 24).

A data stream refers to a data block composed of several consecutive bytes, with a minimum total length of 0.

The numbers in the brackets of the input data and output data in the following table are the number of bytes of the parameter, and if there is no bracket, the default is 1 byte.

The MCU referred to in this datasheet is basically suitable for DSP or MCU/MPU/SCM, etc.

Socket Pair contains quadruples of source IP, source port, destination IP and destination port, which can uniquely determine the 2 connections in the Internet. This manual is referred to as Socket. CH395 can provide 8 Sockets at the same time, and their index values are 0, 1, 2, 3, 4, 5, 6, and 7 respectively.

The IP and MAC addresses agreed upon in this manual may differ from some documents for convenience only:

If the IP address is 192.168.1.2, where 192 is the lowest byte and 2 is the highest byte. This article says (IP) low bytes are in front.

If the MAC address is 00.01.02.03.04.05, 00 is the lowest byte and 05 is the highest byte. This paper calls (MAC) low byte first.

In this datasheet, all commands containing IP address input or output are in byte order with IP low byte first.

In this datasheet, all commands containing MAC address input or output are in byte order with MAC low byte first.

| Code | Command name CMD_           | Input data                | Output data                    | Command purpose                                 |
|------|-----------------------------|---------------------------|--------------------------------|-------------------------------------------------|
| 01H  | GET_IC_VER                  |                           | Version number                 | Get the chip and firmware version               |
| 02H  | SET_BAUDRATE                | Baud rate coefficient (3) | Operating state                | Set the serial port communication baud rate     |
| 03H  | ENTER_SLEEP                 |                           |                                | Enter low-power sleep suspend state             |
| 05H  | RESET_ALL                   |                           | (Wait 15ms)                    | Perform a hardware reset                        |
| 06H  | CHECK_EXIST                 | Any data                  | Bitwise invert                 | Test communication interface and working status |
| 19H  | GET_GLOB_INT_STATUS<br>_ALL |                           | Global interrupt<br>status (2) | Get global interrupt status                     |
| 20H  | SET_PHY                     | PHY connection<br>method  |                                | Set the PHY connection method                   |
| 21H  | SET_MAC_ADDR                | MAC address (6)           |                                | Set MAC address                                 |
| 22H  | SET_IP_ADDR                 | IP address (4)            |                                | Set IP address                                  |

Table 5-1 Command list

| 23H   | SET GWIP ADDR            | Gateway address (4)  |                            | Set the gateway IP address                             |
|-------|--------------------------|----------------------|----------------------------|--------------------------------------------------------|
| 24H   | SET MASK ADDR            | Subnet mask (4)      |                            | Set subnet mask                                        |
| 2.111 |                          | Filter mode          |                            |                                                        |
| 25H   | SET MAC FILT             | HASH0(4)             | -                          | Set MAC filtering mode                                 |
| 2311  |                          | HASH1(4)             | -                          |                                                        |
| 26H   | GET_PHY_STATUS           |                      | PHY status                 | Get PHY status                                         |
| 27H   | INIT_CH395               |                      |                            | Initialize CH395 chip                                  |
| 2011  |                          |                      | Unreachable                | Get unreachable IP, port and                           |
| 28H   | GET_UNREACH_IPPORT       |                      | information (8)            | protocol                                               |
| 29H   | GET_GLOB_INT_STATUS      |                      | Global interrupt<br>status | Get global interrupt status                            |
| 2AH   | SET_RETRAN_COUNT         | Retry times          |                            | Set retry number, up to 20 times                       |
| 2BH   | SET_RETRAN_PERIOD        | Retry cycle (2)      |                            | Set retry period, up to 1000ms                         |
| 2CH   | GET_CMD_STATUS           |                      | Command execution status   | Get command execution status                           |
| 2DH   | GET_REMOT_IPP_SN         | Socket index         | IP and port (6)            | Get the IP and port of the remote<br>end (destination) |
| 2EH   | CLEAR_RECV_BUF_SN        | Socket index         |                            | Clear the receive buffer of Socket                     |
| 2FH   | GET_SOCKET_STATUS_S<br>N | Socket index         | Socket status              | Get Socket status                                      |
| 30H   | GET_INT_STATUS_SN        | Socket index         | Socket interrupt           | Get Socket interrupt status                            |
| 2111  | OFT ID ADDD ON           | Socket index         |                            | Set destination IP address of                          |
| 31H   | SET_IP_ADDR_SN           | Destination IP (4)   |                            | Socket.                                                |
| 32Н   | SET DES DODT SN          | Socket index         |                            | Set destination port address of                        |
| 3211  | SET_DES_PORT_SN          | Destination port (2) |                            | Socket.                                                |
| 33H   | SET SOUR PORT SN         | Socket index         |                            | Set source port of Socket                              |
| 5511  | SEI_SOUK_FORI_SN         | Source port (2)      |                            | Set source port of Socket                              |
| 34H   | SET PROTO TYPE SN        | Socket index         | _                          | Set operation mode of Socket                           |
| 5711  | SET_IKOTO_ITTE_SK        | Protocol type        |                            | Set operation mode of Socket                           |
| 35H   | OPEN_SOCKET_SN           | Socket index         |                            | Open Socket                                            |
| 36H   | TCP_LISTEN_SN            | Socket index         |                            | Enable Socket listening                                |
| 37H   | TCP_CONNECT_SN           | Socket index         |                            | Enable Socket connection                               |
| 38H   | TCP_DISCONNECT_SN        | Socket index         |                            | Disconnect the TCP connection of<br>Socket             |
|       |                          | Socket index         |                            |                                                        |
| 39H   | WRITE_SEND_BUF_SN        | Length (2)           |                            | Send buffer write data to Socket                       |
|       |                          | Data flow (N)        |                            |                                                        |
| 3BH   | GET_RECV_LEN_SN          | Socket index         | Length (2)                 | Gets Socket received data length                       |
| 3CH   | READ RECV BUF SN         | Socket index         | Data flow (N)              | Receive data from Socket receive                       |
|       |                          | Length (2)           |                            | buffer                                                 |
| 3DH   | CLOSE_SOCKET_SN          | Socket index         |                            | Disable Socket                                         |
| 3EH   | SET IPRAW PRO SN         | Socket index         |                            | Set the protocol field of the IP                       |
|       |                          | IP protocol field    |                            | packet of Socket.                                      |

| 3FH   | PING_ENABLE                     | Enable flag            |                     | PING enable                      |
|-------|---------------------------------|------------------------|---------------------|----------------------------------|
| 40H   | GET_MAC_ADDR                    |                        | MAC address (6)     | Get MAC address                  |
| 41H   | DHCP ENABLE                     | Enable flag            |                     | Start (Stop) DHCP                |
| 42H   | GET_DHCP_STATUS                 |                        | DHCP status         | Get DHCP status                  |
| 4211  |                                 |                        | IP and other        | Get IP, MASK, DNS and other      |
| 43H   | GET_IP_INF                      |                        | information         | information.                     |
|       |                                 | ARP retransmission     |                     |                                  |
| 4 411 |                                 | period                 |                     | Set the ARP retransmission cycle |
| 44H   | SET_ARP                         | ARP retransmission     |                     | and times.                       |
|       |                                 | number                 |                     |                                  |
| 50H   | SET_TCP_MSS                     | TCP MSS (2)            |                     | Set TCP MSS                      |
| 51H   | SET_TTL                         | TTL                    |                     | Set TTL value, up to 128.        |
|       |                                 | Socket index           |                     |                                  |
| 52H   | SET_RECV_BUF                    | Start block address    |                     | Set Socket receive buffer        |
|       |                                 | Block number           |                     |                                  |
|       |                                 | Socket index           |                     |                                  |
| 53H   | SET_SEND_BUF                    | Start block address    |                     | Set Socket send buffer           |
|       |                                 | Block number           |                     |                                  |
| 55H   | SET_FUN_PARA                    | Function parameter (4) |                     | Set functional parameter         |
| 56H   | SET_KEEPALIVE_IDLE              | 4-byte time parameter  |                     | Set KEEPALIVE idle time          |
| 57H   | SET_KEEPALIVE_INTVL             | 4-byte time parameter  |                     | Set KEEPALIVE timeout            |
| 58H   | SET KEEPALIVE CNT               | Retry times            |                     | Set the number of KEEPALIVE      |
| 5611  | SEI_KEEIALIVE_CIVI              | iter y times           |                     | timeout retries                  |
| 59H   | SET_KEEPALIVE_SN                | Socket index           |                     | Set Socket KEEPALIVE             |
| 5711  |                                 | Configuration          |                     | Set Socket KLEI ALI V L          |
| E9H   | EEPROM_ERASE                    |                        |                     | Erase EEPROM                     |
|       |                                 | EEPROM address (2)     |                     |                                  |
| EAH   | EEPROM_WRITE                    | Length                 |                     | Write EEPROM                     |
|       |                                 | Data flow (N)          |                     |                                  |
| EBH   | EEPROM READ                     | EEPROM address (2)     | Data flow (N)       | Read EEPROM                      |
|       |                                 | Length                 | Data flow (N)       | KCau EEF KOW                     |
| ECH   | READ_GPIO_REG                   | GPIP0 register address | GPI0 register value | Read GPIO register               |
| FDH   | WRITE GDIO REG                  | GPIP0 register address |                     | Write GPIO register              |
|       | EDH WRITE_GPIO_REG GPIP0 regist |                        |                     | white of 10 register             |

Commands in the shaded part of the table usually need to be executed for a certain period of time and the execution status of the command is queried. The MCU can obtain the status through GET\_CMD\_STATUS (refer to CH395INC.H for the definition of status).

## 5.1 CMD\_GET\_IC\_VER

This command is used to obtain the chip and firmware version, and the returned 1 byte data is the version number.

# 5.2 CMD\_SET\_BAUDRATE

This command is used to set the baud rate of serial communication of CH395. When CH395 works in serial communication mode, the default communication baud rate after reset is set by the level combination of SDO,

SDI and SCK pins (refer to Section 6.3 of this datasheet), and the default communication baud rate is 9600bps when these pins are suspended. If the MCU supports high communication speed, the baud rate of serial communication can be dynamically adjusted by this command. This command needs to input three data, namely baud rate coefficient 0, baud rate coefficient 1 and baud rate coefficient 2. The following table shows the corresponding relationship with baud rate.

Table 5-2 Baud rate

| Table 5-2 Daud Tale  |                         |                         |                                          |  |
|----------------------|-------------------------|-------------------------|------------------------------------------|--|
| Baud rate            | Baud rate               | Baud rate               | Serial port communication baud           |  |
| coefficient 2        | coefficient 1           | coefficient 0           | rate (bps)                               |  |
| 00H                  | 12H                     | СОН                     | 4800                                     |  |
| 00H                  | 25H                     | 80H                     | 9600                                     |  |
| 00H                  | 4BH                     | 00H                     | 19200                                    |  |
| 00H                  | 96H                     | 00H                     | 38400                                    |  |
| 00H                  | E1H                     | 00H                     | 57600                                    |  |
| 01H                  | 2CH                     | 00H                     | 76800                                    |  |
| 01H                  | С2Н                     | 00H                     | 115200                                   |  |
| 07H                  | 08H                     | 00H                     | 460800                                   |  |
| 0EH                  | 10H                     | 00H                     | 921600                                   |  |
| 0FH                  | 42H                     | 40H                     | 1M                                       |  |
| 1EH                  | 84H                     | 80H                     | 2M                                       |  |
| 4CH                  | 4BH                     | 40H                     | 5M                                       |  |
| 98H                  | 96H                     | 80H                     | 10M                                      |  |
| Calculation formula: |                         |                         |                                          |  |
| BaudRate = (Baud ra  | te coefficient 2<<16) - | + (Baud rate coefficien | nt $1 \le 8$ ) + Baud rate coefficient 0 |  |

Set the execution time of the serial communication baud rate configuration command by default to TE8 (the minimum is 1ms, see Table 7-4). After completion, CH395 will output the operating state at the new baud rate. The MCU needs to adjust its own baud rate as soon as possible within TE8 time and wait for CH395 to answer.

### 5.3 CMD\_ENTER\_SLEEP

This command causes the CH395 chip to enter a low-power sleep suspend state. Pull the CH395RXD pin down by 35us or above in serial port mode, and pull the SCS or PCS# chip select pin down by 35us or above in SPI or parallel port mode to remove the CH395 from the low power state. Therefore, after the MCU issues the CMD\_ENTER\_SLEEP command, the SCS or PCS# chip select should be invalid immediately.

The MAC and PHY that enter sleep state CH395 will enter power-down mode and disconnect the Ethernet connection.

After waking up from sleep mode, the CH395 takes about 4ms to complete the wake-up process. During this wake-up phase, CH395 will not parse or respond to any received command code. Therefore, do not send any command code to CH395 during CH395 being awakened. It is recommended that the user wake up for 4ms before operating on CH395.

## 5.4 CMD\_RESET\_ALL

This command causes CH395 to perform a hardware reset. Normally, hardware reset is completed within 15ms.

#### 5.5 CMD\_CHECK\_EXIST

This command is used to test the communication interface and working status to check whether the CH395 is working properly. This command requires input of 1 byte of data, which can be any data. If CH395 works normally, then the output data of CH395 is bitwise inverse of the input data. For example, if the input data is 57H, the output data is A8H.

### 5.6 CMD\_SET\_PHY

This command uses the connection method to set the CH395 Ethernet PHY. The default is automatic negotiation method. This command requires inputting 1 byte of data, which is the connection method code:

Disconnect PHY when connection mode code is 01H;

PHY is 10M full duplex when the connection mode code is 02H;

PHY is 10M half-duplex when the connection mode code is 04H;

PHY is 100M full-duplex When the connection mode code is 08H;

PHY is 100M half-duplex when the connection mode code is 10H;

PHY auto-negotiation when the connection mode code is 20H.

After receiving this command, CH395 will reset the MAC and PHY and reconnect according to the newly set connection mode. If Ethernet is connected, it will be disconnected and reconnected.

#### 5.7 CMD\_SET\_MAC\_ADDR

This command is used to set the MAC address of CH395. You need to enter a 6-byte MAC, and the low byte of the MAC address comes first. The CH395 chip will store the MAC address in the internal EEPROM. This command takes about 30us to complete.

The CH395 chip has been programmed with the MAC address assigned by IEEE when it leaves the factory. Please do not set the MAC address unless it is necessary.

#### 5.8 CMD\_SET\_IP\_ADDR

This command is used to set the IP address of CH395. You need to enter a 4-byte IP address, with the IP low byte first. In this manual, all commands containing IP input or output are in the byte order of IP low byte first, which will not be explained below.

#### 5.9 CMD\_SET\_GWIP\_ADDR

This command is used to set the gateway address of CH395. You need to enter a 4-byte IP address.

#### 5.10 CMD\_SET\_MASK\_ADDR

This command is used to set the subnet mask of CH395. This command requires a 4-byte mask. The default value is 255.255.255.0, which can be left unchecked.

#### 5.11 CMD SET MAC FILT

This command is used to set the MAC filtering mode. The MAC can set multiple filtering modes. This command needs to input 9 bytes of data, the first byte is filter mode, and the meaning of each bit of this data is as follows:

| Bit   | Name | Description |  |
|-------|------|-------------|--|
| [5:7] | -    | Reserved    |  |

| 4 | SEND_ENABLE   | Send enable               |
|---|---------------|---------------------------|
| 3 | RECV_ENABLE   | Receive enable            |
| 2 | RECV_MULTIPKT | Receive multicast packets |
| 1 | RECV_ALL      | Receive all data          |
| 0 | RECV_BROADPKT | Receive broadcast packet  |

The above bits are 1 for enable, and 0 for disable. After CH395 is reset, RECV\_BROADPKT, RECV\_ENABLE and SEND\_ENABLE are enabled by default.

The following table shows what you mean:

| <b>m</b> 1 1 |     | 1110    | 01. 1     |         |
|--------------|-----|---------|-----------|---------|
| Table        | 5-4 | MAC     | filtering | meaning |
| 10010        | • • | 1.11.10 |           |         |

| RECV_ENABLE | RECV_ALL | RECV_BROADPKT             | RECV_MULTIPKT             | Description                                                                                                                                     |
|-------------|----------|---------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | 0        | 0                         | 0                         | Receive packets matching the                                                                                                                    |
|             | -        | -                         | -                         | MAC address                                                                                                                                     |
| 1           | 1        | Х                         | Х                         | Receive all packets                                                                                                                             |
|             |          |                           |                           | Receive packets matching the                                                                                                                    |
| 1           | 0        | 1                         | 0                         | MAC address                                                                                                                                     |
|             |          |                           |                           | Receive broadcast packets                                                                                                                       |
|             |          |                           |                           | Receive packets matching the                                                                                                                    |
| 1           | 0        | 0 0                       | 1                         | MAC address                                                                                                                                     |
|             |          |                           |                           | Receive multicast packets                                                                                                                       |
|             |          |                           |                           | Receive packets matching the                                                                                                                    |
| 1           | 0        | 1                         | 1                         | Receive packets matching the   MAC address   Receive broadcast packets   Receive packets matching the   MAC address   Receive multicast packets |
|             | 1        |                           | Receive broadcast packets |                                                                                                                                                 |
|             |          | Receive multicast packets |                           |                                                                                                                                                 |
| 0           | Х        | X                         | Х                         | Prohibit receiving                                                                                                                              |

The 2nd to 5th bytes are HASH0 (Hash Table 0), and the 6th to 9th bytes are Hash H1 (Hash Table 1). HASH0 and Hash H1 are only valid when multicast is turned on.

HASH0 and HASH1 together form a 64-bit HASH table, with 0-31 bits being HASH0 and 32-63 bits being HASH1.

HASH table calculation method: calculate a 32-bit CRC value for the multicast address by using standard Ethernet redundancy check (CRC32), use the upper 6 bits of this CRC value as the index value, and write 1 to the corresponding bit of the HASH table. For example, if the upper 6 bits of the CRC value calculated by the multicast address are 32, the 0 th bit of HASH1 should be written as 1.

### 5.12 CMD\_GET\_PHY\_STATUS

This command is used to obtain the connection status of PHY. After receiving this command, CH395 will query the current connection status of PHY and output a 1-byte PHY connection status code:

A connection status code of 01H indicates that the PHY connection is disconnected;

A connection status code of 02H indicates that the PHY connection is 10M full-duplex;

A connection status code of 04H indicates that the PHY connection is 10M half-duplex;

A connection status code of 08H indicates that the PHY connection is 100M full-duplex;

A connection status code of 10H indicates that the PHY connection is 100M half-duplex.

## 5.13 CMD\_INIT\_CH395

This command is used to initialize CH395, including initializing the MAC, PHY and TCP/IP protocol stack of CH395. This command takes about 5ms to complete. MCU can send GET\_CMD\_STATUS to inquire whether the execution is completed and the execution status.

# 5.14 CMD\_GET\_UNREACH\_IPPORT

This command is used to obtain unreachable IP, port and protocol type. When an unreachable message is received, CH395 will generate an unreachable interrupt. MCU can use this command to obtain unreachable information. After receiving this command, CH395 will output 1-byte unreachable code, 1 byte protocol type, 2 bytes port number (low byte first) and 4 bytes IP in turn. MCU can judge whether the protocol is unreachable, the port is unreachable or the IP is unreachable according to the unreachable code. For unreachable codes, please refer to RFC792 (CH395INC.H defines four common unreachable codes).

# 5.15 CMD\_GET\_GLOB\_INT\_STATUS

This command is used to obtain the global interrupt status. After receiving this command, CH395 will output the global interrupt status of 1-byte. The global interrupt status is defined as follows:

| Bit | Name                 | Description                |  |  |  |
|-----|----------------------|----------------------------|--|--|--|
| 7   | GINT_STAT_SOCK3      | Socket3 interrupt          |  |  |  |
| 6   | GINT_STAT_SOCK2      | Socket2 interrupt          |  |  |  |
| 5   | GINT_STAT_SOCK1      | Socket1 interrupt          |  |  |  |
| 4   | GINT_STAT_SOCK0      | Socket0 interrupt          |  |  |  |
| 3   | GINT_STAT_DHCP       | DHCP interrupt             |  |  |  |
| 2   | GINT_STAT_PHY_CHANGE | PHY state change interrupt |  |  |  |
| 1   | GINT_STAT_IP_CONFLI  | IP conflict                |  |  |  |
| 0   | GINT_STAT_UNREACH    | Unreachable interrupt      |  |  |  |

Table 5-5 Global interrupt 1

- ① GINT\_STAT\_UNREACH: unreachable interrupt. When CH395 receives the ICMP unreachable interrupt message, it saves the IP address, port and protocol type of the unreachable IP packet in the unreachable information table, and then generates this interrupt. When the MCU receives this interrupt, it can send the GET\_UNREACH\_IPPORT command to obtain the unreachable information.
- ② Gint\_stat\_IP\_conf Li: IP conflict interrupt. This interrupt occurs when CH395 detects that its own IP address is the same as that of other network devices in the same network segment.
- ③ Gint\_stat\_phy\_change: PHY change is interrupted. This interrupt occurs when the PHY connection of CH395 changes, for example, the PHY state changes from the connected state to the disconnected state or from the disconnected state to the connected state. The MCU can send the GET\_PHY\_STATUS command to get the status of the current PHY connection.
- ④ Gint\_stat\_DHCP: DHCP interrupt. If the MCU enables the DHCP function of CH395, CH395 will generate this interrupt after DHCP succeeds or times out, and the MCU can send CMD\_GET\_DHCP\_STATUS command to obtain the DHCP status. If the status is 0, it means success, otherwise it means timeout failure.
- ⑤ Gint\_stat\_sock 0 ~ gint\_stat\_sock 3: socket interrupt. CH395 will generate this interrupt when there is an interrupt event in the Socket, and the MCU needs to send GET\_INT\_STATUS\_SN to get the interrupt status of the Socket. Please refer to the GET\_INT\_STATUS\_SN section.

After this command is executed, CH395 will set the INT# pin high and clear the global interrupt status.

### 5.16 CMD\_GET\_GLOB\_INT\_STATUS\_ALL

This command is used to obtain the global interrupt status. After receiving this command, CH395 will output the global interrupt status of 2 bytes. The global interrupt status is defined as follows:

| Bit     | Name                 | Description                |
|---------|----------------------|----------------------------|
| [12:15] | -                    | Reserved                   |
| 11      | GINT_STAT_SOCK7      | Socket7 interrupt          |
| 10      | GINT_STAT_SOCK6      | Socket6 interrupt          |
| 9       | GINT_STAT_SOCK5      | Socket5 interrupt          |
| 8       | GINT_STAT_SOCK4      | Socket4 interrupt          |
| 7       | GINT_STAT_SOCK3      | Socket3 interrupt          |
| 6       | GINT_STAT_SOCK2      | Socket2 interrupt          |
| 5       | GINT_STAT_SOCK1      | Socket1 interrupt          |
| 4       | GINT_STAT_SOCK0      | Socket0 interrupt          |
| 3       | GINT_STAT_DHCP       | DHCP interrupt             |
| 2       | GINT_STAT_PHY_CHANGE | PHY state change interrupt |
| 1       | GINT_STAT_IP_CONFLI  | IP conflict                |
| 0       | GINT_STAT_UNREACH    | Unreachable interrupt      |

| Table | 5-6 | Global | interrupt | 2 |
|-------|-----|--------|-----------|---|
|-------|-----|--------|-----------|---|

For bits 0-7, please refer to section 5.15.

Gint\_stat\_sock  $4 \sim \text{gint}_{\text{stat}_{\text{sock}}}$ ?: socket interrupt. CH395 will generate this interrupt when there is an interrupt event in the Socket, and the MCU needs to send GET\_INT\_STATUS\_SN to get the interrupt status of the Socket. Please refer to the GET\_INT\_STATUS\_SN section.

CH395 can obtain the interrupt status by 2 commands, CMD\_GET\_GLOB\_INT\_STATUS and CMD\_GET\_GLOB\_INT\_STATUS\_ALL. The former can only obtain the interrupt status of the lower 8 bits, and the latter can obtain all the interrupt status. Please pay attention to it when using it. Any version of the chip supports the command CMD\_GET\_GLOB\_INT\_STATUS. If the chip version number is greater than or equal to 0X44 and Socket4~Socke7 is used, only CMD\_GET\_GLOB\_INT\_STATUS\_ALL can be used. CMD\_GET\_GLOB\_INT\_STATUS\_ALL command is not supported if the chip version number is less than 0X44.

### 5.17 CMD\_SET\_RETRAN\_COUNT

This command is used to set the number of retries. You need to enter the number of retries of 1 byte, and the maximum allowable value is 20. If the input data is greater than 20, it will be treated as 20. The default number of retries is 12, and retries are only valid in TCP mode.

### 5.18 CMD\_SET\_RETRAN\_PERIOD

This command is used to set the retry cycle. You need to enter the cycle number of 2 bytes (low byte first) in ms, and the maximum allowable value is 1000. The total time of retry is N\*M, where n is the number of retries and m is the retry period. The default retry period is 500ms, and retry is only valid in TCP mode.

### 5.19 CMD\_SET\_RETRAN\_PERIOD

This command is used to obtain the status of command execution. CH395 will output 1 byte of data, which is the state of command execution. Command execution status is as follows:

| Code | Name              | Description                                         |
|------|-------------------|-----------------------------------------------------|
| 00H  | CH395_ERR_SUCCESS | Success                                             |
| 10H  | CH395_ERR_BUSY    | Busy, indicating that the command is being executed |
| 11H  | CH395_ERR_MEM     | Memory management error                             |
| 12H  | CH395_ERR_BUF     | Buffer error                                        |
| 13H  | CH395_ERR_TIMEOUT | Timeout                                             |
| 14H  | CH395_ERR_RTE     | Routing error                                       |
| 15H  | CH395_ERR_ABRT    | Connection aborted                                  |
| 16H  | CH395_ERR_RST     | Connection reset                                    |
| 17H  | CH395_ERR_CLSD    | Connection closed                                   |
| 18H  | CH395_ERR_CONN    | No connection                                       |
| 19H  | CH395_ERR_VAL     | Error value                                         |
| 1AH  | CH395_ERR_ARG     | Error parameters                                    |
| 1BH  | CH395_ERR_USE     | Has been used                                       |
| 1CH  | CH395_ERR_IF      | MAC error                                           |
| 1DH  | CH395_ERR_ISCONN  | Connected                                           |
| 20H  | CH395_ERR_OPEN    | Opened                                              |

Table 5-7 Command execution status

If the MCU receives CH395\_ERR\_BUSY, it means that CH395 is executing the command, and the MCU should delay for more than 2ms and send the CMD\_GET\_CMD\_STATUS command again to get the status.

Commands in the shaded part of the command code table need to send CMD\_GET\_CMD\_STATUS to get the execution status.

### 5.20 CMD\_GET\_REMOT\_IPP\_SN

This command is used to obtain the IP address and port number of the remote end. It needs to input a 1-byte Socket index value, and CH395 will output 4-byte IP address and 2-byte (low byte first) port number. After the Socket works in TCP Server mode and the connection is established, the MCU can obtain the remote IP address and port number through this command.

#### 5.21 CMD\_CLEAR\_RECV\_BUF\_SN

This command is used to empty the receive buffer of Socket, and a 1-byte Socket index value is required. Upon receiving this command, CH395 will clear the receiving length of this Socket, and the receiving pointer will point to the head of the buffer.

### 5.22 CMD\_GET\_SOCKET\_STATUS\_SN

This command is used to obtain the status of Socket, and it needs to input a Socket index value of 1 byte. CH395 will output a 2-byte status code after receiving this command.

The first status code is the status code of Socket, and the status code of Socket is defined as follows:

Table 5-8 Socket status code

| Code | Name          |
|------|---------------|
| 00H  | SOCKET_CLOSED |

05H SOCKET\_OPEN

The second status code is the status code of TCP, which is meaningful only when it is in TCP mode and has been turned on. The TCP status code is defined as follows:

| Code | Name            | Description                                        |
|------|-----------------|----------------------------------------------------|
| 00H  | TCP_CLOSED      | Closed                                             |
| 01H  | TCP_LISTEN      | Listen                                             |
| 02H  | TCP_SYN_SENT    | SYN send                                           |
| 03H  | TCP_SYN_RCVD    | SYN receive                                        |
| 04H  | TCP_ESTABLISHED | TCP connection establishment                       |
| 05H  | TCP_FIN_WAIT_1  | Active shutdown party sends FIN for the first time |
| 06H  | TCP_FIN_WAIT_2  | Active shutdown party receives ACK from FIN        |
| 07H  | TCP_CLOSE_WAIT  | Passive closing party receives FIN                 |
| 08H  | TCP_CLOSING     | Closing                                            |
| 09H  | TCP_LAST_ACK    | Passive shutdown party sends FIN                   |
| 0AH  | TCP_TIME_WAIT   | 2MLS waiting state                                 |

| Table : | 5-9 | TCP | status | code |
|---------|-----|-----|--------|------|
|---------|-----|-----|--------|------|

TCP states are all specified in the TCP/IP protocol. Please refer to the TCP/IP protocol for details. Only care about 'TCP\_CLOSED', 'TCP\_LISTEN' and 'TCP\_ESTABLISHED' in application. Other status chips will be automatically processed and updated.

### 5.23 CMD\_GET\_INT\_STATUS\_SN

This command is used to obtain the interrupt status of the Socket, and it is required to input a Socket index value of 1 byte. After receiving this command, CH395 will output an interrupt code of 1 byte of the Socket, and each bit of the interrupt code is defined as follows:

| Bit | Name                  | Description           |  |  |
|-----|-----------------------|-----------------------|--|--|
| 7   | -                     | Reserved              |  |  |
| 6   | SINT_STAT_TIM_OUT     | Timeout               |  |  |
| 5   | -                     | Reserved              |  |  |
| 4   | SINT_STAT_DISCONNECT  | TCP disconnect        |  |  |
| 3   | SINT_STAT_CONNECT     | TCP connect           |  |  |
| 2   | SINT_STAT_RECV        | Receive buffer is not |  |  |
|     |                       | empty                 |  |  |
| 1   | SINT_STAT_SEND_OK     | Send success          |  |  |
| 0   | SINT_STAT_SENBUF_FREE | Send buffer free      |  |  |

Table 5-10 Socket interrupt status

- SINT\_STAT\_SENBUF\_FREE, the sending buffer is idle. After the MCU writes data to the Socket sending buffer, CH395 will quickly copy the data to the internal protocol stack or MAC buffer to encapsulate the data. When the data is copied, this interrupt will occur, and the MCU can continue to write subsequent data to the sending buffer. After the MCU writes data to the Socket sending buffer once, it must wait until this interrupt occurs before writing the next data.
- ② SINT\_STAT\_SEND\_OK, interrupt of successful transmission. This interrupt is generated, indicating that the data packet was successfully transmitted. Sokcet will generate this interrupt every time a packet of data is

successfully transmitted. After the MCU writes data to the Socket buffer once, CH395 may be packaged into several data packets for transmission, so there may be several successful transmission interrupts.

- ③ SINT\_STAT\_CONNECT, TCP connection is broken, only valid in TCP mode. It shows that the TCP connection is successful, and the MCU must interrupt before data transmission can be carried out.
- ④ SINT\_STAT\_DISCONNECT, TCP connection disconnection interrupt, valid only in TCP mode, indicating that TCP connection is disconnected.
- <sup>(5)</sup> SINT\_STAT\_TIM\_OUT, in TCP mode, this interrupt will be generated when timeout occurs during TCP connection, disconnection, data transmission, etc. In IPRAW and UDP modes, this interrupt will also be generated when sending data fails.

After the interrupt of SINT\_STAT\_DISCONNECT and SINT\_STAT\_TIM\_OUT is generated, CH395 will make different actions according to whether the FUN\_PARA\_FLAG\_SOCKET\_CLOSE bit is 1 or 0. If FUN\_PARA\_FLAG\_SOCKET\_CLOSE is 0, when the above two interrupts are generated, CH395 will actively set the Socket state to the closed state and clear all related buffers. On the other hand, it will not do anything about the Socket status and related buffers, so as to facilitate the external MCU to read the residual data after TCP disconnection or timeout. When the external MCU reads the data, it must send a close command to close the Socket.

### 5.24 CMD\_SET\_IP\_ADDR\_SN

This command is used to set the Socket destination IP address. You need to enter a Socket index value of 1 byte and a destination IP address of 4 bytes. When the Socket works in IPRAW, UDP and TCP Client modes, the destination IP must be set before sending the CMD\_OPEN\_SOCKET\_SN command.

### 5.25 CMD\_SET\_DES\_PORT\_SN

This command is used to set the Socket destination port. You need to enter the Socket index value of 1 byte and the destination port of 2 bytes (the lower byte comes first). Socket works in UDP and TCPClient mode, and this value must be set.

### 5.26 CMD\_SET\_SOUR\_PORT\_SN

This command is used to set the Socket source port. You need to enter a Socket index value of 1 byte and a source port of 2 bytes (low byte first). 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.

### 5.27 CMD\_SET\_PROTO\_TYPE\_SN

This command is used to set the working mode of Socket, and it is required to input a Socket index value of 1 byte and a working mode of 1 byte. The working mode is defined as follows:

|                        |                    | 8                        |
|------------------------|--------------------|--------------------------|
| Code                   | Name               | Description              |
| 03H                    | PROTO_TYPE_TCP     | TCP mode                 |
| 02H                    | PROTO_TYPE_UDP     | UDP mode                 |
| 01H                    | PROTO TYPE MAC RAW | MAC original message     |
| 01H PROTO_TYPE_MAC_RAW | mode               |                          |
| 00H                    | PROTO_TYPE_IP_RAW  | IP original message mode |

| Table 5-11 | Socket wor | king mode |
|------------|------------|-----------|
|------------|------------|-----------|

This command must be executed before CMD\_OPEN\_SOCKET\_SN. For detailed steps, please refer to 9.2 Application Reference Steps.

### 5.28 CMD\_OPEN\_SOCKET\_SN

This command is used to open the Socket, which is a necessary step to use the Socket. You need to enter a Socket index value of 1 byte. After sending this command, the MCU should send GET\_CMD\_STATUS to query the execution status of the command. After opening the Socket in UDP, IPRAW and MACRAW modes and returning successfully, data transmission can be carried out. Before sending this command, necessary settings must be made for the destination IP, protocol type, source port and destination port. For detailed steps, please refer to 9.2 Application Reference Steps.

### 5.29 CMD\_TCP\_LISTEN\_SN

This command is only valid in TCP mode, enabling Socket to enter the listening mode, that is, TCP Server mode. You need to enter a 1-byte Socket index, and this command must be executed after OPEN\_SOCKET\_SN. After sending this command, the MCU should send GET\_CMD\_STATUS to inquire about the execution status of the command.

Under the TCP Server mode, the Socket will directly test the connection event until the connection is completed, and the SINT\_STAT\_CONNECT interrupt will be generated. Only one connection can be established per Socket. If a qualified connection event is received again, Socket will send TCP RESET to the remote end trying to connect.

### 5.30 CMD\_TCP\_CONNECT\_SN

This command is only valid in TCP mode. To enable Socket to enter the connection mode, that is, TCP Client mode, you need to enter a Socket index value of 1 byte. After sending this command, the MCU should send GET\_CMD\_STATUS to inquire about the execution status of the command.

After receiving this command, Socket will initiate a connection event, and after successful connection, it will generate a SINT\_STAT\_CONNECT interrupt. SINT\_STAT\_TIM\_OUT interrupt will be generated if there is an exception in the connection process or if the connection fails after a certain period of time. The MCU receives this interrupt, and if it needs to be connected again, it needs to reopen the Socket and perform TCP\_CONNECT\_SN.

### 5.31 CMD\_TCP\_DISCONNECT\_SN

This command is only valid in TCP mode. To disconnect the current TCP connection, you need to enter a 1-byte Socket index value. After sending this command, the MCU should send GET\_CMD\_STATUS to inquire about the execution status of the command. SINT\_STAT\_DISCONNECT interrupt will be generated after the current TCP is successfully disconnected.

### 5.32 CMD\_WRITE\_SEND\_BUF\_SN

This command is used to write data to the send buffer of Socket. It needs to input the Socket index value of 1 byte, the length of 2 bytes (low byte first) and several bytes of data stream. The length of the input data must not be greater than the size of the send buffer, but in MACRAW mode, the maximum length of the input data can only be 1514, and the redundant data will be discarded. When the external MCU finishes writing the data, CH395 will package the data packet according to the working mode of Socket, and then send it. Before the MCU receives SINT\_STAT\_SENBUF\_FREE, it is not allowed to write data to the Socket sending buffer again.

### 5.33 CMD\_GET\_RECV\_LEN\_SN

This command is used to obtain the effective data length of the current receiving buffer. It needs to input a Socket index value of 1 byte. After receiving this command, CH395 outputs a length of 2 bytes (the low byte comes first).

## 5.34 CMD\_READ\_RECV\_BUF\_SN

This command is used to read data from the Socket receiving buffer. It needs to input a Socket index value of 1 byte, and the length of 2 bytes (the lower byte comes first). CH395 will output several bytes of data stream according to the length value. In practical application, you can send the RECV\_LEN\_SN command first to obtain the actual effective length of the current buffer. The length of the read data can be less than the actual effective data length of the buffer, and the unread data still remains in the receiving buffer, and the MCU can continue reading through this command.

In MACRAW mode, the processing methods are different. In MACRAW mode, the receiving buffer is a frame buffer, and only one frame of Ethernet data can be cached. After processing the command READ\_RECV\_BUF\_SN, CH395 will clear all the receiving buffers of Socket0, so the MCU should read all the valid data of the buffer at one time.

## 5.35 CMD\_CLOSE\_SOCKET\_SN

This command is used to close the Socket. You need to enter a Socket index value of 1 byte. After closing the Socket, the receiving and sending buffer of the Socket is emptied, but the configuration information is still retained. You only need to open the Socket again the next time you use the Socket.

In TCP mode, CH395 will automatically disconnect the TCP connection before closing the Socket.

### 5.36 CMD\_SET\_IPRAW\_PRO\_SN

This command is valid only in IPRAW mode and requires the entry of a 1-byte socket index value, and a 1-byte protocol code for the IP Packet Protocol field. This command must be executed before OPEN\_SOCKET\_SN.

If multiple Socket adopt IPRAW mode, the protocol code shall not be reused. For example, if Socket 0 and Socket 1 both adopt IPRAW mode, the protocol codes of the two sockets shall not be the same, otherwise it may lead to failure when opening the socket.

IPRAW data processing priority is higher than UDP and TCP, so the protocol code must not be the same as other Socket. For example, Socket 0 adopts IPRAW mode and the protocol code is 17(UDP protocol). Socket 1 adopts UDP mode. This may cause the data of Socket 1 to be received by Socket 0.

## 5.37 CMD\_PING\_ENABLE

This command is used to turn PING on or off, and you need to enter a 1-byte flag code. A flag code of 1 means to turn PING on, and a flag code of 0 means to turn PING off.

### 5.38 CMD\_GET\_MAC\_ADDR

This command is used to obtain the MAC address. After receiving this command, CH395 will output a 6-byte MAC address.

### 5.39 CMD\_DHCP\_ENABLE

This command is used to start or stop DHCP. You need to enter a 1-byte flag code. If the flag code is 1, it means to start DHCP. If it is 0, it means to close DHCP. Before starting DHCP, you must initialize CH395.

After starting DHCP, CH395 will broadcast DHCPDISCOVER message to the network, which is used to discover DHCP Server, apply for address and other configuration parameters after finding DHCP Server, and then generate GINT\_STAT\_DHCP interrupt. After this interrupt is generated, the MCU can send the command GET\_DHCP\_STATUS to get the status of DHCP. If the status is 0, it means success, then the MCU can send the command GET\_IP\_INF to obtain information such as IP and MASK. If the status is 1, it indicates an error, which is usually caused by timeout, for example, DHCP Server is not found.

DHCP is always in working state after it is started, unless it receives a command from the MCU to turn off DHCP. During this process, if DHCP Server reassigns a configuration to CH395, and this configuration is different from the original one, CH395 will still generate an interrupt.

After the timeout interrupt occurs, if the DHCP Server is not found, CH395 will continue to send DHCPDISCOVER messages with an interval of about 16 seconds.

This command takes about 1ms to execute, and the MCU can send GET\_CMD\_STATUS to inquire whether it has been executed and its execution status.

## 5.40 CMD\_GET\_DHCP\_STATUS

This command is used to obtain the status of DHCP. Generally, after the MCU receives the interrupt, it sends this command to obtain the execution status of DHCP. After receiving this command, CH395 outputs the DHCP status code. There are two status codes, namely 0 and 1, which are as follows:

If the status is 0, it means success, then the MCU can send the command GET\_IP\_INF to obtain information such as IP and MASK.

If the status is 1, it indicates an error, which is usually caused by timeout, for example, DHCP Server is not found.

### 5.41 CMD\_GET\_IP\_INF

This command is used to obtain information such as IP, GatewayIP, MASK, DNS, etc. After receiving this command, CH395 will output 20 bytes of data in turn, namely: 4 bytes of IP address, 4 bytes of gateway IP, 4 bytes of subnet mask, 4 bytes of DNS1 (primary DNS) and 4 bytes of DNS2 (secondary DNS).

After DHCP, you can send this command to get the information of the current CH395. If some configurations are not obtained in DHCP, the configuration is 0. For example, DNS may not be allocated when DHCP is used in local area network. When this command is sent to obtain configuration information, DNS1 and DNS2 are all 0.

### 5.42 CMD\_SET\_ARP

This command is used to set the ARP retransmission cycle and times. You need to enter a 1-byte retransmission cycle n (100ms) and a 1-byte retransmission number m (times). CH395F, CH395A and CH395P support this command.

When CH395 sends data to the target device, it will search the APR cache table to find the MAC address of the target device. If it is not stored in the cache table, CH395 will send an ARP request to obtain the MAC address of

the target device. If the target device does not respond, CH395 will retransmit according to the set retransmission period n (100ms), with the maximum retransmission time of m times.

By default, the number of retransmissions is 3 (times) and the retransmission period is 10 (that is, 1 second). If the ARP retransmission number or period is set to 0, the default value will be used. If the number of retransmissions is set to 255, it means that CH395 will retransmit indefinitely until the MAC address of the target device is successfully obtained.

This command should be set after initializing CH395.

### 5.43 CMD\_SET\_TCP\_MSS

This command is used to set TCPMSS, and a 2-byte TCPMSS value is required, with a maximum value of 1460 and a minimum value of 60. This value should be set before initializing CH395, and it is not allowed to be set after initialization.

#### 5.44 CMD\_SET\_TTL

This command is used to set the TTL of Socket, and it needs to input a 1-byte Socket index and a 1-byte TTL value. It should be set after opening the Socket, and the maximum value is 128. This command does not take effect when Socket is in TCP Sever mode.

### 5.45 CMD SET RECV BUF

This command is used to set the receiving buffer of Socket, and 3 bytes of data are required, the first byte is the Socket index, the second byte is the starting block of the buffer, and the third byte is the number of blocks.

| Block 0 Block 1 Block 2 Block 46 Block 47 |         |         | -       | - |          |          |
|-------------------------------------------|---------|---------|---------|---|----------|----------|
|                                           | Block 0 | Block 1 | Block 2 |   | Block 46 | Block 47 |

The internal buffer structure of CH395 is shown above, which consists of 48 blocks, each of which is 512 bytes long. MCU can freely allocate the size of each Socket receiving buffer. The allocation of buffer after initialization of CH395 is as follows:

| Socket | Buffer         | Start block                                    | Number of blocks |
|--------|----------------|------------------------------------------------|------------------|
| 0      | Receive buffer | 0                                              | 8                |
| 0      | Send buffer    | 8                                              | 4                |
| 1      | Receive buffer | 12                                             | 8                |
|        | Send buffer    | 20                                             | 4                |
| 2      | Receive buffer | 24                                             | 8                |
| 2      | Send buffer    | 32                                             | 4                |
| 3      | Receive buffer | 36                                             | 8                |
| 3      | Send buffer    | 44                                             | 4                |
| 4      | Receive buffer | NULL (Empty, not allocated,<br>the same below) | 0                |
|        | Send buffer    | NULL                                           | 0                |
| 5      | Receive buffer | NULL                                           | 0                |
| 5      | Send buffer    | NULL                                           | 0                |
| 6      | Receive buffer | NULL                                           | 0                |

Table 5-12 CH395 internal buffer

|     | Send buffer    | NULL | 0 |
|-----|----------------|------|---|
| 7 - | Receive buffer | NULL | 0 |
|     | Send buffer    | NULL | 0 |

As can be seen from the above table, after CH395 is initialized, all buffers are allocated to Socket0~3, the receiving buffer is 8 blocks (4KB), and the sending buffer is 4 blocks (2KB). If the number of sockets required by the MCU is greater than 4, the buffer needs to be allocated again.

### 5.46 CMD\_SET\_SEND\_BUF

This command is used to set the Socket's sending buffer. It requires input of 3 bytes of data. The first byte is the Socket index, the second byte is the starting block of the buffer, and the third byte is the number of blocks.

For the definition and allocation of buffers, please refer to Chapter 5.45.

### 5.47 CMD\_EEPROM\_ERASE

This command is used to erase the EEPROM. The CH395 chip comes with 4KB of EEPROM, and all the data after erasing is 0XF5. Before writing to EEPROM, it is necessary to ensure that all data in the destination area is 0XF5. This command needs to be executed approximately 21us.

### 5.48 CMD\_EEPROM\_WRITE

This command is used to write EEPROM. It requires inputting 2 bytes of address, 1 byte length and several bytes of data stream. The length of the byte stream must not be greater than 64 bytes. This command needs to be executed approximately 6.5us.

### 5.49 CMD\_EEPROM\_READ

This command is used to read EEPROM. It requires inputting the address of 2 bytes and the length of 1 byte. CH395 outputs several bytes of data stream according to the length, and the length value must not be greater than 64 bytes. After sending the length, the external MCU should wait 27us before reading the data. This command needs to be executed approximately 5.2us.

### 5.50 CMD\_READ\_GPIO\_REG

This command is used to read the GPIO register. It requires inputting a register address of 1 byte, and CH395 outputs a register value of 1 byte. All registers are 8 bits, bit0~7 corresponds to GPIO0~7 respectively. Their addresses and meanings are as follows:

| Address         | Name         | Description                               |  |
|-----------------|--------------|-------------------------------------------|--|
| 8011            | CDIO DID DEC | Direction Register                        |  |
| 80H             | GPIO_DIR_REG | 1: Output; 0: Input                       |  |
| 81H             | GPIO_IN_REG  | Input data register                       |  |
| 82H             | GPIO_OUT_REG | Output data register                      |  |
| 83H             | GPIO_CLR_REG | 0: Keep; 1: Clear                         |  |
| 0.411           | CDIO DI DEC  | Pull-down register                        |  |
| 84H GPIO_PU_REG |              | 1: Pull-up enable; 0: Pull-up disable     |  |
| 85H             | CDIO DD DEC  | Pull-up register                          |  |
| 83H             | GPIO_PD_REG  | 1: Pull-down enable; 0: Pull-down disable |  |

CH395 has 8 channels of GPIO, and GPIO3 defaults to output. After CH395 is successfully initialized, it outputs low level, and the rest GPIO defaults to input state.

# 5.51 CMD\_WRITE\_GPIO\_REG

This command is used to write a GPIO register, and it needs to input a register address of 1 byte and a register value of 1 byte.

Refer to Section 5.50 for the definition of GPIO register.

# 5.52 CMD\_SET\_FUN\_PARA

This command is used to set function parameters, and 4-byte parameters are required. The meanings of each parameter are as follows:

| Bit    | Name                | Reset value | Description                                          |
|--------|---------------------|-------------|------------------------------------------------------|
| [31:8] | -                   | -           | Reserved, must be 0                                  |
| 8      | FUN_PARA_FLAG_UART  | 0           | Serial port flow control enable bit, only supported  |
| 8      | _FLOW_CONTROL       | 0           | by CH395F                                            |
| 7      | FUN_PARA_FLAG_UART  | 0           | Serial port fast reply enable bit, supported by 0x4A |
| /      | _FAST_DEAL          | 0           | and later versions                                   |
| [5:6]  | -                   | -           | Reserved, must be 0                                  |
| 4      | FUN_PARA_FLAG_DISAB | 0           | Disable Socket SEND_OK interrupt, supported by       |
| 4      | LE_SEND_OK          | 0           | 0x4A and later versions                              |
| 3      | FUN_PARA_FLAG_SOCK  | 0           | Socket off mode, supported by 0x46 and later         |
| 3      | ET_CLOSE            | 0           | versions.                                            |
| 2      | -                   | -           | Reserved, must be 0                                  |
| 1      | FUN_PARA_FLAG_TCP_S | 0           | TCP server multi-connection mode enable bit,         |
|        | ERVER               | U           | supported by 0x44 and later versions.                |
| 0      | -                   | -           | Reserved, must be 0                                  |

Table 5-14 Functional parameters

(1) Fun\_para\_flag\_TCP\_server: TCP server multi-connection mode enable bit, this bit is 1, TCP server can connect multiple clients, please refer to 9.2.6, Global Configuration for usage, which is valid for all Socket.

- <sup>(2)</sup> FUN\_PARA\_FLAG\_SOCKET\_CLOSE: This parameter is mainly used for TCP, and this bit is 0, which indicates that CH395 will actively close the Socket after the interrupt of SINT\_STAT\_DISCONNECT or SINT\_STAT\_TIM\_OUT occurs. This bit is 1, which means that the Socket is closed by an external MCU after the above 2 interrupts are generated. Closing the Socket means that CH395 will clear the internal buffer of the Socket and some related variables. In some applications, if CH395 closes the Socket by itself, the residual data may be forcibly cleared. In this case, you can set this bit to 1, read the data by the MCU, and then close the Socket.
- ③ FUN\_PARA\_FLAG\_DISABLE\_SEND\_OK: Disable SINT\_STAT\_SEND\_OK interrupt. This bit is 1 and CH395 will no longer generate SINT\_STAT\_SEND\_OK interrupt.
- ④ FUN\_PARA\_FLAG\_UART\_FAST\_DEAL: For the serial command with data output, when this bit is 0, CH395 will output the data after receiving the data at an interval of 4 bytes of serial data timeout +TSC time; When this bit is set to 1, CH395 replies the data only at TSC time after receiving the data.
- ⑤ Fun \_ para \_ flag \_ UART \_ flow \_ control: serial port flow control enable bit, only applicable to CH395F. When this bit is set to 1, CTS and RTS pins of CH395F will be used as hardware flow control signals to realize the hardware flow control mechanism of serial communication.

⑥ Note that the CMD\_SET\_FUN\_PARA command must be set before initialization, and once initialization is completed, it cannot be set at will. In addition, you need to pay attention to the version number of the parameter.

#### 5.53 CMD\_SET\_KEEPALIVE\_IDLE

This command is used to set the Keepalive idle time, and a 4-byte time value in ms is required. This command is only used for TCP connections. Keepalive idle time refers to the time from the TCP connection without data transmission and reception to the sending of Keepalive packets. The default value is 20000.

#### 5.54 CMD\_SET\_KEEPALIVE\_INTVL

This command is used to set the Keepalive timeout, and a 4-byte time value in ms is required. This command is only used for TCP connections. Keepalive timeout refers to the time waiting for reply after Keepalive packet is sent. The default value is 15000.

### 5.55 CMD\_SET\_KEEPALIVE\_CNT

This command is used to set the Keepalive timeout, and you need to enter a timeout of 1 byte. This command is only used for TCP connections. Keepalive timeout refers to the maximum number of consecutive unanswered Keepalive packets. The default value is 9.

Assume that the Keepalive IDLE time is idle, the timeout time is INTVL, and the timeout number is CNT.

If the Keepalive function is enabled for the Socket connection, when the TCP connection is idle (no data is sent or received), the Socket will start sending Keepalive packets. If the remote end replies with an ACK in the INTVLms, the connection is considered normal. Otherwise, the Socket thinks that it has timed out after INTVLms, and starts sending Keepalive packets again. If no ACK packets are received within CNT times, it is considered that the current connection is disconnected, and a SINT\_STAT\_TIM\_OUT or SINT\_STAT\_DISCONNECT interrupt will be generated.

If three variables, IDLE, INTVL and CNT, need to be configured, it should be noted that IDLE must be greater than INTVL and both are multiples of 500.

### 5.56 CMD\_SET\_KEEPALIVE\_SN

This command is used to turn on or off the Keepalive function of Socket, and it needs to input a 1-byte Socket index and a 1-byte configuration value, where the configuration value is 0 to turn off the Keepalive function of Socket and 1 to turn on it. The default is off.

When the Socket is a TCP client, use this command to open the Keepalive function after creating the Socket. When the Socket is a TCP server, use this command to open the Keepalive function after generating

SINT\_STAT\_CONNECT.

## 6. Function Description

#### 6.1 MCU Communication Interface

There are 3 types of communication interfaces between CH395 and the MCU: 8-bit parallel interface, SPI synchronous serial interface, and asynchronous serial interface. When the chip is powered on and reset, CH395 will sample the status of the SEL and TXD pins, and select the communication interface according to the combination of these 2 pin states, refer to the table below (X in the table means not caring about this bit, 0 means low level, and 1 means high level or floating). SEL and TXD pins have built-in pull-up resistors, and the asynchronous serial port is selected by default. The desired communication interface can be selected by directly grounding the SEL or TXD pin to set to low.

| Table 6-1 Interface selection |         |                                    |  |
|-------------------------------|---------|------------------------------------|--|
| SEL pin                       | TXD pin | Select the communication interface |  |
| 1                             | 1       | UART                               |  |
| 1                             | 0       | SPI interface                      |  |
| 0                             | 1       | 8-bit parallel                     |  |
| 0                             | 0       | Error interface                    |  |

Table 6-1 Interface selection

The interrupt request output of the INT# pin of the CH395 chip is valid for low by default. It can be connected to the interrupt input pin or ordinary input pin of the MCU. The MCU can use the interrupt method or query method to obtain the interrupt request of the CH395.

#### **6.2 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, CH395 can be connected to SPI serial bus of various MCU, DSP and MCU with less wires.

The SPI interface of CH395 supports SPI mode 0 and SPI mode 3. CH395 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 MSB first, and 8 bits are counted as a word.

#### 6.2.1 SPI Operation Steps

The operation steps of SPI are as follows:

- ① MCU generates SPI chip selection of CH395 chip, active low;
- ② MCU sends out a byte of data according to SPI output mode. CH395 always takes the first byte received after SPI chip selects SCS as the command code and the subsequent bytes as the data.
- ③ MCU delays TSC time (about 0.6us) to wait for SPI interface of CH395 to be idle;
- ④ If it is a write operation, the MCU sends a byte of data to be written to CH395. After the SPI interface is idle, the MCU continues to send several bytes of data to be written, and CH395 receives them in turn until the MCU prohibits SPI chip selection.
- (5) If it is a read operation, the MCU receives one byte of data from CH395, and after the SPI interface is idle, the MCU continues to receive several bytes of data from CH395 until the MCU prohibits SPI chip selection;
- 6 MCU prohibits SPI chip selection of CH395 chip to end the current SPI operation.

The following figure is the logic timing diagram of SPI interface. Figure 6-1 shows issuing a command for 12H and writing data for 34H, and Figure 6-2 shows issuing a command for 28H and reading data for 78H.





### 6.3 UART

UART signal line includes a serial data input pin RXD and a serial data output pin TXD. Through the serial interface, CH395 can connect with MCU, DSP and MCU point to point with the least number of wires.

CH395F supports serial port hardware flow control (clearing the sending input pin CTS and sending request output pin RTS) and RS485 transceiver automatic switching (sending status output pin TNOW). By default, the flow control function is disabled, but it can be enabled by the CMD\_SET\_FUN\_PARA command to realize the hardware flow control mechanism.

The serial data format of CH395 is a standard byte transmission mode, including 1 start bit, 8 data bits and 1 stop bit.

CH395 not only supports the hardware to set the default serial communication baud rate, but also supports the MCU to select the appropriate communication baud rate at any time through the cmd\_set\_baud command. After each power-on reset, the default baud rate of CH395 serial communication is set by the level combination of SDO, SDI and SCK, refer to the following table (0 in the table stands for low level, 1 stands for high level or floating). SDO, SDI and SCK pins are suspended, and 9600bps is selected by default.

The baud rate error of CH395 serial port transmitting signal is less than 0.3%, and the allowable baud rate error of serial port receiving signal is less than 2%.

| SDO pin | SDI pin | SCK pin | Default baud rate of serial communication after power-on reset. |
|---------|---------|---------|-----------------------------------------------------------------|
| 1       | 1       | 1       | 9600bps                                                         |
| 1       | 1       | 0       | 57600bps                                                        |
| 1       | 0       | 1       | 115200bps                                                       |
| 1       | 0       | 0       | 460800bps                                                       |
| 0       | 1       | 1       | 250000bps                                                       |
| 0       | 1       | 0       | 1Mbps                                                           |
| 0       | 0       | 1       | 2Mbps                                                           |
| 0       | 0       | 0       | 921600bps                                                       |

In order to distinguish the command code from the data, CH395 requires the MCU to send 2 synchronization code bytes (57H and ABH) through the serial port first, then send the command code, and then send or receive the data. CH395 will check the interval time between the above 2 synchronization code bytes and between the synchronization code and the command code. If the interval time is longer than the serial input timeout time SER\_CMD\_TIMEOUT (about 40ms), CH395 will discard the synchronization code and the command packet. For the serial command with returned data, CH395 will return the data after about TE7 time (see Table 7-4) after receiving the command.

#### 6.3.1 Serial Port Operation Steps

The serial port command operation steps are as follows:

- ① The MCU sends the first synchronization code 57H to CH395 through the serial port;
- 2 The MCU issues the second synchronization code ABH to CH395;
- ③ The MCU issues command code to CH395;
- ④ If the command has input data, input data is sent to CH395 in turn, one byte at a time;
- 5 If the command has output data, the output data is received from CH395 in turn, one byte at a time.

The following figure is the logical timing diagram of the serial port.





### 6.4 8-bit Parallel Interface

The parallel signal lines include: 8-bit bidirectional data bus D7 to D0, read gate input pin RD#, write gate input pin WR#, chip select input pin PCS#, and address input pin A0. The PCS# of the CH395 chip is used to select devices when the MCU has multiple peripheral devices. Through the passive parallel interface, the CH395 chip can be easily attached to the system bus of various 8-bit MCUs, DSPs, and MCUs, and can coexist with multiple peripheral devices.

For MCUs similar to Intel parallel timing, the RD# pins and WR# pins of the CH395 chip can be connected to the read gate output pin and the write gate output pin of the MCU respectively. For MCUs similar to Motorola parallel timing, the RD# pin of the CH395 chip should be connected to the low level, and the WR# pin is connected to the MCU's read and write direction output pin R/-W.

The following table is the truth table for parallel I/O operations (X in the table means that this bit is not caring about, Z means that CH395 three-state prohibited).

| PCS# | WR# | RD# | A0 | D7-D0  | Practical operation of CH395 chip                                                                                            |
|------|-----|-----|----|--------|------------------------------------------------------------------------------------------------------------------------------|
| 1    | X   | Х   | Х  | X/Z    | CH395 is not selected and no operation is performed.                                                                         |
| 0    | 1   | 1   | Х  | X/Z    | Although selected, no operation is performed and no operation is performed.                                                  |
| 0    | 0   | 1/X | 1  | Input  | Write command code to the command port of CH395.                                                                             |
| 0    | 0   | 1/X | 0  | Input  | Write data to the data port of CH395.                                                                                        |
| 0    | 1   | 0   | 0  | Output | Read data from the data port of CH395.                                                                                       |
| 0    | 1   | 0   | 1  | Output | Read interface status from the command port of CH395:<br>Bit 7 is the interrupt flag, low valid, equivalent to the INT# pin. |

| Table 6-3 Parallel op | eration truth table |
|-----------------------|---------------------|
|-----------------------|---------------------|

#### 6.4.1 Parallel Operation Steps

When the CH395A0 pin is high, select the command port, and can write a new command, or read the interface status; when the A0 pin is low, select the data port, and can read and write data.

The MCU reads and writes the CH395 chip through an 8-bit parallel port. All operations are composed of a command code, several input data and several output data. Some commands do not require input data, and some commands do not output data. The command operation steps are as follows:

- ① When A0=1, the MCU writes command code to the command port;
- 2 The MCU delays TSC time (about 0.6us) to wait for the parallel port of CH395 to be free;
- (3) If the command has input data, write the input data one byte at a time when A0=0;
- (4) If the command has output data, the output data is read one byte at a time when A0=0.

#### 6.5 Other Hardware

CH395 chip integrates 10M/100M Ethernet PHY, MAC, serial port, SPI-Slave controller, passive parallel interface, SRAM, high-speed MCU and PLL frequency multiplier, power-on reset circuit, etc.

CH395 chip has built-in power-on reset circuit, which can also be controlled by pulling RSTI pin low. RSTI pin is used to input asynchronous reset signal from outside; When the RSTI pin is low, the CH395 chip is reset; When the RSTI pin returns to the high level, CH395 will enter the initialization phase for about 15ms, during which the host prohibits the operation of CH395.

# 7. Parameters

### 7.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 temperature during operation                        | -40  | 85                     | °C   |
| $T_J$                 | Junction temperature range                                  | -40  | 100                    | °C   |
| Ts                    | Stored ambient temperature                                  | -55  | 150                    | °C   |
| V <sub>CC33</sub>     | Operating power supply voltage                              | -0.4 | 4.0                    | V    |
| V <sub>CCIO</sub>     | I/O supply voltage                                          | -0.4 | 4.0                    | V    |
| V <sub>DDK</sub>      | Power decoupling end of core analog circuit                 | -0.4 | 1.5                    | V    |
| VETH                  | Voltage on ETH physical signal pin                          | -0.4 | V <sub>CC33</sub> +0.4 | V    |
| V <sub>IN</sub>       | Input voltage on other I/O pins                             | -0.4 | V <sub>CCIO</sub> +0.4 | V    |
| V <sub>ESD(HBM)</sub> | ESD electrostatic discharge voltage of common I/O pin (HBM) | 6K   |                        | V    |
| т                     | Sinking current on I/O pin                                  |      | 20                     |      |
| I <sub>IO</sub>       | Output current on I/O pin                                   |      | 20                     | mA   |

| Table 7-1 | Absolute  | maximum         | value |
|-----------|-----------|-----------------|-------|
| 14010 / 1 | 110001010 | 11100/111100111 |       |

### 7.2 Electrical Parameters

### Table 7-2 Electrical Parameter ( $V_{CC33} = 3.3V$ , $V_{CCIO} = 3.3V$ , $T_A = 25^{\circ}C$ )

| Name              | Parameter dese                                           | Min.              | Тур.                   | Max.                   | Unit              |     |
|-------------------|----------------------------------------------------------|-------------------|------------------------|------------------------|-------------------|-----|
| V <sub>CC33</sub> | Operating power supply volta                             | 3.2               | 3.3                    | 3.4                    | V                 |     |
| V <sub>CCIO</sub> | I/O supply voltage                                       |                   | 1.7                    | 3.3                    | 3.6               | V   |
| V-                | I/O nin input low voltage                                | $V_{DDIO} = 3.3V$ | 0                      |                        | 0.8               | V   |
| V <sub>IL</sub>   | I/O pin, input low voltage.                              | $V_{DDIO} = 1.8V$ | 0                      |                        | 0.6               | v   |
| V <sub>IH</sub>   | I/O pin, input high voltage.                             | $V_{DDIO} = 3.3V$ | 2.0                    |                        | V <sub>CCI0</sub> | V   |
| V IH              | 10 pm, mput mgn vonage.                                  | $V_{DDIO} = 1.8V$ | 1.2                    |                        | V <sub>CCI0</sub> |     |
| V <sub>OL</sub>   | Low level output voltage, single pin sinks 5mA current   |                   |                        | 0.4                    | 0.6               | V   |
| V OL              |                                                          |                   |                        | 0.4                    | 0.0               | v   |
| V <sub>OH</sub>   | High level output voltage, single pin output 5mA current |                   | V <sub>CCIO</sub> -0.6 | V <sub>CCIO</sub> -0.4 |                   | V   |
| V OH              |                                                          |                   | V (() 0.0              |                        |                   | , , |
| V <sub>hys</sub>  | Voltage hysteresis of I/O Schr                           |                   | 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 resistant                           | ce                | 30                     | 40                     | 55                | kΩ  |

## 7.3 Power Consumption

Table 7-3 Power consumption ( $V_{CC33} = 3.3V$ ,  $V_{CCIO} = 3.3V$ ,  $T_A = 25^{\circ}C$ )

| ymbol Parameter Condition Typical Unit |
|----------------------------------------|
|----------------------------------------|

Sy

|                  |                              | (All current, with network regulator)         |      |      |
|------------------|------------------------------|-----------------------------------------------|------|------|
|                  |                              | 100BASE-TX channel link is successful and     | 74.9 |      |
| T                | Supply current in transfer   | there is a packet on the transceiver channel  | /4.9 | mA   |
| I <sub>DD0</sub> | status                       | 10BASE-TX channel link is successful and      | 46.8 | mA   |
|                  |                              | there is a packet on the transceiver channel  | 40.0 |      |
|                  |                              | 100BASE-TX channel link is successful and     | 74.9 |      |
| I <sub>DD1</sub> | Supply current in transfer   | there is no packet on the transceiver channel | /4.9 | mA   |
| IDDI             | status                       | 10BASE-TX channel link is successful and      | 47.5 | IIIA |
|                  |                              | there is no packet on the v channel           | 47.5 |      |
|                  | Supply current in disconnect | Both the 100BASE-TX and 10BASE-TX paths       |      |      |
| I <sub>DD2</sub> | status                       | are not successfully linked and the PHY is in | 54.4 | mA   |
|                  | Status                       | auto-negotiation.                             |      |      |
| I <sub>DD3</sub> | Sleep power consumption      |                                               | 380  | uA   |

### 7.4 Control Timing Parameters

| Name | Parameter description                                                           | Condition          | Тур.       | Unit |
|------|---------------------------------------------------------------------------------|--------------------|------------|------|
| TWAK | Wake-up time exiting from low power state                                       |                    | 100        | us   |
| TE0  | Execution time of CMD_RESET_ALL command                                         |                    | 15         | ms   |
| TE1  | Execution time of CMD_INIT_CH395 command                                        |                    | 5          | ms   |
| TE2  | Execution time of CMD00_EEPROM_ERASE command                                    |                    | 21.1       | us   |
| TE3  | Execution time of CMD30_EEPROM_WRITE command.                                   |                    | 6.5        | us   |
| TE4  | Execution time of CMD30_EEPROM_READ command.                                    |                    | 5.2        | us   |
| TE5  | Execution time of CMD_SET_MAC_ADDR command.                                     |                    | 30         | us   |
| TE6  | Execution time of the remaining commands                                        |                    | 1.5        | us   |
| TE7  | Return time of command data in serial mode                                      |                    | See note 1 | -    |
| TE8  | Execution time of cmd_set_baud command.                                         |                    | See note 2 |      |
| TUC  | Rrequired interval between transmission command code<br>and data in serial mode |                    | 0          | us   |
| TUD  | Required interval between data bytes in serial mode                             |                    | 0          | us   |
|      |                                                                                 | Read-write         | See table  |      |
| TSC  | Required interval between transmission command code                             | transceiver buffer | 7-5        | us   |
|      | and data in SPI or parallel port mode                                           | Other orders       | 0.6        |      |
|      | Paguirad interval between data butes in SPI or percella                         | Read-write         | See table  |      |
| TSD  | Required interval between data bytes in SPI or parallel                         | transceiver buffer | 7-5        | us   |
|      | port mode                                                                       | Other orders       | 0.3        |      |

Table 7-4 Control timing parameters

Note: 1. For serial commands with data output, CH395 will interval TE7 time after receiving data before outputting data.TE7 time is determined by bit7 of CMD\_SET\_FUN\_PARA command. When the default is 0, the TE7 time is about the timeout time of 4 bytes of serial data plus the TSC time, which is calculated as 4\*(10/BaudRate) + TSC (unit: s). For example, when the baud rate is 921600, the timeout time is about  $4*(10/921600)+0.0000006 \approx 0.000044$  seconds (44us); when bit7 is 1, the return time is only TSC time (0.6us).

2. TE8 time is TE7+1ms.

In SPI or parallel port mode, CH395 only needs to ensure the interval of TSL time between the length and data, and all other bytes need no interval.

| Table 7-5 Read and write transcerver burier timing parameters |                                                       |                     |      |      |  |  |
|---------------------------------------------------------------|-------------------------------------------------------|---------------------|------|------|--|--|
| Name                                                          | Parameter description                                 | Condition           | Тур. | Unit |  |  |
| TOI                                                           | The required interval between transmission length and | Read-receive buffer | 0.4  | 110  |  |  |
| TSL                                                           | data in SPI or parallel port mode                     | Write-send buffer   | 0.2  | us   |  |  |

Table 7-5 Read and write transceiver buffer timing parameters

## Figure 7-1 SPI mode write-send buffer



## Figure 7-2 SPI mode read-receive buffer









## Figure 7-4 Parallel port mode write-send buffer

# 7.5 AC Electrical Characteristic and Timing7.5.1 SPI Timing



Figure 7-5 SPI mode 0 timing figure

Figure 7-6 SPI mode 3 timing figure



| Symbol                | Parameter                  | Condition | Min. | Max. | Unit |
|-----------------------|----------------------------|-----------|------|------|------|
| f <sub>SCK</sub>      | SCK clock frequency of SPI |           |      | 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   |

## 7.5.2 Parallel Port Timing



Figure 7-7 Parallel port timing figure

Table 7-7 Parallel port parameter table ( $V_{CC33} = 3.3V$ ,  $V_{CCIO} = 3.3V$ ,  $T_A = 25^{\circ}C$ )

| Symbol              | Parameter                   | Condition | Min. | Max. | Unit |
|---------------------|-----------------------------|-----------|------|------|------|
| t <sub>CR</sub>     | PCS# setup time             |           | 1    |      | ns   |
| t <sub>RC</sub>     | PCS# holding time           |           | 0    |      | ns   |
| t <sub>ADDRS</sub>  | Address setup time          |           | 1    |      | ns   |
| t <sub>WDATAS</sub> | Data input setup time       |           | 1    |      | ns   |
| t <sub>WDATAH</sub> | Data input holding time     |           | 10   |      | ns   |
| T <sub>RDATAD</sub> | Data output delay time      |           | 15   |      | ns   |
| t <sub>RDN</sub>    | RD# high level holding time |           | 25   |      | ns   |
| t <sub>RD</sub>     | RD# low level holding time  |           | 30   |      | ns   |
| t <sub>WRN</sub>    | WR# high level holding time |           | 25   |      | ns   |
| t <sub>WR</sub>     | WR# low level holding time  |           | 30   |      | ns   |
| t <sub>RWC</sub>    | Read-write cycle time       |           | 70   |      | ns   |
| t <sub>CSN</sub>    | CS high level holding time  |           | 35   |      | ns   |

## 7.5.3 Oscillator and Crystal Oscillator Timing

Table 7-8 Parameters table of oscillator and crystal oscillator timing

| Symbol | Parameter              | Condition                | Min.   | Тур. | Max.   | Unit |
|--------|------------------------|--------------------------|--------|------|--------|------|
| TCKF   | Crystal frequency      | Recommended within 30ppm | 24.999 | 25   | 25.001 | MHz  |
| 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.

# 7.5.4 Reset Timing

| Symbol                | Parameter                                     | Min. | Тур. | Max. | Unit |
|-----------------------|-----------------------------------------------|------|------|------|------|
| t <sub>RSTTEMPO</sub> | RSTI low level width                          | 1    |      |      | us   |
| t <sub>RSTTEMP1</sub> | RSTI high to host operable                    | 12   | 15   | 19   | ms   |
| t <sub>RSTTEMP2</sub> | Reset command valid to the host for operation | 12   | 15   | 19   | ms   |
| t <sub>RSTTEMP3</sub> | Power on and reset to the host for operation  | 27   | 30   | 35   | ms   |

Table 7-9 Reset timing parameter table

# 8. Package Information

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.* 

# 8.1 QFN32



# 8.2 LQFP64M





8.3 LQFP128



# 9. Application

# 9.1 Application Base

CH395 integrates IPv4, ARP, ICMP, 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 high-reliability communication for network devices, and is responsible for transmitting application-layer data to network layer in segments, acknowledging receiving packets, setting timeout and other functions, thus realizing end-to-end reliable transmission, so that the application layer does not need to pay attention to the underlying details. In contrast, UDP provides a simple and fast service, which is only responsible for transmitting datagrams from one network terminal to another, and does not guarantee the delivery of datagrams. The reliability needs to be realized by the application layer itself. Both TCP and UDP data are transmitted through the IP protocol of the network 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 CH395 generates unreachable interrupt, it is through ICMP that error message switching is performed. PING also uses the ICMP protocol.

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

# 9.2 Application Reference Steps

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

# 9.2.1 Initialize CH395, Necessary Operations

- ① Send the command CMD\_SET\_MAC\_ADDR to set the MAC address of CH395;
- ② Send the command CMD\_SET\_IP\_ADDR to set the IP address of CH395;
- ③ Send the command CMD\_SET\_GWIP\_ADDR to set the gateway IP address of CH395;
- ④ Send the command CMD\_SET\_MASK\_ADDR to set the subnet mask of CH395;
- (5) Send the command CMD\_INIT\_CH395 to initialize CH395;
- ⑥ Delay 2ms or more to send the command CMD\_GET\_CMD\_STATUS to get the execution status of CMD\_INIT\_CH395, if it returns CH395\_ERR\_BUSY it means that CH395 is executing the command internally and needs to be executed again ⑥; if it returns CH395\_ERR\_SUCCESS, it means that the command has been executed successfully.CMD\_INIT\_CH395 normally takes 5ms to be executed. INIT\_CH395 normally takes 5ms to execute.

Step (1) is generally not needed, the CH395 has already burned the MAC address assigned by IEEE when it is shipped from the factory.

If you need to start DHCP, steps (2) - (4) are not required.

Step (4) is optional, and the default subnet mask of 255.255.255.0 is generally not required.

After receiving the cmd\_init\_CH395 command, Ch395 initializes the internal TCP/IP protocol stack, and initializes the MAC and PHY. At this time, the MAC and PHY will be initialized to the auto-negotiation mode. If PHY needs to work in other modes, such as 10M full-duplex mode, it needs to send the CMD\_SET\_PHY command for setting after the successful execution of CMD INIT CH395.

### 9.2.2 Initialize Socket to MACRAW Mode

The initialization steps are as follows:

- ① Send the command CMD\_SET\_PROTO\_TYPE\_SN to set the Socket to work in MACRAW mode;
- ② Send the command CMD\_OPEN\_SOCKET\_SN to open Socket;
- ③ Send the command CMD\_GET\_CMD\_STATUS with a delay of more than 2ms to get the execution status of CMD\_OPEN\_SOCKET\_SN. If the command is being executed in CH395\_ERR\_BUSY, it needs to be executed again. If CH395\_ERR\_SUCCESS is returned, the command is executed successfully. Other values indicate that opening the Socket failed.

#### IEEE802.3 Ethernet frame format:

| Destination MAC | Source MAC  | Туре | Data        | CRC32 |
|-----------------|-------------|------|-------------|-------|
| 6Byte           | 6Byte 6Byte |      | 46-1500Byte | 4Byte |

In MACRAW mode, CH395 will transparently transmit the data between Ethernet and MCU, and will not encapsulate the data with TCP/IP. when CH395 receives the data, it will check the Ethernet redundancy check CRC32, and if the check is wrong, the packet will not be forwarded to the MCU. when CH395 sends the data, it will add the Ethernet redundancy check CRC32 at the end of the packet. The length of the data written by the MCU to the CH395 each time shall not be greater than 1514, and the CH395 will encapsulate the data written by the MCU each time into a frame of data to be sent. When CH395 receives data from the Ethernet, it will notify the MCU, and then the MCU should immediately read all the data away from the internal receive buffer of CH395.

Only Socket0 can set this mode, and other Sockets will not be available.

#### 9.2.3 Initialize Socket to IPRAW Mode

The initialization steps are as follows:

- ① Send the command CMD\_SET\_PROTO\_TYPE\_SN to set the Socket to work in IPRAW mode;
- ② Send the command CMD\_SET\_IP\_ADDR\_SN to set the destination IP address;
- ③ Send the command CMD SET IPRAW PRO SN to set the protocol field;
- ④ Send the command CMD\_OPEN\_SOCKET\_SN to open Socket;
- (5) Send the command CMD\_GET\_CMD\_STATUS with a delay of more than 2ms to get the execution status of CMD\_OPEN\_SOCKET\_SN. If the command is being executed in CH395\_ERR\_BUSY, it needs to be executed again. If the return of CH395\_ERR\_SUCCESS indicates that the command was executed successfully, other values indicate that opening the Socket failed.

#### IP message structure:

| Destination MAC | Source MAC | Туре  | IP header | IPRAW data   | CRC32 |
|-----------------|------------|-------|-----------|--------------|-------|
| 6Byte           | 6Byte      | 2Byte | 20Byte    | Max.1480Byte | 4Byte |

After the MCU writes several bytes of data streams to CH395, CH395 encapsulates the protocol field of this Socket in the IP header and encapsulates the data stream in the IPRAW data part for sending. The maximum

length allowed for a IPRAW packet to send is 1480 bytes. If the length of the data stream written by the MCU is greater than 1480 bytes, CH395 will encapsulate the data stream into several IP packets for transmission, and after each packet is successfully sent, a SINT\_STAT\_SEND\_OK interrupt will occur. The byte length written by the MCU each time must not be greater than the length of the sending buffer, and the next data writing can be performed only after receiving the SINT\_STAT\_SENBUF\_FREE interrupt. If a SINT\_STAT\_TIM\_OUT interrupt occurs, it means that the data transmission fails, and there are generally two reasons for the failure to send data:

- ① If the destination IP address and CH395 are on the same subnet, the network device with the destination IP address may not be online.
- ② If the destination IP address and CH395 are not on the same subnet, the gateway of CH395 may not be online.

When CH395 receives the IP packet, it first checks whether the protocol field and the protocol field set by Socket are the same. If the same, copy the IPRAW packet to the receiving buffer and generates a SINT\_STAT\_RECV interrupt. After the MCU receives this interrupt, it can send the command CMD\_GET\_RECV\_LEN\_SN to obtain the length of the received buffer data, and then send the command CMD\_READ\_RECV\_SN to read the buffer data. The MCU can read all data at once or in multiple times. Since CH395 cannot be flow-controlled in IPRAW mode, it is recommended that the MCU read all data immediately after querying the received data interrupt port to avoid being overwritten by subsequent data.

#### Notes on the Protocol Field Setting

CH395 has higher priority in handling IPRAW than UDP and TCP. If the IP protocol field is set to 17 (UDP) or 6 (TCP), there may be a possibility of conflict with other Sockets. Pay attention to avoid it when using it. The following two situations are listed for explanation:

- (1) Socket0 is set to IPRAW mode, IP protocol field is 17, and Socket1 is UDP mode. In UDP mode, the protocol field of IP packet is also 17, which will cause the data communicated by Socket1 to be intercepted by Socket0 and unable to receive the data.
- ② Socket0 is set to IPRAW mode, IP protocol field is 6, and Socket1 is set to TCP mode. In TCP mode, the protocol field of IP packet is also 6, which will cause the data communicated by Socket1 to be intercepted by Socket0 and unable to receive the data.

#### 9.2.4 Initialize Socket to UDP Mode

The initialization steps are as follows:

- ① Send the command CMD\_SET\_PROTO\_TYPE\_SN to set the Socket to work in UDP mode;
- ② Send the command CMD\_SET\_IP\_ADDR\_SN to set the destination IP address;
- ③ Send the command CMD SET DES PORT SN to set the destination port;
- ④ Send the command CMD SET SOUR PORT SN to set the source port;
- ⑤ Send the command CMD\_OPEN\_SOCKET\_SN to open Socket;
- 6 Send the command CMD\_GET\_CMD\_STATUS with a delay of more than 2ms to get the execution status of CMD\_OPEN\_SOCKET\_SN. If the command is being executed in CH395\_ERR\_BUSY, it needs to be executed again. If the return of CH395\_ERR\_SUCCESS indicates that the command was executed successfully, other values indicate that opening the Socket failed.

#### UDP message structure:

| Destination MAC | Source MAC | Туре  | IP header | UDP header | UDP data     | CRC32 |
|-----------------|------------|-------|-----------|------------|--------------|-------|
| 6Byte           | 6Byte      | 2Byte | 20Byte    | 8Byte      | Max.1472Byte | 4Byte |

UDP is a simple and unreliable transport layer protocol for data messages, which has a high transmission speed and cannot guarantee that the data can reach its destination. The application layer must ensure the reliability and stability of transmission.

After the MCU writes several bytes of data streams to CH395, the CH395 data stream is encapsulated in the UDP data part for transmission. The maximum length that a UDP packet can send is 1472 bytes. If the length of the data stream written by the MCU is greater than 1472 bytes, CH395 will encapsulate the data stream into several UDP packets for transmission, and after each packet is successfully sent, a SINT\_STAT\_SEND\_OK interrupt will occur. The byte length written by the MCU each time must not be greater than the length of the sending buffer, and the next data writing can be performed only after receiving the SINT\_STAT\_SENBUF\_FREE interrupt. If data transmission fails, SINT\_STAT\_TIM\_OUT interrupt will occur, resulting in failure to send data. The following two reasons are generally:

- (1) If the destination IP address and CH395 are on the same subnet, the network device with the destination IP address may not be online.
- ② If the destination IP address and CH395 are not on the same subnet, the gateway of CH395 may not be online.

When CH395 receives the UDP message, it copies the UDP data into the Socket receiving buffer and generates a SINT\_STAT\_RECV interrupt. After the MCU receives this interrupt, it can send the command CMD\_GET\_RECV\_LEN\_SN to obtain the length of the received buffer data, and then send the command CMD\_READ\_RECV\_SN to read the buffer data. Since CH395 cannot provide flow control in UDP mode, it is recommended that the received data be read quickly and quickly to avoid being overwritten by subsequent data.

CH395 supports 2 UDP modes: UDP client and UDP server. The UDP client can only communicate with the specified IP and port, and the UDP server can communicate with any remote IP and port.

There are some differences in the use of the two:

- (1) Initialization step (2), if the destination IP address is 0XFFFFFFF, this socket will enter UDP server mode, otherwise UDP client mode.
- ② The MCU reads data from CH395. In client mode, CH395 directly sends the received data stream to the MCU. The MCU can read all the data at once or only read out part of the data. In server mode, CH395 will add an 8-byte information table to the head of the data. The MCU can obtain the source information of the data packet based on the information table. The MCU must read out all the data at one time.

| Packet length | Port  | IP address | Data  |
|---------------|-------|------------|-------|
| 2Byte         | 2Byte | 4Byte      | NByte |

③ The MCU sends data, and CH395 directly sends the data to the destination IP and port specified during initialization in the client mode. In server mode, CH395 can send data to any IP and port, and the MCU can set the destination IP and destination port before sending.

#### 9.2.5 Initialize Socket to TCP Client Mode

The initialization steps are as follows:

- ① Send the command CMD\_SET\_PROTO\_TYPE\_SN to set the Socket to work in TCP mode;
- ② Send the command CMD\_SET\_IP\_ADDR\_SN to set the destination IP address;
- ③ Send the command CMD SET DES PORT SN to set the destination port;
- ④ Send the command CMD\_SET\_SOUR\_PORT\_SN to set the source port;
- 5 Send the command CMD\_OPEN\_SOCKET\_SN to open Socket;
- 6 Send the command CMD\_GET\_CMD\_STATUS with a delay of more than 2ms to get the execution status of

CMD\_OPEN\_SOCKET\_SN. If the command is being executed in CH395\_ERR\_BUSY, it needs to be executed again. If CH395\_ERR\_SUCCESS is returned, it indicates that the command was executed successfully, and other values indicate that opening the Socket failed;

- ⑦ Send the command CMD\_TCP\_CONNECT\_SN for TCP connection;
- Belay 2ms or more to send the command CMD\_GET\_CMD\_STATUS to get the execution status of CMD\_TCP\_CONNECT\_SN, if it returns CH395\_ERR\_BUSY, it means that the command is being executed inside CH395, and it needs to be executed again (8); if it returns CH395\_ERR\_SUCCESS, it means that the command is executed successfully. Other values indicate that the command execution fails. Returning CH395\_ERR\_SUCCESS only means that the command is executed successfully, it does not mean that the TCP connection is successful. If the TCP connection is successful, CH395 will generate SINT\_STAT\_CONNECT interrupt. If the connection fails CH395 will generate a SINT\_STAT\_TIM\_OUT interrupt, and if it is necessary to connect again, start execution from (5) again.

TCP message structure:

| Destination MAC | Source MAC | Туре  | IP header | TCP header | TCP data      | CRC32 |
|-----------------|------------|-------|-----------|------------|---------------|-------|
| 6Byte           | 6Byte      | 2Byte | 20Byte    | 20Byte     | Max. 1460Byte | 4Byte |

TCP provides a connection-oriented and reliable byte stream service.

CH395 generates SINT\_STAT\_CONNECT, which indicates that TCP connection is established and data can be sent and received. Data transmission operation is not allowed before the connection is established.

After the MCU writes several bytes of data stream to CH395, the CH395 data stream is encapsulated in the TCP data part and sent. The maximum length that a TCP packet can send is TCP MSS bytes. If the length of the data stream written by the MCU is longer than TCP MSS bytes, CH395 will package the data stream into several TCP packets for sending, and each packet will generate a SINT\_STAT\_SEND\_OK interrupt after it is successfully sent. The length of bytes written by the MCU at a time shall not be greater than the length of the sending buffer, and the next data writing operation can only be carried out after receiving the interrupt of SINT\_STAT\_SENBUF\_FREE. In TCP mode, if the data transmission fails, the SINT\_STAT\_TIM\_OUT interrupt will be generated, and CH395 will automatically close this Socket (refer to 5.51 when FUN\_PARA\_FLAG\_SOCKET\_CLOSE is 0).

When CH395 receives the TCP message, it copies the TCP data into the Socket receiving buffer and generates a SINT\_STAT\_RECV interrupt. After the MCU receives this interrupt, it can send the command CMD\_GET\_RECV\_LEN\_SN to obtain the length of the received buffer data, and then sends the command CMD\_READ\_RECV\_SN to read the buffer data. The MCU can read all the data at once or only part of the data. The remaining space in the receiving buffer is the TCP window. After each time the MCU reads the data, CH395 will check the remaining space in the receiving buffer and inform the TCP server of the current window size.

# 9.2.6 Initialize Socket to TCP Server Mode

The initialization steps are as follows:

- ① Send the command CMD\_SET\_PROTO\_TYPE\_SN to set the Socket to work in TCP mode;
- ② Send the command CMD\_SET\_SOUR\_PORT\_SN to set the source port Sport;
- ③ Send the command CMD\_OPEN\_SOCKET\_SN to open Socket;
- ④ Send the command CMD\_GET\_CMD\_STATUS with a delay of more than 2ms to get the execution status of CMD\_OPEN\_SOCKET\_SN. If the command is being executed in CH395\_ERR\_BUSY, it needs to be executed again. If the return of CH395\_ERR\_SUCCESS indicates that the command was executed successfully, other values indicate that opening the Socket failed.

In the TCP server mode, if the client connects, the Socket will always be in listening state, and there will be no timeout interruption. If the TCP connection is successful, CH395 will interrupt SINT\_STAT\_CONNECT. At this time, the MCU can obtain the IP address and port number of the client by sending the command CMD GET REMOT IPP SN.

By default, the server multi-connection function is turned off. In TCP server mode, only one TCP connection can be established for each Socket.

When the multi-connection mode is enabled, the TCP server can connect multiple TCP connections, and the MCU needs to set the source port of the Socket to be consistent with the source port of the server. If the TCP server listens to the connection, CH395 will find out whether the source ports of all the Sockets are consistent with the current server, and the protocol type is TCP, and it is closed. If it is found, it will immediately open the Socket, assign the connection to the socket, and notify the MCU that there is a connection event. If it is not found, it will reset the connection. In this mode, the Socket of the server is only used for monitoring, and the MCU needs to allocate other sockets for the connection of the server. For example, Socket0 is set to server mode, and Socket1 and Socket2 are used to connect this server. The steps are as follows:

Socket0 executes (1-4);

- ⑤ Send command CMD\_SET\_SOUR\_PORT\_SN to Socket1 to set source port Sport;
- 6 Send command CMD\_SET\_PROTO\_TYPE\_SN to Socket1 to set Socket working in TCP mode;
- ⑦ Send command CMD\_SET\_SOUR\_PORT\_SN to Socket2 to set source port Sport;
- 8 Send the command CMD\_SET\_PROTO\_TYPE\_SN to Socket2 to set the Socket to work in TCP mode;

Regarding the data structure, the process of sending data and receiving data can refer to TCP client mode.

#### 9.2.7 DHCP

Before starting the following steps, the CH395 should be initialized first.

DHCP steps are as follows:

- ① Send the command CMD\_DHCP\_ENABLE parameter to 1 to start DHCP;
- 2 Wait for CH395 to generate GINT\_STAT\_DHCP interrupt;
- ③ Wait for the GINT\_STAT\_DHCP interrupt and send the command CMD\_GET\_DHCP\_STATUS to get the DHCP status, if the status code is 0 it means success, and the MCU can send the command CMD\_GET\_IP\_INF to get the information of IP, MASK and so on. If the status code is 1, it means failure, there may be a problem in the connection between CH395 and DHCP Server, for example, the DHCP Server is not online, although CH395 notifies the MCU of the DHCP error through interrupts, the MCU still keeps retrying internally to find the DHCP Server, and the MCU can send the CMD\_DHCP\_ENABLE command with a parameter of 0 to stop DHCP. The MCU can send CMD\_DHCP\_ENABLE command with parameter 0 to stop DHCP.

#### 9.2.8 About TCP MSS and Buffer

CH395 supports modifying TCPMSS, and the default TCPMSS size is 1460. Generally speaking, the larger the TCPMSS, the higher the communication speed and efficiency. Some principles should be followed when modifying TCPMSS and receive buffer.

- ① (Recommended) The length of the receive buffer must not be less than 2 times the TCP MSS;
- 2 (Must) The length of the receive buffer must not be less than the TCP MSS;
- ③ (Recommended) The length of the receive buffer must not be greater than 6 times the TCP MSS;
- ④ (Must) The send buffer size must not exceed 8KB.

When modifying TCPMSS, it should be as large as possible. If it is too small, it may lead to the increase of packet data on Ethernet and affect communication efficiency.

# 9.3 Reference Circuit9.3.1 CH395F Reference Circuit



CH395F has built-in part of the oscillation capacitance of crystal Y1, C5 and C6 can be adjusted according to the crystal parameters. For Y1 with a load capacitance of 12pF, C5 and C6 are not required; for Y1 with a load capacitance of 20pF, C5 and C6 are recommended to be 15pF each.

CH395F has built-in Ethernet  $50\Omega$  impedance matching resistor, do not connect  $49.9\Omega$  or  $50\Omega$  resistor externally, which is equivalent to voltage driver.

T1 is the ethernet network transformer, its center tap is grounded through capacitors C8 and C9 respectively, do not connect any power supply.

CH395F can select the desired communication interface through J2 and J3 jumper caps. Refer to section 6.1 for details on interface configuration.

#### 9.3.2 CH395A Reference Circuit



Figure 9-2 CH395A Hardware reference circuit

CH395A 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.

CH395A 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.

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

C24, C25, C26, C27 and C28 should be placed close to the VCCIO pin respectively.

CH395A can select the required communication interface through J2 and J3 jumper caps. Refer to Section 6.1 for

details about interface configuration.

When upgrading from CH395Q to CH395A, although the pins are basically compatible, the connection of peripheral circuits such as network transformers may need to be adjusted. For specific changes, please refer to the relevant articles in WCH official forum or contact technical support.

#### 9.3.3 CH395P Reference Circuit



Figure 9-2 CH395P Hardware reference circuit

CH395P 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.

CH395P has built-in Ethernet 50Ω impedance matching resistor, so don't connect 49.9Ω or 50Ω resistor

externally, which is equivalent to voltage driving.

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

CH395P can select the required communication interface through J2 and J3 jumper caps. Refer to Section 6.1 for details about interface configuration.

When upgrading from CH395L to CH395P, although the pins are basically compatible, the connection of peripheral circuits such as network transformers may need to be adjusted. For specific changes, please refer to the relevant articles in WCH official forum or contact technical support.