EMAC driver for the ENC28J60 Ethernet controller. This is a simplified fork of https://github.com/tobiasjaster/ENC28J60-EMAC-Driver published by Tobias Jaster.

Dependents:   MQTT_Hello MQTT_HelloENC28J60

EMAC driver for the ENC28J60 Ethernet controller

https://os.mbed.com/media/uploads/hudakz/enc28j60_module01.jpg

This is a fork (the INT and RST pins are not used) of the ENC28J60-EMAC driver published by Tobias Jaster at

https://github.com/tobiasjaster/ENC28J60-EMAC-Driver

Usage:

  • Connect the ENC28J60 module to the Mbed board as follows:

https://os.mbed.com/media/uploads/hudakz/enc28j60-emac.png

  • Import (add) this ENC28J60-EMAC library to your program.
  • Add a "mbed_app.json" file with the following content to the root directory of your program:

    {
        "target_overrides": {
            "*": {
                "platform.callback-nontrivial": true,
                "enc28j60-emac.mosi":  "D11",
                "enc28j60-emac.miso":  "D12",
                "enc28j60-emac.sck" :  "D13",
                "enc28j60-emac.cs"  :  "D10"
            }
        }
    }
  • Replace "D11", ..., "D10" with the actual pin names you selected on the Mbed board to be used for the SPI communication.
  • To set the MAC address define an array with the desired address bytes and call the "set_hwaddr(mac)" function before calling the network interface "connect" function.

For example:

    const uint8_t       MAC[6] = { 0, 1, 2, 3, 4, 5 };
    EthernetInterface   net;
 
    int main()
    {
        net.get_emac().set_hwaddr(MAC);             // set MAC address
        if (net.connect() != 0) {
            printf("Error: Unable to connect to the network.\n");
            return -1;
        }
     ...

enc28j60_emac_config.h

Committer:
hudakz
Date:
2021-03-29
Revision:
3:aa88808326b9
Parent:
0:b599e748252c

File content as of revision 3:aa88808326b9:

/*
 * enc28j60_emac_config.h
 *
 *  Created on: 27.08.2019
 *      Author: tobias
 *
 * Modified by Zoltan Hudak
 *
 */

#ifndef ENC28J60_EMAC_CONFIG_H_
#define ENC28J60_EMAC_CONFIG_H_

/*
 *  ENC28J60 receive buffer size in kylobytes
 */
#define ENC28J60_ETH_RXBUF_SIZE_KB           6U
#define ENC28J60_HWADDR_SIZE                 6U
#define ENC28J60_BUFF_ALIGNMENT              4U

/*
 * Maximum Transfer Unit
 * The IEEE 802.3 specification limits the data portion of the 802.3 frame
 * to a minimum of 46 and a maximum of 1522 bytes, this is on L2 level.
 */
#define ENC28J60_ETH_MTU_SIZE                1500U
#define ENC28J60_ETH_IF_NAME                 "enc28j60"

/** \brief Defines for receiver thread */
#define LINK_STATUS_TASK_PERIOD_MS           200ms
#define RECEIVE_TASK_PERIOD_MS               20ms
#define PHY_STATE_LINK_DOWN                  false
#define PHY_STATE_LINK_UP                    true
#define CRC_LENGTH_BYTES                     4U

#endif /* ENC28J60_EMAC_CONFIG_H_ */