123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- /*
- * Copyright (c) 2020 DENX Software Engineering GmbH
- * Lukasz Majewski <lukma@denx.de>
- * SPDX-License-Identifier: Apache-2.0
- */
- /** @file
- * @brief DSA definitions and handlers
- */
- #ifndef ZEPHYR_INCLUDE_NET_DSA_H_
- #define ZEPHYR_INCLUDE_NET_DSA_H_
- #include <device.h>
- #include <net/net_if.h>
- /**
- * @brief DSA definitions and helpers
- * @defgroup DSA - Distributed Switch Architecture definitions and helpers
- * @ingroup networking
- * @{
- */
- #define NET_DSA_PORT_MAX_COUNT 8
- #define DSA_STATUS_PERIOD_MS K_MSEC(1000)
- /*
- * Size of the DSA TAG:
- * - KSZ8794 - 1 byte
- */
- #if defined(CONFIG_DSA_KSZ8794) && defined(DSA_KSZ_TAIL_TAGGING)
- #define DSA_TAG_SIZE 1
- #else
- #define DSA_TAG_SIZE 0
- #endif
- #ifdef __cplusplus
- extern "C" {
- #endif
- /**
- * @brief DSA generic transmit function
- *
- * This is a generic function for passing packets from slave DSA interface to
- * master.
- *
- * @param dev Device
- * @param pkt Network packet
- *
- * Returns:
- * - 0 if ok (packet sent via master iface), < 0 if error
- */
- int dsa_tx(const struct device *dev, struct net_pkt *pkt);
- /**
- * @brief DSA (MGMT) Receive packet callback
- *
- * Callback gets called upon receiving packet. It is responsible for
- * freeing packet or indicating to the stack that it needs to free packet
- * by returning correct net_verdict.
- *
- * Returns:
- * - NET_DROP, if packet was invalid, rejected or we want the stack to free it.
- * In this case the core stack will free the packet.
- * - NET_OK, if the packet was accepted, in this case the ownership of the
- * net_pkt goes to callback and core network stack will forget it.
- */
- typedef enum net_verdict (*dsa_net_recv_cb_t)(struct net_if *iface,
- struct net_pkt *pkt);
- /**
- * @brief Register DSA Rx callback functions
- *
- * @param iface Network interface
- * @param cb Receive callback function
- *
- * @return 0 if ok, < 0 if error
- */
- int dsa_register_recv_callback(struct net_if *iface, dsa_net_recv_cb_t cb);
- /**
- * @brief Set DSA interface to packet
- *
- * @param iface Network interface (master)
- * @param pkt Network packet
- *
- * @return Return the slave network interface
- */
- struct net_if *dsa_net_recv(struct net_if *iface, struct net_pkt **pkt);
- /**
- * @brief Pointer to master interface send function
- */
- typedef int (*dsa_send_t)(const struct device *dev, struct net_pkt *pkt);
- /**
- * @brief DSA helper function to register transmit function for master
- *
- * @param iface Network interface (master)
- * @param fn Pointer to master interface send method
- *
- * Returns:
- * - 0 if ok, < 0 if error
- */
- int dsa_register_master_tx(struct net_if *iface, dsa_send_t fn);
- /**
- * @brief DSA helper function to check if port is master
- *
- * @param iface Network interface (master)
- *
- * Returns:
- * - true if ok, false otherwise
- */
- bool dsa_is_port_master(struct net_if *iface);
- /**
- * @cond INTERNAL_HIDDEN
- *
- * These are for internal use only, so skip these in
- * public documentation.
- */
- /** DSA context data */
- struct dsa_context {
- /** Pointers to all DSA slave network interfaces */
- struct net_if *iface_slave[NET_DSA_PORT_MAX_COUNT];
- /** Pointer to DSA master network interface */
- struct net_if *iface_master;
- /** DSA specific API callbacks - filled in the switch IC driver */
- struct dsa_api *dapi;
- /** DSA related work (e.g. monitor if network interface is up) */
- struct k_work_delayable dsa_work;
- /** Number of slave ports in the DSA switch */
- uint8_t num_slave_ports;
- /** Status of each port */
- bool link_up[NET_DSA_PORT_MAX_COUNT];
- /** Instance specific data */
- void *prv_data;
- };
- /**
- * @brief Structure to provide DSA switch api callbacks - it is an augmented
- * struct ethernet_api.
- */
- struct dsa_api {
- /** Function to get proper LAN{123} interface */
- struct net_if *(*dsa_get_iface)(struct net_if *iface,
- struct net_pkt *pkt);
- /*
- * Callbacks required for DSA switch initialization and configuration.
- *
- * Each switch instance (e.g. two KSZ8794 ICs) would have its own struct
- * dsa_context.
- */
- /** Read value from DSA register */
- int (*switch_read)(const struct device *dev, uint16_t reg_addr,
- uint8_t *value);
- /** Write value to DSA register */
- int (*switch_write)(const struct device *dev, uint16_t reg_addr,
- uint8_t value);
- /** Program (set) mac table entry in the DSA switch */
- int (*switch_set_mac_table_entry)(const struct device *dev,
- const uint8_t *mac,
- uint8_t fw_port,
- uint16_t tbl_entry_idx,
- uint16_t flags);
- /** Read mac table entry from the DSA switch */
- int (*switch_get_mac_table_entry)(const struct device *dev,
- uint8_t *buf,
- uint16_t tbl_entry_idx);
- /*
- * DSA helper callbacks
- */
- struct net_pkt *(*dsa_xmit_pkt)(struct net_if *iface,
- struct net_pkt *pkt);
- };
- /**
- * @endcond
- */
- /**
- * @brief Get network interface of a slave port
- *
- * @param iface Master port
- * @param[in] slave_num Slave port number
- *
- * @return network interface of the slave if successful
- * @return NULL if slave port does not exist
- */
- struct net_if *dsa_get_slave_port(struct net_if *iface, int slave_num);
- /**
- * @brief Read from DSA switch register
- *
- * @param iface The interface
- * @param[in] reg_addr The register address
- * @param value The value
- *
- * @return 0 if successful, negative if error
- */
- int dsa_switch_read(struct net_if *iface, uint16_t reg_addr, uint8_t *value);
- /**
- * @brief Write to DSA switch
- *
- * @param iface The interface
- * @param[in] reg_addr The register address
- * @param[in] value The value
- *
- * @return { description_of_the_return_value }
- */
- int dsa_switch_write(struct net_if *iface, uint16_t reg_addr, uint8_t value);
- /**
- * @brief Write static MAC table entry
- *
- * @param iface Master DSA interface
- * @param[in] mac MAC address
- * @param[in] fw_port The firmware port
- * @param[in] tbl_entry_idx Table entry index
- * @param[in] flags Flags
- *
- * @return 0 if successful, negative if error
- */
- int dsa_switch_set_mac_table_entry(struct net_if *iface,
- const uint8_t *mac,
- uint8_t fw_port,
- uint16_t tbl_entry_idx,
- uint16_t flags);
- /**
- * @brief Read static MAC table entry
- *
- * @param iface Master DSA interface
- * @param buf Buffer to receive MAC address
- * @param[in] tbl_entry_idx Table entry index
- *
- * @return 0 if successful, negative if error
- */
- int dsa_switch_get_mac_table_entry(struct net_if *iface,
- uint8_t *buf,
- uint16_t tbl_entry_idx);
- /**
- * @brief Structure to provide mac address for each LAN interface
- */
- struct dsa_slave_config {
- /** MAC address for each LAN{123.,} ports */
- uint8_t mac_addr[6];
- };
- #ifdef __cplusplus
- }
- #endif
- /**
- * @}
- */
- #endif /* ZEPHYR_INCLUDE_NET_DSA_H_ */
|