~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/net/ipv6_frag.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/net/ipv6_frag.h (Version linux-6.12-rc7) and /include/net/ipv6_frag.h (Version linux-4.15.18)


  1 /* SPDX-License-Identifier: GPL-2.0 */              1 
  2 #ifndef _IPV6_FRAG_H                              
  3 #define _IPV6_FRAG_H                              
  4 #include <linux/icmpv6.h>                         
  5 #include <linux/kernel.h>                         
  6 #include <net/addrconf.h>                         
  7 #include <net/ipv6.h>                             
  8 #include <net/inet_frag.h>                        
  9                                                   
 10 enum ip6_defrag_users {                           
 11         IP6_DEFRAG_LOCAL_DELIVER,                 
 12         IP6_DEFRAG_CONNTRACK_IN,                  
 13         __IP6_DEFRAG_CONNTRACK_IN       = IP6_    
 14         IP6_DEFRAG_CONNTRACK_OUT,                 
 15         __IP6_DEFRAG_CONNTRACK_OUT      = IP6_    
 16         IP6_DEFRAG_CONNTRACK_BRIDGE_IN,           
 17         __IP6_DEFRAG_CONNTRACK_BRIDGE_IN = IP6    
 18 };                                                
 19                                                   
 20 /*                                                
 21  *      Equivalent of ipv4 struct ip              
 22  */                                               
 23 struct frag_queue {                               
 24         struct inet_frag_queue  q;                
 25                                                   
 26         int                     iif;              
 27         __u16                   nhoffset;         
 28         u8                      ecn;              
 29 };                                                
 30                                                   
 31 #if IS_ENABLED(CONFIG_IPV6)                       
 32 static inline void ip6frag_init(struct inet_fr    
 33 {                                                 
 34         struct frag_queue *fq = container_of(q    
 35         const struct frag_v6_compare_key *key     
 36                                                   
 37         q->key.v6 = *key;                         
 38         fq->ecn = 0;                              
 39 }                                                 
 40                                                   
 41 static inline u32 ip6frag_key_hashfn(const voi    
 42 {                                                 
 43         return jhash2(data,                       
 44                       sizeof(struct frag_v6_co    
 45 }                                                 
 46                                                   
 47 static inline u32 ip6frag_obj_hashfn(const voi    
 48 {                                                 
 49         const struct inet_frag_queue *fq = dat    
 50                                                   
 51         return jhash2((const u32 *)&fq->key.v6    
 52                       sizeof(struct frag_v6_co    
 53 }                                                 
 54                                                   
 55 static inline int                                 
 56 ip6frag_obj_cmpfn(struct rhashtable_compare_ar    
 57 {                                                 
 58         const struct frag_v6_compare_key *key     
 59         const struct inet_frag_queue *fq = ptr    
 60                                                   
 61         return !!memcmp(&fq->key, key, sizeof(    
 62 }                                                 
 63                                                   
 64 static inline void                                
 65 ip6frag_expire_frag_queue(struct net *net, str    
 66 {                                                 
 67         struct net_device *dev = NULL;            
 68         struct sk_buff *head;                     
 69                                                   
 70         rcu_read_lock();                          
 71         /* Paired with the WRITE_ONCE() in fqd    
 72         if (READ_ONCE(fq->q.fqdir->dead))         
 73                 goto out_rcu_unlock;              
 74         spin_lock(&fq->q.lock);                   
 75                                                   
 76         if (fq->q.flags & INET_FRAG_COMPLETE)     
 77                 goto out;                         
 78                                                   
 79         fq->q.flags |= INET_FRAG_DROP;            
 80         inet_frag_kill(&fq->q);                   
 81                                                   
 82         dev = dev_get_by_index_rcu(net, fq->ii    
 83         if (!dev)                                 
 84                 goto out;                         
 85                                                   
 86         __IP6_INC_STATS(net, __in6_dev_get(dev    
 87         __IP6_INC_STATS(net, __in6_dev_get(dev    
 88                                                   
 89         /* Don't send error if the first segme    
 90         if (!(fq->q.flags & INET_FRAG_FIRST_IN    
 91                 goto out;                         
 92                                                   
 93         /* sk_buff::dev and sk_buff::rbnode ar    
 94          * pull the head out of the tree in or    
 95          * deal with head->dev.                   
 96          */                                       
 97         head = inet_frag_pull_head(&fq->q);       
 98         if (!head)                                
 99                 goto out;                         
100                                                   
101         head->dev = dev;                          
102         spin_unlock(&fq->q.lock);                 
103                                                   
104         icmpv6_send(head, ICMPV6_TIME_EXCEED,     
105         kfree_skb_reason(head, SKB_DROP_REASON    
106         goto out_rcu_unlock;                      
107                                                   
108 out:                                              
109         spin_unlock(&fq->q.lock);                 
110 out_rcu_unlock:                                   
111         rcu_read_unlock();                        
112         inet_frag_put(&fq->q);                    
113 }                                                 
114                                                   
115 /* Check if the upper layer header is truncate    
116 static inline bool                                
117 ipv6frag_thdr_truncated(struct sk_buff *skb, i    
118 {                                                 
119         u8 nexthdr = *nexthdrp;                   
120         __be16 frag_off;                          
121         int offset;                               
122                                                   
123         offset = ipv6_skip_exthdr(skb, start,     
124         if (offset < 0 || (frag_off & htons(IP    
125                 return false;                     
126         switch (nexthdr) {                        
127         case NEXTHDR_TCP:                         
128                 offset += sizeof(struct tcphdr    
129                 break;                            
130         case NEXTHDR_UDP:                         
131                 offset += sizeof(struct udphdr    
132                 break;                            
133         case NEXTHDR_ICMP:                        
134                 offset += sizeof(struct icmp6h    
135                 break;                            
136         default:                                  
137                 offset += 1;                      
138         }                                         
139         if (offset > skb->len)                    
140                 return true;                      
141         return false;                             
142 }                                                 
143                                                   
144 #endif                                            
145 #endif                                            
146                                                   

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php