aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ppp
diff options
context:
space:
mode:
authorGuillaume Nault <g.nault@alphalink.fr>2016-08-09 09:12:26 -0400
committerDavid S. Miller <davem@davemloft.net>2016-08-09 17:56:21 -0400
commitbb8082f6913889418b69a54e57b4a39d7128a700 (patch)
tree6790b1aa62160bddf693d708b856e3d1edec8ebe /drivers/net/ppp
parent6cdaf03f8c23fcbfe7d4fa6876e114193bb6b632 (diff)
ppp: build ifname using unit identifier for rtnl based devices
Userspace programs generally need to know the name of the ppp devices they create. Both ioctl and rtnl interfaces use the ppp<suffix> sheme to name them. But although the suffix used by the ioctl interface can be known by userspace (it's the PPP unit identifier returned by the PPPIOCGUNIT ioctl), the one used by the rtnl is only known by the kernel. This patch brings more consistency between ioctl and rtnl based ppp devices by generating device names using the PPP unit identifer as suffix in both cases. This way, userspace can always infer the name of the devices they create. Signed-off-by: Guillaume Nault <g.nault@alphalink.fr> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ppp')
-rw-r--r--drivers/net/ppp/ppp_generic.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/net/ppp/ppp_generic.c b/drivers/net/ppp/ppp_generic.c
index f226db4616b7..70cfa06ccd40 100644
--- a/drivers/net/ppp/ppp_generic.c
+++ b/drivers/net/ppp/ppp_generic.c
@@ -1103,6 +1103,15 @@ static int ppp_nl_newlink(struct net *src_net, struct net_device *dev,
1103 } 1103 }
1104 1104
1105 conf.file = file; 1105 conf.file = file;
1106
1107 /* Don't use device name generated by the rtnetlink layer when ifname
1108 * isn't specified. Let ppp_dev_configure() set the device name using
1109 * the PPP unit identifer as suffix (i.e. ppp<unit_id>). This allows
1110 * userspace to infer the device name using to the PPPIOCGUNIT ioctl.
1111 */
1112 if (!tb[IFLA_IFNAME])
1113 conf.ifname_is_set = false;
1114
1106 err = ppp_dev_configure(src_net, dev, &conf); 1115 err = ppp_dev_configure(src_net, dev, &conf);
1107 1116
1108out_unlock: 1117out_unlock: