sections: fix section conflicts in net
authorAndi Kleen <ak@linux.intel.com>
Fri, 5 Oct 2012 00:12:11 +0000 (17:12 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Fri, 5 Oct 2012 18:04:45 +0000 (03:04 +0900)
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Cc: David Miller <davem@davemloft.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
include/net/net_namespace.h
net/decnet/dn_rules.c
net/ipv4/fib_rules.c
net/ipv4/ipmr.c
net/ipv6/addrlabel.c
net/ipv6/fib6_rules.c
net/ipv6/ip6mr.c

index 4faf6612ecacc05d2b00877691e440338ebb0144..95e646641184a3cdd2b32255822490683ea4f819 100644 (file)
@@ -257,10 +257,12 @@ static inline struct net *read_pnet(struct net * const *pnet)
 #define __net_init
 #define __net_exit
 #define __net_initdata
+#define __net_initconst
 #else
 #define __net_init     __init
 #define __net_exit     __exit_refok
 #define __net_initdata __initdata
+#define __net_initconst        __initconst
 #endif
 
 struct pernet_operations {
index e65f2c856e06bcc6b40147576adb286a047bc37e..faf7cc3483fe0822c26be6b915061ee8fdd8be9a 100644 (file)
@@ -220,7 +220,7 @@ static void dn_fib_rule_flush_cache(struct fib_rules_ops *ops)
        dn_rt_cache_flush(-1);
 }
 
-static const struct fib_rules_ops __net_initdata dn_fib_rules_ops_template = {
+static const struct fib_rules_ops __net_initconst dn_fib_rules_ops_template = {
        .family         = AF_DECnet,
        .rule_size      = sizeof(struct dn_fib_rule),
        .addr_size      = sizeof(u16),
index 274309d3aded0ffbf351dbf5f4ad128d87ff5a0b..26aa65d1fce49dfeaa45cbc02046218b5bc70453 100644 (file)
@@ -262,7 +262,7 @@ static void fib4_rule_flush_cache(struct fib_rules_ops *ops)
        rt_cache_flush(ops->fro_net);
 }
 
-static const struct fib_rules_ops __net_initdata fib4_rules_ops_template = {
+static const struct fib_rules_ops __net_initconst fib4_rules_ops_template = {
        .family         = AF_INET,
        .rule_size      = sizeof(struct fib4_rule),
        .addr_size      = sizeof(u32),
index 1daa95c2a0bad8e532181dc4d67d4aead0f3671f..6168c4dc58b1db546c567ef0c55842ab42edee16 100644 (file)
@@ -221,7 +221,7 @@ static int ipmr_rule_fill(struct fib_rule *rule, struct sk_buff *skb,
        return 0;
 }
 
-static const struct fib_rules_ops __net_initdata ipmr_rules_ops_template = {
+static const struct fib_rules_ops __net_initconst ipmr_rules_ops_template = {
        .family         = RTNL_FAMILY_IPMR,
        .rule_size      = sizeof(struct ipmr_rule),
        .addr_size      = sizeof(u32),
index 4be23da32b89c14ef19d5b0b349c244e33b881cd..ff76eecfd622ed80115fe691f9901739e7c7c0da 100644 (file)
@@ -79,7 +79,7 @@ struct net *ip6addrlbl_net(const struct ip6addrlbl_entry *lbl)
 
 #define IPV6_ADDR_LABEL_DEFAULT        0xffffffffUL
 
-static const __net_initdata struct ip6addrlbl_init_table
+static const __net_initconst struct ip6addrlbl_init_table
 {
        const struct in6_addr *prefix;
        int prefixlen;
index 0ff1cfd55bc4949fc02bf9dcef30fca58727c308..d9fb9110f607e8c587667147739979f34d52bc0a 100644 (file)
@@ -238,7 +238,7 @@ static size_t fib6_rule_nlmsg_payload(struct fib_rule *rule)
               + nla_total_size(16); /* src */
 }
 
-static const struct fib_rules_ops __net_initdata fib6_rules_ops_template = {
+static const struct fib_rules_ops __net_initconst fib6_rules_ops_template = {
        .family                 = AF_INET6,
        .rule_size              = sizeof(struct fib6_rule),
        .addr_size              = sizeof(struct in6_addr),
index 08ea3f0b6e55f9557ec1e919e77f1496ccb1fdf1..f7c7c6319720246f67f3cdbf09daea76634df0ba 100644 (file)
@@ -205,7 +205,7 @@ static int ip6mr_rule_fill(struct fib_rule *rule, struct sk_buff *skb,
        return 0;
 }
 
-static const struct fib_rules_ops __net_initdata ip6mr_rules_ops_template = {
+static const struct fib_rules_ops __net_initconst ip6mr_rules_ops_template = {
        .family         = RTNL_FAMILY_IP6MR,
        .rule_size      = sizeof(struct ip6mr_rule),
        .addr_size      = sizeof(struct in6_addr),