2015-04-08 19:54:00 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-11-19 17:13:33 +01:00
|
|
|
* @defgroup drivers_encx24j600 ENCX24J600
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_netdev
|
2015-04-08 19:54:00 +02:00
|
|
|
* @brief Driver for the ENCX24J600 Ethernet Adapter
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for the ENCX24J600 driver
|
|
|
|
*
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ENCX24J600_H
|
|
|
|
#define ENCX24J600_H
|
|
|
|
|
|
|
|
#include "mutex.h"
|
|
|
|
#include "periph/spi.h"
|
|
|
|
#include "periph/gpio.h"
|
2017-02-15 13:07:34 +01:00
|
|
|
#include "net/netdev.h"
|
2015-04-08 19:54:00 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief encx24j600 netdev device
|
2017-02-15 13:07:34 +01:00
|
|
|
* @extends netdev_t
|
2015-04-08 19:54:00 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2017-02-15 13:07:34 +01:00
|
|
|
netdev_t netdev; /**< extended netdev structure */
|
2015-04-08 19:54:00 +02:00
|
|
|
spi_t spi; /**< SPI device the enc is connected to*/
|
|
|
|
gpio_t cs; /**< SPI chip select pin */
|
|
|
|
gpio_t int_pin; /**< SPI interrupt pin */
|
2019-10-23 21:25:51 +02:00
|
|
|
uint16_t rx_next_ptr; /**< ptr to next packet within devices memory */
|
2015-04-08 19:54:00 +02:00
|
|
|
} encx24j600_t;
|
|
|
|
|
2016-03-27 21:36:00 +02:00
|
|
|
/**
|
|
|
|
* @brief Struct containing the needed peripheral configuration
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
spi_t spi; /**< SPI line */
|
|
|
|
gpio_t cs_pin; /**< chip select pin */
|
|
|
|
gpio_t int_pin; /**< interrupt pin */
|
|
|
|
} encx24j600_params_t;
|
|
|
|
|
2015-04-08 19:54:00 +02:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Setup an encx24j600 based device state.
|
2015-04-08 19:54:00 +02:00
|
|
|
*
|
|
|
|
* This function sets SPI pins, initializes the device state structure.
|
|
|
|
* It does not initialize the device itself.
|
|
|
|
*
|
2016-03-27 21:36:00 +02:00
|
|
|
* @param[out] dev the handle of the device to initialize
|
|
|
|
* @param[in] params parameters for device initialization
|
2022-03-16 15:02:25 +01:00
|
|
|
* @param[in] index Index of @p params in a global parameter struct array.
|
|
|
|
* If initialized manually, pass a unique identifier instead.
|
2015-04-08 19:54:00 +02:00
|
|
|
*/
|
2022-03-16 15:02:25 +01:00
|
|
|
void encx24j600_setup(encx24j600_t *dev, const encx24j600_params_t *params, uint8_t index);
|
2015-04-08 19:54:00 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* ENCX24J600_H */
|
|
|
|
/** @} */
|