| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifndef _NET_AH_H
 | 
					
						
							|  |  |  | #define _NET_AH_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-06 19:49:12 +10:00
										 |  |  | #include <linux/crypto.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #include <net/xfrm.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This is the maximum truncated ICV length that we know of. */ | 
					
						
							|  |  |  | #define MAX_AH_AUTH_LEN	12
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct ah_data | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	u8			*work_icv; | 
					
						
							|  |  |  | 	int			icv_full_len; | 
					
						
							|  |  |  | 	int			icv_trunc_len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-20 14:24:50 +10:00
										 |  |  | 	struct crypto_hash	*tfm; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-20 14:24:50 +10:00
										 |  |  | static inline int ah_mac_digest(struct ah_data *ahp, struct sk_buff *skb, | 
					
						
							|  |  |  | 				u8 *auth_data) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-08-20 14:24:50 +10:00
										 |  |  | 	struct hash_desc desc; | 
					
						
							|  |  |  | 	int err; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	desc.tfm = ahp->tfm; | 
					
						
							|  |  |  | 	desc.flags = 0; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	memset(auth_data, 0, ahp->icv_trunc_len); | 
					
						
							| 
									
										
										
										
											2006-08-20 14:24:50 +10:00
										 |  |  | 	err = crypto_hash_init(&desc); | 
					
						
							|  |  |  | 	if (unlikely(err)) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							|  |  |  | 	err = skb_icv_walk(skb, &desc, 0, skb->len, crypto_hash_update); | 
					
						
							|  |  |  | 	if (unlikely(err)) | 
					
						
							|  |  |  | 		goto out; | 
					
						
							|  |  |  | 	err = crypto_hash_final(&desc, ahp->work_icv); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | out: | 
					
						
							|  |  |  | 	return err; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-10 15:45:25 -07:00
										 |  |  | struct ip_auth_hdr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline struct ip_auth_hdr *ip_auth_hdr(const struct sk_buff *skb) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return (struct ip_auth_hdr *)skb_transport_header(skb); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif
 |