2019-04-18 11:39:51 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2018 Aquantia Corporation
|
|
|
|
*/
|
|
|
|
|
2021-01-29 16:48:19 +00:00
|
|
|
#include <ethdev_driver.h>
|
2019-04-18 11:39:51 +00:00
|
|
|
|
|
|
|
#include "rte_pmd_atlantic.h"
|
|
|
|
#include "atl_ethdev.h"
|
|
|
|
|
|
|
|
|
2019-06-29 13:58:49 +02:00
|
|
|
int
|
2019-04-18 11:39:51 +00:00
|
|
|
rte_pmd_atl_macsec_enable(uint16_t port,
|
|
|
|
uint8_t encr, uint8_t repl_prot)
|
|
|
|
{
|
|
|
|
struct rte_eth_dev *dev;
|
|
|
|
|
|
|
|
RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
|
|
|
|
|
|
|
|
dev = &rte_eth_devices[port];
|
|
|
|
|
|
|
|
if (!is_atlantic_supported(dev))
|
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return atl_macsec_enable(dev, encr, repl_prot);
|
|
|
|
}
|
|
|
|
|
2019-06-29 13:58:49 +02:00
|
|
|
int
|
2019-04-18 11:39:51 +00:00
|
|
|
rte_pmd_atl_macsec_disable(uint16_t port)
|
|
|
|
{
|
|
|
|
struct rte_eth_dev *dev;
|
|
|
|
|
|
|
|
RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
|
|
|
|
|
|
|
|
dev = &rte_eth_devices[port];
|
|
|
|
|
|
|
|
if (!is_atlantic_supported(dev))
|
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return atl_macsec_disable(dev);
|
|
|
|
}
|
|
|
|
|
2019-06-29 13:58:49 +02:00
|
|
|
int
|
2019-04-18 11:39:51 +00:00
|
|
|
rte_pmd_atl_macsec_config_txsc(uint16_t port, uint8_t *mac)
|
|
|
|
{
|
|
|
|
struct rte_eth_dev *dev;
|
|
|
|
|
|
|
|
RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
|
|
|
|
|
|
|
|
dev = &rte_eth_devices[port];
|
|
|
|
|
|
|
|
if (!is_atlantic_supported(dev))
|
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return atl_macsec_config_txsc(dev, mac);
|
|
|
|
}
|
|
|
|
|
2019-06-29 13:58:49 +02:00
|
|
|
int
|
2019-04-18 11:39:51 +00:00
|
|
|
rte_pmd_atl_macsec_config_rxsc(uint16_t port, uint8_t *mac, uint16_t pi)
|
|
|
|
{
|
|
|
|
struct rte_eth_dev *dev;
|
|
|
|
|
|
|
|
RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
|
|
|
|
|
|
|
|
dev = &rte_eth_devices[port];
|
|
|
|
|
|
|
|
if (!is_atlantic_supported(dev))
|
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return atl_macsec_config_rxsc(dev, mac, pi);
|
|
|
|
}
|
|
|
|
|
2019-06-29 13:58:49 +02:00
|
|
|
int
|
2019-04-18 11:39:51 +00:00
|
|
|
rte_pmd_atl_macsec_select_txsa(uint16_t port, uint8_t idx, uint8_t an,
|
|
|
|
uint32_t pn, uint8_t *key)
|
|
|
|
{
|
|
|
|
struct rte_eth_dev *dev;
|
|
|
|
|
|
|
|
RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
|
|
|
|
|
|
|
|
dev = &rte_eth_devices[port];
|
|
|
|
|
|
|
|
if (!is_atlantic_supported(dev))
|
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return atl_macsec_select_txsa(dev, idx, an, pn, key);
|
|
|
|
}
|
|
|
|
|
2019-06-29 13:58:49 +02:00
|
|
|
int
|
2019-04-18 11:39:51 +00:00
|
|
|
rte_pmd_atl_macsec_select_rxsa(uint16_t port, uint8_t idx, uint8_t an,
|
|
|
|
uint32_t pn, uint8_t *key)
|
|
|
|
{
|
|
|
|
struct rte_eth_dev *dev;
|
|
|
|
|
|
|
|
RTE_ETH_VALID_PORTID_OR_ERR_RET(port, -ENODEV);
|
|
|
|
|
|
|
|
dev = &rte_eth_devices[port];
|
|
|
|
|
|
|
|
if (!is_atlantic_supported(dev))
|
|
|
|
return -ENOTSUP;
|
|
|
|
|
|
|
|
return atl_macsec_select_rxsa(dev, idx, an, pn, key);
|
|
|
|
}
|