renet driver for the ENC424J600 SPI Ethernet controller
Go to file
Harry Ho 99899e6657 nal: Fix read/write not pushing erroneous socket back to the stack
* Based on quartiq's minimq as of 933687c2e4
* In minimq applications, a socket is expected to be returned when `nal::TcpStack::open()` is called
  * `MqttClient::read()`/`write()` takes away the TCP socket handle (wrapped as an `Option`) from its `RefCell`, and then calls `nal::TcpStack::read()`/`write()`; if NAL returns `nb::Error`, then the MQTT client will propagate and return the error, leaving `None` behind
  * Afterwards, when `MqttClient::socket_is_connected()` gets called (e.g. while polling the interface), it will detect that the socket handle is `None`, and attempt to call `nal::TcpStack::open()`
  * Since `open()` pops a socket from the array (`unused_handles`), when implementing this NAL the socket should have been pushed back to the stack, i.e. by `close()`; this prevents any future calls of `open()` from returning `NetworkError::NoSocket` due to emptiness of the array of socket handles
2021-03-11 17:32:44 +08:00
.cargo Add tx_stm32f407 example 2020-06-18 15:06:55 +08:00
examples cargo: bump smoltcp version 2021-01-26 15:41:16 +08:00
nix nix/tmux.sh: Remove error message about existing tmux sessions 2020-12-09 10:51:32 +08:00
src nal: Fix read/write not pushing erroneous socket back to the stack 2021-03-11 17:32:44 +08:00
.gitignore add gitignore 2021-01-20 15:26:48 +08:00
Cargo.toml cargo: fix [package] meta 2021-01-28 17:56:14 +08:00
memory.x Add tx_stm32f407 example 2020-06-18 15:06:55 +08:00
openocd.gdb Use japaric/itm-tools; Introduce tmux environment 2020-08-24 12:05:49 +08:00
README.md Use RTIC framework on the examples 2020-12-29 11:47:02 +08:00
shell.nix Cargo.toml: Fix excessive dependency requirements 2020-12-29 11:53:34 +08:00

ENC424J600 Driver

General Instructions

The ENC424J600 Ethernet controller module supports operation in one of the following interfaces: Serial Peripheral Interace (SPI), or Parallel Slave Port (PSP). This Rust library supports the use of SPI for all embedded systems compatible with the Rust embedded-hal crate.

On ENC424J600, the INTn/SPISEL pin is multiplexed with an interrupt function (INTn) and an interface selection function (SPISEL). During power-up, to select SPI as the interface, INTn/SPISEL needs to latch a logic high for 1-10 us, driven outside of ENC424J600. After ENC424J600 has been initialsed, the same pin can be used to indicate occurrence of interrupt with a logic low, or idling with a logic high, driven by ENC424J600. Therefore, on the microcontroller side, the mode of driving the pin should be chosen by design: it should be tri-stated if interrupt is enabled, or push-pull otherwise.

To help facilitate the user, we provide a nix-shell environment and a set of Shell scripts to perform certain tasks, such as creating a ready-to-use tmux session for debugging an STM32 microcontroller, as well as compiling and running STM32-based examples.

Instructions for STM32F407 Examples

Currently, the provided examples are for STM32F4xx microcontrollers using the Rust stm32f4xx-hal crate. These examples assume that the SPI1 port is connected to the Ethernet module, and the GPIO PA1 pin is connected to its SPISEL pin. Since no interrupts are involved, GPIO PA1 is configured as a push-pull output to only initialise the controller. The program output is logged via ITM stimulus port 0.

Examples

Endless Pinging - tx_stm32f407

This program demonstrates the Ethernet TX capability on an STM32F407 board. Once loaded and initialised, a specific ping packet is sent (broadcasted) every 100ms. Such a packet has the following properties:

  • Destination MAC Address: ff-ff-ff-ff-ff-ff
  • Source MAC Address: 08-60-6e-44-42-95
  • Destination IP Address: 192.168.1.231
  • Source IP Address: 192.168.1.100
  • Frame Length in Bytes: 64

How-to

  1. Connect your STM32F407 device to the computer. Without changing any code, you may use an STLink V2 debugger.

  2. Create a tmux session for debugging:

    $ nix-shell
    [nix-shell]$ run-tmux-env
    
  3. When the tmux session is ready, on the top-right pane, compile and run the example program:

    [nix-shell]$ tx_stm32f407
    
  4. Observe the output on the left pane. If you wish to debug manually, run run-help to see the list of all available commands.

Expected Output

(Note: the MAC address is an example only.)

Eth TX Pinging on STM32-F407 via NIC100/ENC424J600
Ethernet initialised.
MAC Address = 04-91-62-3e-fc-1e
Promiscuous Mode ON
Sending packet (len=64): dest=ff-ff-ff-ff-ff-ff src=08-60-6e-44-42-95 data=08060001 08000604 ...
Packet sent
Sending packet (len=64): dest=ff-ff-ff-ff-ff-ff src=08-60-6e-44-42-95 data=08060001 08000604 ...
Packet sent
...

TCP Echoing & Greeting - tcp_stm32f407

This program demonstrates the TCP connectivity using smoltcp on an STM32F407 board. Once loaded and initialised, two TCP sockets will be opened on a specific IPv4 address. These sockets are:

  1. Echoing port - 1234
    • This socket receives raw data on all incoming TCP packets on the said port and prints them back on the output.
    • Note that this socket has a time-out of 10s.
  2. Greeting port - 4321
    • This socket waits for a single incoming TCP packet on the said port, and sends a TCP packet holding a text of greeting on the port.
    • Note that once a greeting is sent, the socket is closed immediately. Further packets received by the controller are dropped until the initiator disconnects from the port.

How-to

  1. Connect your STM32F407 device to the computer. Without changing any code, you may use an STLink V2 debugger.

  2. Create a tmux session for debugging:

    $ nix-shell
    [nix-shell]$ run-tmux-env
    
  3. When the tmux session is ready, on the top-right pane, compile and run the example program. The default IP address is 192.168.1.77, which can be edited in the source file examples/tcp_stm32f407.rs.

    [nix-shell]$ tcp_stm32f407
    
  4. To test the TCP ports, switch to the bottom-right pane (with Ctrl+B, followed by an arrow key) and use utilities like NetCat (nc):

    $ nc <ip> <port-number>
    

    Multiple instances of Netcat can run to use all the ports simultaneously. Use Ctrl+C to disconnect from the port manually (especially for the greeting port).

  5. Observe the output on the left pane. If you wish to debug manually, run run-help to see the list of all available commands.

Expected Output

(Note: the MAC address and timestamps shown below are examples only.)

ITM output at the initial state:

Eth TCP Server on STM32-F407 via NIC100/ENC424J600
Ethernet initialised.
Timer initialised.
MAC Address = 04-91-62-3e-fc-1e
TCP sockets will listen at 192.168.1.77/24
[0.0s] Listening to port 1234 for echoing, time-out in 10s
[0.0s] Listening to port 4321 for greeting, please connect to the port

The user connects to port 1234 and sends two packets with the following commands:

$ nc 192.168.1.77 1234
Hello World!
Bye World!

The following is appended to the ITM output:

[12.950s] Received packet: Ok("Hello world!\n")
[19.0s] Received packet: Ok("Bye world!\n")

The user then connects port 4321 with the following command, and immediately receives the following message on their console:

$ nc 192.168.1.77 4321
Welcome to the server demo for STM32-F407!

The following is appended to the ITM output:

[24.200s] Greeting sent, socket closed

After 10 seconds of the user not sending any more packets on port 1234, the following is appended to the ITM output; meanwhile, the socket is closed by nc for the user:

[29.0s] Listening to port 1234 for echoing, time-out in 10s

The user can now re-connect to port 1234 again.

For port 4321, without closing the port by exiting nc, the user keeps sending any packets with the utility. Since the Ethernet controller has already closed the socket, these new packets are dropped and the following error messages are appended to the ITM output:

[35.950s] Poll error: Dropped
[36.150s] Poll error: Dropped
...

The user then disconnects from port 4321 by exiting nc, and the following message is appended to the ITM output:

[40.200s] Listening to port 4321 for greeting, please connect to the port

The user can now re-connect to port 4321 again.