rocker: Add proper validation of Netlink attributes
authorThomas Graf <tgraf@suug.ch>
Fri, 28 Nov 2014 13:34:31 +0000 (14:34 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 3 Dec 2014 04:01:26 +0000 (20:01 -0800)
Signed-off-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: Jiri Pirko <jiri@resnulli.us>
Signed-off-by: Scott Feldman <sfeldma@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/rocker/rocker.c

index 61cfdbf..30687bf 100644 (file)
@@ -3712,6 +3712,9 @@ static int rocker_port_bridge_setlink(struct net_device *dev,
        if (afspec) {
                attr = nla_find_nested(afspec, IFLA_BRIDGE_MODE);
                if (attr) {
+                       if (nla_len(attr) < sizeof(mode))
+                               return -EINVAL;
+
                        mode = nla_get_u16(attr);
                        if (mode != BRIDGE_MODE_SWDEV)
                                return -EINVAL;
@@ -3721,6 +3724,9 @@ static int rocker_port_bridge_setlink(struct net_device *dev,
        if (protinfo) {
                attr = nla_find_nested(protinfo, IFLA_BRPORT_LEARNING);
                if (attr) {
+                       if (nla_len(attr) < sizeof(u8))
+                               return -EINVAL;
+
                        if (nla_get_u8(attr))
                                rocker_port->brport_flags |= BR_LEARNING;
                        else
@@ -3731,6 +3737,9 @@ static int rocker_port_bridge_setlink(struct net_device *dev,
                }
                attr = nla_find_nested(protinfo, IFLA_BRPORT_LEARNING_SYNC);
                if (attr) {
+                       if (nla_len(attr) < sizeof(u8))
+                               return -EINVAL;
+
                        if (nla_get_u8(attr))
                                rocker_port->brport_flags |= BR_LEARNING_SYNC;
                        else