2018-09-26 17:07:38 +10:00
|
|
|
.. currentmodule:: network
|
|
|
|
.. _network.WIZNET5K:
|
|
|
|
|
|
|
|
class WIZNET5K -- control WIZnet5x00 Ethernet modules
|
|
|
|
=====================================================
|
|
|
|
|
|
|
|
This class allows you to control WIZnet5x00 Ethernet adaptors based on
|
|
|
|
the W5200 and W5500 chipsets. The particular chipset that is supported
|
2022-06-07 14:41:25 +10:00
|
|
|
by the firmware is selected at compile-time via the MICROPY_PY_NETWORK_WIZNET5K
|
2018-09-26 17:07:38 +10:00
|
|
|
option.
|
|
|
|
|
|
|
|
Example usage::
|
|
|
|
|
|
|
|
import network
|
|
|
|
nic = network.WIZNET5K(pyb.SPI(1), pyb.Pin.board.X5, pyb.Pin.board.X4)
|
|
|
|
print(nic.ifconfig())
|
|
|
|
|
|
|
|
# now use socket as usual
|
|
|
|
...
|
|
|
|
|
|
|
|
For this example to work the WIZnet5x00 module must have the following connections:
|
|
|
|
|
|
|
|
- MOSI connected to X8
|
|
|
|
- MISO connected to X7
|
|
|
|
- SCLK connected to X6
|
|
|
|
- nSS connected to X5
|
|
|
|
- nRESET connected to X4
|
|
|
|
|
2021-05-20 16:21:47 +10:00
|
|
|
It is possible to use other SPI buses and other pins for nSS and nRESET.
|
2018-09-26 17:07:38 +10:00
|
|
|
|
|
|
|
Constructors
|
|
|
|
------------
|
|
|
|
|
|
|
|
.. class:: WIZNET5K(spi, pin_cs, pin_rst)
|
|
|
|
|
|
|
|
Create a WIZNET5K driver object, initialise the WIZnet5x00 module using the given
|
|
|
|
SPI bus and pins, and return the WIZNET5K object.
|
|
|
|
|
|
|
|
Arguments are:
|
|
|
|
|
|
|
|
- *spi* is an :ref:`SPI object <pyb.SPI>` which is the SPI bus that the WIZnet5x00 is
|
|
|
|
connected to (the MOSI, MISO and SCLK pins).
|
|
|
|
- *pin_cs* is a :ref:`Pin object <pyb.Pin>` which is connected to the WIZnet5x00 nSS pin.
|
|
|
|
- *pin_rst* is a :ref:`Pin object <pyb.Pin>` which is connected to the WIZnet5x00 nRESET pin.
|
|
|
|
|
|
|
|
All of these objects will be initialised by the driver, so there is no need to
|
|
|
|
initialise them yourself. For example, you can use::
|
|
|
|
|
|
|
|
nic = network.WIZNET5K(pyb.SPI(1), pyb.Pin.board.X5, pyb.Pin.board.X4)
|
|
|
|
|
|
|
|
Methods
|
|
|
|
-------
|
|
|
|
|
|
|
|
.. method:: WIZNET5K.isconnected()
|
|
|
|
|
|
|
|
Returns ``True`` if the physical Ethernet link is connected and up.
|
|
|
|
Returns ``False`` otherwise.
|
|
|
|
|
|
|
|
.. method:: WIZNET5K.ifconfig([(ip, subnet, gateway, dns)])
|
|
|
|
|
|
|
|
Get/set IP address, subnet mask, gateway and DNS.
|
|
|
|
|
|
|
|
When called with no arguments, this method returns a 4-tuple with the above information.
|
|
|
|
|
|
|
|
To set the above values, pass a 4-tuple with the required information. For example::
|
|
|
|
|
|
|
|
nic.ifconfig(('192.168.0.4', '255.255.255.0', '192.168.0.1', '8.8.8.8'))
|
|
|
|
|
|
|
|
.. method:: WIZNET5K.regs()
|
|
|
|
|
|
|
|
Dump the WIZnet5x00 registers. Useful for debugging.
|