* Since those fields can change at any moment, use READ_ONCE to
  * access both.
  */
-static struct mpls_nh *mpls_select_multipath(struct mpls_route *rt,
-                                            struct sk_buff *skb)
+static const struct mpls_nh *mpls_select_multipath(struct mpls_route *rt,
+                                                  struct sk_buff *skb)
 {
        u32 hash = 0;
        int nh_index = 0;
 {
        struct net *net = dev_net(dev);
        struct mpls_shim_hdr *hdr;
+       const struct mpls_nh *nh;
        struct mpls_route *rt;
-       struct mpls_nh *nh;
        struct mpls_entry_decoded dec;
        struct net_device *out_dev;
        struct mpls_dev *out_mdev;
        u32 labels[MAX_NEW_LABELS];
        struct mpls_shim_hdr *hdr;
        unsigned int hdr_size = 0;
+       const struct mpls_nh *nh;
        struct net_device *dev;
        struct mpls_route *rt;
        struct rtmsg *rtm, *r;
        struct nlmsghdr *nlh;
        struct sk_buff *skb;
-       struct mpls_nh *nh;
        u8 n_labels;
        int err;
 
 
 };
 
 #define for_nexthops(rt) {                                             \
-       int nhsel; struct mpls_nh *nh;                                  \
+       int nhsel; const struct mpls_nh *nh;                            \
        for (nhsel = 0, nh = (rt)->rt_nh;                               \
             nhsel < (rt)->rt_nhn;                                      \
             nh = (void *)nh + (rt)->rt_nh_size, nhsel++)