mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 02:33:57 +00:00
net: mctp: Expose transport binding identifier via IFLA attribute
MCTP control protocol implementations are transport binding dependent. Endpoint discovery is mandatory based on transport binding. Message timing requirements are specified in each respective transport binding specification. However, we currently have no means to get this information from MCTP links. Add a IFLA_MCTP_PHYS_BINDING netlink link attribute, which represents the transport type using the DMTF DSP0239-defined type numbers, returned as part of RTM_GETLINK data. We get an IFLA_MCTP_PHYS_BINDING attribute for each MCTP link, for example: - 0x00 (unspec) for loopback interface; - 0x01 (SMBus/I2C) for mctpi2c%d interfaces; and - 0x05 (serial) for mctpserial%d interfaces. Signed-off-by: Khang Nguyen <khangng@os.amperecomputing.com> Reviewed-by: Matt Johnston <matt@codeconstruct.com.au> Link: https://patch.msgid.link/20241105071915.821871-1-khangng@os.amperecomputing.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
4861333b42
commit
580db513b4
@ -880,7 +880,8 @@ static int mctp_i2c_add_netdev(struct mctp_i2c_client *mcli,
|
|||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = mctp_register_netdev(ndev, &mctp_i2c_mctp_ops);
|
rc = mctp_register_netdev(ndev, &mctp_i2c_mctp_ops,
|
||||||
|
MCTP_PHYS_BINDING_SMBUS);
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
dev_err(&mcli->client->dev,
|
dev_err(&mcli->client->dev,
|
||||||
"register netdev \"%s\" failed %d\n",
|
"register netdev \"%s\" failed %d\n",
|
||||||
|
@ -607,7 +607,7 @@ __must_hold(&busdevs_lock)
|
|||||||
goto err_free_uninit;
|
goto err_free_uninit;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = mctp_register_netdev(ndev, NULL);
|
rc = mctp_register_netdev(ndev, NULL, MCTP_PHYS_BINDING_I3C);
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
dev_warn(&ndev->dev, "netdev register failed: %d\n", rc);
|
dev_warn(&ndev->dev, "netdev register failed: %d\n", rc);
|
||||||
goto err_free_netdev;
|
goto err_free_netdev;
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
#include <linux/mctp.h>
|
#include <linux/mctp.h>
|
||||||
#include <net/mctp.h>
|
#include <net/mctp.h>
|
||||||
|
#include <net/mctpdevice.h>
|
||||||
#include <net/pkt_sched.h>
|
#include <net/pkt_sched.h>
|
||||||
|
|
||||||
#define MCTP_SERIAL_MTU 68 /* base mtu (64) + mctp header */
|
#define MCTP_SERIAL_MTU 68 /* base mtu (64) + mctp header */
|
||||||
@ -470,7 +471,7 @@ static int mctp_serial_open(struct tty_struct *tty)
|
|||||||
spin_lock_init(&dev->lock);
|
spin_lock_init(&dev->lock);
|
||||||
INIT_WORK(&dev->tx_work, mctp_serial_tx_work);
|
INIT_WORK(&dev->tx_work, mctp_serial_tx_work);
|
||||||
|
|
||||||
rc = register_netdev(ndev);
|
rc = mctp_register_netdev(ndev, NULL, MCTP_PHYS_BINDING_SERIAL);
|
||||||
if (rc)
|
if (rc)
|
||||||
goto free_netdev;
|
goto free_netdev;
|
||||||
|
|
||||||
@ -492,7 +493,7 @@ static void mctp_serial_close(struct tty_struct *tty)
|
|||||||
struct mctp_serial *dev = tty->disc_data;
|
struct mctp_serial *dev = tty->disc_data;
|
||||||
int idx = dev->idx;
|
int idx = dev->idx;
|
||||||
|
|
||||||
unregister_netdev(dev->netdev);
|
mctp_unregister_netdev(dev->netdev);
|
||||||
ida_free(&mctp_serial_ida, idx);
|
ida_free(&mctp_serial_ida, idx);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -298,4 +298,22 @@ void mctp_routes_exit(void);
|
|||||||
int mctp_device_init(void);
|
int mctp_device_init(void);
|
||||||
void mctp_device_exit(void);
|
void mctp_device_exit(void);
|
||||||
|
|
||||||
|
/* MCTP IDs and Codes from DMTF specification
|
||||||
|
* "DSP0239 Management Component Transport Protocol (MCTP) IDs and Codes"
|
||||||
|
* https://www.dmtf.org/sites/default/files/standards/documents/DSP0239_1.11.1.pdf
|
||||||
|
*/
|
||||||
|
enum mctp_phys_binding {
|
||||||
|
MCTP_PHYS_BINDING_UNSPEC = 0x00,
|
||||||
|
MCTP_PHYS_BINDING_SMBUS = 0x01,
|
||||||
|
MCTP_PHYS_BINDING_PCIE_VDM = 0x02,
|
||||||
|
MCTP_PHYS_BINDING_USB = 0x03,
|
||||||
|
MCTP_PHYS_BINDING_KCS = 0x04,
|
||||||
|
MCTP_PHYS_BINDING_SERIAL = 0x05,
|
||||||
|
MCTP_PHYS_BINDING_I3C = 0x06,
|
||||||
|
MCTP_PHYS_BINDING_MMBI = 0x07,
|
||||||
|
MCTP_PHYS_BINDING_PCC = 0x08,
|
||||||
|
MCTP_PHYS_BINDING_UCIE = 0x09,
|
||||||
|
MCTP_PHYS_BINDING_VENDOR = 0xFF,
|
||||||
|
};
|
||||||
|
|
||||||
#endif /* __NET_MCTP_H */
|
#endif /* __NET_MCTP_H */
|
||||||
|
@ -22,6 +22,7 @@ struct mctp_dev {
|
|||||||
refcount_t refs;
|
refcount_t refs;
|
||||||
|
|
||||||
unsigned int net;
|
unsigned int net;
|
||||||
|
enum mctp_phys_binding binding;
|
||||||
|
|
||||||
const struct mctp_netdev_ops *ops;
|
const struct mctp_netdev_ops *ops;
|
||||||
|
|
||||||
@ -44,7 +45,8 @@ struct mctp_dev *mctp_dev_get_rtnl(const struct net_device *dev);
|
|||||||
struct mctp_dev *__mctp_dev_get(const struct net_device *dev);
|
struct mctp_dev *__mctp_dev_get(const struct net_device *dev);
|
||||||
|
|
||||||
int mctp_register_netdev(struct net_device *dev,
|
int mctp_register_netdev(struct net_device *dev,
|
||||||
const struct mctp_netdev_ops *ops);
|
const struct mctp_netdev_ops *ops,
|
||||||
|
enum mctp_phys_binding binding);
|
||||||
void mctp_unregister_netdev(struct net_device *dev);
|
void mctp_unregister_netdev(struct net_device *dev);
|
||||||
|
|
||||||
void mctp_dev_hold(struct mctp_dev *mdev);
|
void mctp_dev_hold(struct mctp_dev *mdev);
|
||||||
|
@ -1958,6 +1958,7 @@ struct ifla_rmnet_flags {
|
|||||||
enum {
|
enum {
|
||||||
IFLA_MCTP_UNSPEC,
|
IFLA_MCTP_UNSPEC,
|
||||||
IFLA_MCTP_NET,
|
IFLA_MCTP_NET,
|
||||||
|
IFLA_MCTP_PHYS_BINDING,
|
||||||
__IFLA_MCTP_MAX,
|
__IFLA_MCTP_MAX,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -371,6 +371,8 @@ static int mctp_fill_link_af(struct sk_buff *skb,
|
|||||||
return -ENODATA;
|
return -ENODATA;
|
||||||
if (nla_put_u32(skb, IFLA_MCTP_NET, mdev->net))
|
if (nla_put_u32(skb, IFLA_MCTP_NET, mdev->net))
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
if (nla_put_u8(skb, IFLA_MCTP_PHYS_BINDING, mdev->binding))
|
||||||
|
return -EMSGSIZE;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -385,6 +387,7 @@ static size_t mctp_get_link_af_size(const struct net_device *dev,
|
|||||||
if (!mdev)
|
if (!mdev)
|
||||||
return 0;
|
return 0;
|
||||||
ret = nla_total_size(4); /* IFLA_MCTP_NET */
|
ret = nla_total_size(4); /* IFLA_MCTP_NET */
|
||||||
|
ret += nla_total_size(1); /* IFLA_MCTP_PHYS_BINDING */
|
||||||
mctp_dev_put(mdev);
|
mctp_dev_put(mdev);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -480,7 +483,8 @@ static int mctp_dev_notify(struct notifier_block *this, unsigned long event,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int mctp_register_netdevice(struct net_device *dev,
|
static int mctp_register_netdevice(struct net_device *dev,
|
||||||
const struct mctp_netdev_ops *ops)
|
const struct mctp_netdev_ops *ops,
|
||||||
|
enum mctp_phys_binding binding)
|
||||||
{
|
{
|
||||||
struct mctp_dev *mdev;
|
struct mctp_dev *mdev;
|
||||||
|
|
||||||
@ -489,17 +493,19 @@ static int mctp_register_netdevice(struct net_device *dev,
|
|||||||
return PTR_ERR(mdev);
|
return PTR_ERR(mdev);
|
||||||
|
|
||||||
mdev->ops = ops;
|
mdev->ops = ops;
|
||||||
|
mdev->binding = binding;
|
||||||
|
|
||||||
return register_netdevice(dev);
|
return register_netdevice(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mctp_register_netdev(struct net_device *dev,
|
int mctp_register_netdev(struct net_device *dev,
|
||||||
const struct mctp_netdev_ops *ops)
|
const struct mctp_netdev_ops *ops,
|
||||||
|
enum mctp_phys_binding binding)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
rtnl_lock();
|
rtnl_lock();
|
||||||
rc = mctp_register_netdevice(dev, ops);
|
rc = mctp_register_netdevice(dev, ops, binding);
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
|
Loading…
Reference in New Issue
Block a user