Commit b76b163f authored by Oliver Hartkopp's avatar Oliver Hartkopp Committed by Marc Kleine-Budde

can: isotp: isotp_bind(): do not validate unused address information

With commit 2aa39889 ("can: isotp: isotp_bind(): return -EINVAL on
incorrect CAN ID formatting") the bind() syscall returns -EINVAL when
the given CAN ID needed to be sanitized. But in the case of an unconfirmed
broadcast mode the rx CAN ID is not needed and may be uninitialized from
the caller - which is ok.

This patch makes sure the result of an inproper CAN ID format is only
provided when the address information is needed.

Link: https://lore.kernel.org/all/20220517145653.2556-1-socketcan@hartkopp.netSigned-off-by: default avatarOliver Hartkopp <socketcan@hartkopp.net>
Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
parent d7e6f583
...@@ -1212,30 +1212,35 @@ static int isotp_bind(struct socket *sock, struct sockaddr *uaddr, int len) ...@@ -1212,30 +1212,35 @@ static int isotp_bind(struct socket *sock, struct sockaddr *uaddr, int len)
struct net *net = sock_net(sk); struct net *net = sock_net(sk);
int ifindex; int ifindex;
struct net_device *dev; struct net_device *dev;
canid_t tx_id, rx_id; canid_t tx_id = addr->can_addr.tp.tx_id;
canid_t rx_id = addr->can_addr.tp.rx_id;
int err = 0; int err = 0;
int notify_enetdown = 0; int notify_enetdown = 0;
if (len < ISOTP_MIN_NAMELEN) if (len < ISOTP_MIN_NAMELEN)
return -EINVAL; return -EINVAL;
/* sanitize tx/rx CAN identifiers */ /* sanitize tx CAN identifier */
tx_id = addr->can_addr.tp.tx_id;
if (tx_id & CAN_EFF_FLAG) if (tx_id & CAN_EFF_FLAG)
tx_id &= (CAN_EFF_FLAG | CAN_EFF_MASK); tx_id &= (CAN_EFF_FLAG | CAN_EFF_MASK);
else else
tx_id &= CAN_SFF_MASK; tx_id &= CAN_SFF_MASK;
rx_id = addr->can_addr.tp.rx_id; /* give feedback on wrong CAN-ID value */
if (tx_id != addr->can_addr.tp.tx_id)
return -EINVAL;
/* sanitize rx CAN identifier (if needed) */
if (isotp_register_rxid(so)) {
if (rx_id & CAN_EFF_FLAG) if (rx_id & CAN_EFF_FLAG)
rx_id &= (CAN_EFF_FLAG | CAN_EFF_MASK); rx_id &= (CAN_EFF_FLAG | CAN_EFF_MASK);
else else
rx_id &= CAN_SFF_MASK; rx_id &= CAN_SFF_MASK;
/* give feedback on wrong CAN-ID values */ /* give feedback on wrong CAN-ID value */
if (tx_id != addr->can_addr.tp.tx_id || if (rx_id != addr->can_addr.tp.rx_id)
rx_id != addr->can_addr.tp.rx_id)
return -EINVAL; return -EINVAL;
}
if (!addr->can_ifindex) if (!addr->can_ifindex)
return -ENODEV; return -ENODEV;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment