summaryrefslogtreecommitdiff
path: root/CMSIS/Driver/DriverTemplates/Driver_ETH_MAC.c
diff options
context:
space:
mode:
Diffstat (limited to 'CMSIS/Driver/DriverTemplates/Driver_ETH_MAC.c')
-rw-r--r--CMSIS/Driver/DriverTemplates/Driver_ETH_MAC.c210
1 files changed, 210 insertions, 0 deletions
diff --git a/CMSIS/Driver/DriverTemplates/Driver_ETH_MAC.c b/CMSIS/Driver/DriverTemplates/Driver_ETH_MAC.c
new file mode 100644
index 0000000..4fdb494
--- /dev/null
+++ b/CMSIS/Driver/DriverTemplates/Driver_ETH_MAC.c
@@ -0,0 +1,210 @@
+#include "Driver_ETH_MAC.h"
+
+#define ARM_ETH_MAC_DRV_VERSION ARM_DRIVER_VERSION_MAJOR_MINOR(2, 0) /* driver version */
+
+/* Driver Version */
+static const ARM_DRIVER_VERSION DriverVersion = {
+ ARM_ETH_MAC_API_VERSION,
+ ARM_ETH_MAC_DRV_VERSION
+};
+
+/* Driver Capabilities */
+static const ARM_ETH_MAC_CAPABILITIES DriverCapabilities = {
+ 0, /* 1 = IPv4 header checksum verified on receive */
+ 0, /* 1 = IPv6 checksum verification supported on receive */
+ 0, /* 1 = UDP payload checksum verified on receive */
+ 0, /* 1 = TCP payload checksum verified on receive */
+ 0, /* 1 = ICMP payload checksum verified on receive */
+ 0, /* 1 = IPv4 header checksum generated on transmit */
+ 0, /* 1 = IPv6 checksum generation supported on transmit */
+ 0, /* 1 = UDP payload checksum generated on transmit */
+ 0, /* 1 = TCP payload checksum generated on transmit */
+ 0, /* 1 = ICMP payload checksum generated on transmit */
+ 0, /* Ethernet Media Interface type */
+ 0, /* 1 = driver provides initial valid MAC address */
+ 0, /* 1 = callback event \ref ARM_ETH_MAC_EVENT_RX_FRAME generated */
+ 0, /* 1 = callback event \ref ARM_ETH_MAC_EVENT_TX_FRAME generated */
+ 0, /* 1 = wakeup event \ref ARM_ETH_MAC_EVENT_WAKEUP generated */
+ 0 /* 1 = Precision Timer supported */
+};
+
+//
+// Functions
+//
+
+ARM_DRIVER_VERSION ARM_ETH_MAC_GetVersion(void)
+{
+}
+
+ARM_ETH_MAC_CAPABILITIES ARM_ETH_MAC_GetCapabilities(void)
+{
+}
+
+int32_t ARM_ETH_MAC_Initialize(ARM_ETH_MAC_SignalEvent_t cb_event)
+{
+}
+
+int32_t ARM_ETH_MAC_Uninitialize(void)
+{
+}
+
+int32_t ARM_ETH_MAC_PowerControl(ARM_POWER_STATE state)
+{
+ switch (state)
+ {
+ case ARM_POWER_OFF:
+ break;
+
+ case ARM_POWER_LOW:
+ break;
+
+ case ARM_POWER_FULL:
+ break;
+
+ default:
+ return ARM_DRIVER_ERROR_UNSUPPORTED;
+ }
+}
+
+int32_t ARM_ETH_MAC_GetMacAddress(ARM_ETH_MAC_ADDR *ptr_addr)
+{
+}
+
+int32_t ARM_ETH_MAC_SetMacAddress(const ARM_ETH_MAC_ADDR *ptr_addr)
+{
+}
+
+int32_t ARM_ETH_MAC_SetAddressFilter(const ARM_ETH_MAC_ADDR *ptr_addr, uint32_t num_addr)
+{
+}
+
+int32_t ARM_ETH_MAC_SendFrame(const uint8_t *frame, uint32_t len, uint32_t flags)
+{
+}
+
+int32_t ARM_ETH_MAC_ReadFrame(uint8_t *frame, uint32_t len)
+{
+}
+
+uint32_t ARM_ETH_MAC_GetRxFrameSize(void)
+{
+}
+
+int32_t ARM_ETH_MAC_GetRxFrameTime(ARM_ETH_MAC_TIME *time)
+{
+}
+
+int32_t ARM_ETH_MAC_GetTxFrameTime(ARM_ETH_MAC_TIME *time)
+{
+}
+
+int32_t ARM_ETH_MAC_Control(uint32_t control, uint32_t arg)
+{
+ switch (control)
+ {
+ case ARM_ETH_MAC_CONFIGURE:
+
+ switch (arg & ARM_ETH_MAC_SPEED_Msk)
+ {
+ case ARM_ETH_MAC_SPEED_10M:
+ break;
+ case ARM_ETH_SPEED_100M:
+ break;
+ default:
+ return ARM_DRIVER_ERROR_UNSUPPORTED;
+ }
+
+ switch (arg & ARM_ETH_MAC_DUPLEX_Msk)
+ {
+ case ARM_ETH_MAC_DUPLEX_FULL:
+ break;
+ }
+
+ if (arg & ARM_ETH_MAC_LOOPBACK)
+ {
+ }
+
+ if ((arg & ARM_ETH_MAC_CHECKSUM_OFFLOAD_RX) ||
+ (arg & ARM_ETH_MAC_CHECKSUM_OFFLOAD_TX))
+ {
+ return ARM_DRIVER_ERROR_UNSUPPORTED;
+ }
+
+ if (!(arg & ARM_ETH_MAC_ADDRESS_BROADCAST))
+ {
+ }
+
+ if (arg & ARM_ETH_MAC_ADDRESS_MULTICAST)
+ {
+ }
+
+ if (arg & ARM_ETH_MAC_ADDRESS_ALL)
+ {
+ }
+
+ break;
+
+ case ARM_ETH_MAC_CONTROL_TX:
+ break;
+
+ case ARM_ETH_MAC_CONTROL_RX:
+ break;
+
+ case ARM_ETH_MAC_FLUSH:
+ if (arg & ARM_ETH_MAC_FLUSH_RX)
+ {
+ }
+ if (arg & ARM_ETH_MAC_FLUSH_TX)
+ {
+ }
+ break;
+
+ case ARM_ETH_MAC_SLEEP:
+ break;
+
+ case ARM_ETH_MAC_VLAN_FILTER:
+ break;
+
+ default:
+ return ARM_DRIVER_ERROR_UNSUPPORTED;
+ }
+}
+
+int32_t ARM_ETH_MAC_ControlTimer(uint32_t control, ARM_ETH_MAC_TIME *time)
+{
+}
+
+int32_t ARM_ETH_MAC_PHY_Read(uint8_t phy_addr, uint8_t reg_addr, uint16_t *data)
+{
+}
+
+int32_t ARM_ETH_MAC_PHY_Write(uint8_t phy_addr, uint8_t reg_addr, uint16_t data)
+{
+}
+
+void ARM_ETH_MAC_SignalEvent(uint32_t event)
+{
+}
+
+// End ETH MAC Interface
+
+ARM_DRIVER_ETH_MAC Driver_ETH_MAC =
+{
+ ARM_ETH_MAC_GetVersion,
+ ARM_ETH_MAC_GetCapabilities,
+ ARM_ETH_MAC_Initialize,
+ ARM_ETH_MAC_Uninitialize,
+ ARM_ETH_MAC_PowerControl,
+ ARM_ETH_MAC_GetMacAddress,
+ ARM_ETH_MAC_SetMacAddress,
+ ARM_ETH_MAC_SetAddressFilter,
+ ARM_ETH_MAC_SendFrame,
+ ARM_ETH_MAC_ReadFrame,
+ ARM_ETH_MAC_GetRxFrameSize,
+ ARM_ETH_MAC_GetRxFrameTime,
+ ARM_ETH_MAC_GetTxFrameTime,
+ ARM_ETH_MAC_ControlTimer,
+ ARM_ETH_MAC_Control,
+ ARM_ETH_MAC_PHY_Read,
+ ARM_ETH_MAC_PHY_Write
+};