Linux Audio

Check our new training course

Loading...
v4.17
 
  1/*
  2 * Copyright (c) 2015 Tom Herbert <tom@herbertland.com>
  3 *
  4 * This program is free software; you can redistribute it and/or
  5 * modify it under the terms of the GNU General Public License as
  6 * published by the Free Software Foundation; either version 2 of
  7 * the License, or (at your option) any later version.
  8 *
  9 */
 10
 11#ifndef __ILA_H
 12#define __ILA_H
 13
 14#include <linux/errno.h>
 15#include <linux/ip.h>
 16#include <linux/kernel.h>
 17#include <linux/module.h>
 18#include <linux/socket.h>
 19#include <linux/skbuff.h>
 20#include <linux/types.h>
 21#include <net/checksum.h>
 
 22#include <net/ip.h>
 23#include <net/protocol.h>
 24#include <uapi/linux/ila.h>
 25
 26struct ila_locator {
 27	union {
 28		__u8            v8[8];
 29		__be16          v16[4];
 30		__be32          v32[2];
 31		__be64		v64;
 32	};
 33};
 34
 35struct ila_identifier {
 36	union {
 37		struct {
 38#if defined(__LITTLE_ENDIAN_BITFIELD)
 39			u8 __space:4;
 40			u8 csum_neutral:1;
 41			u8 type:3;
 42#elif defined(__BIG_ENDIAN_BITFIELD)
 43			u8 type:3;
 44			u8 csum_neutral:1;
 45			u8 __space:4;
 46#else
 47#error  "Adjust your <asm/byteorder.h> defines"
 48#endif
 49			u8 __space2[7];
 50		};
 51		__u8            v8[8];
 52		__be16          v16[4];
 53		__be32          v32[2];
 54		__be64		v64;
 55	};
 56};
 57
 58#define CSUM_NEUTRAL_FLAG	htonl(0x10000000)
 59
 60struct ila_addr {
 61	union {
 62		struct in6_addr addr;
 63		struct {
 64			struct ila_locator loc;
 65			struct ila_identifier ident;
 66		};
 67	};
 68};
 69
 70static inline struct ila_addr *ila_a2i(struct in6_addr *addr)
 71{
 72	return (struct ila_addr *)addr;
 73}
 74
 75static inline bool ila_addr_is_ila(struct ila_addr *iaddr)
 76{
 77	return (iaddr->ident.type != ILA_ATYPE_IID);
 78}
 79
 80struct ila_params {
 81	struct ila_locator locator;
 82	struct ila_locator locator_match;
 83	__wsum csum_diff;
 84	u8 csum_mode;
 85	u8 ident_type;
 86};
 87
 88static inline __wsum compute_csum_diff8(const __be32 *from, const __be32 *to)
 89{
 90	__be32 diff[] = {
 91		~from[0], ~from[1], to[0], to[1],
 92	};
 93
 94	return csum_partial(diff, sizeof(diff), 0);
 95}
 96
 97static inline bool ila_csum_neutral_set(struct ila_identifier ident)
 98{
 99	return !!(ident.csum_neutral);
100}
101
102void ila_update_ipv6_locator(struct sk_buff *skb, struct ila_params *p,
103			     bool set_csum_neutral);
104
105void ila_init_saved_csum(struct ila_params *p);
106
 
 
 
 
 
 
 
 
 
107int ila_lwt_init(void);
108void ila_lwt_fini(void);
109int ila_xlat_init(void);
110void ila_xlat_fini(void);
 
 
 
 
 
 
 
 
 
 
 
 
 
111
112#endif /* __ILA_H */
v6.8
  1/* SPDX-License-Identifier: GPL-2.0-or-later */
  2/*
  3 * Copyright (c) 2015 Tom Herbert <tom@herbertland.com>
 
 
 
 
 
 
  4 */
  5
  6#ifndef __ILA_H
  7#define __ILA_H
  8
  9#include <linux/errno.h>
 10#include <linux/ip.h>
 11#include <linux/kernel.h>
 12#include <linux/module.h>
 13#include <linux/socket.h>
 14#include <linux/skbuff.h>
 15#include <linux/types.h>
 16#include <net/checksum.h>
 17#include <net/genetlink.h>
 18#include <net/ip.h>
 19#include <net/protocol.h>
 20#include <uapi/linux/ila.h>
 21
 22struct ila_locator {
 23	union {
 24		__u8            v8[8];
 25		__be16          v16[4];
 26		__be32          v32[2];
 27		__be64		v64;
 28	};
 29};
 30
 31struct ila_identifier {
 32	union {
 33		struct {
 34#if defined(__LITTLE_ENDIAN_BITFIELD)
 35			u8 __space:4;
 36			u8 csum_neutral:1;
 37			u8 type:3;
 38#elif defined(__BIG_ENDIAN_BITFIELD)
 39			u8 type:3;
 40			u8 csum_neutral:1;
 41			u8 __space:4;
 42#else
 43#error  "Adjust your <asm/byteorder.h> defines"
 44#endif
 45			u8 __space2[7];
 46		};
 47		__u8            v8[8];
 48		__be16          v16[4];
 49		__be32          v32[2];
 50		__be64		v64;
 51	};
 52};
 53
 54#define CSUM_NEUTRAL_FLAG	htonl(0x10000000)
 55
 56struct ila_addr {
 57	union {
 58		struct in6_addr addr;
 59		struct {
 60			struct ila_locator loc;
 61			struct ila_identifier ident;
 62		};
 63	};
 64};
 65
 66static inline struct ila_addr *ila_a2i(struct in6_addr *addr)
 67{
 68	return (struct ila_addr *)addr;
 69}
 70
 
 
 
 
 
 71struct ila_params {
 72	struct ila_locator locator;
 73	struct ila_locator locator_match;
 74	__wsum csum_diff;
 75	u8 csum_mode;
 76	u8 ident_type;
 77};
 78
 79static inline __wsum compute_csum_diff8(const __be32 *from, const __be32 *to)
 80{
 81	__be32 diff[] = {
 82		~from[0], ~from[1], to[0], to[1],
 83	};
 84
 85	return csum_partial(diff, sizeof(diff), 0);
 86}
 87
 88static inline bool ila_csum_neutral_set(struct ila_identifier ident)
 89{
 90	return !!(ident.csum_neutral);
 91}
 92
 93void ila_update_ipv6_locator(struct sk_buff *skb, struct ila_params *p,
 94			     bool set_csum_neutral);
 95
 96void ila_init_saved_csum(struct ila_params *p);
 97
 98struct ila_net {
 99	struct {
100		struct rhashtable rhash_table;
101		spinlock_t *locks; /* Bucket locks for entry manipulation */
102		unsigned int locks_mask;
103		bool hooks_registered;
104	} xlat;
105};
106
107int ila_lwt_init(void);
108void ila_lwt_fini(void);
109
110int ila_xlat_init_net(struct net *net);
111void ila_xlat_exit_net(struct net *net);
112
113int ila_xlat_nl_cmd_add_mapping(struct sk_buff *skb, struct genl_info *info);
114int ila_xlat_nl_cmd_del_mapping(struct sk_buff *skb, struct genl_info *info);
115int ila_xlat_nl_cmd_get_mapping(struct sk_buff *skb, struct genl_info *info);
116int ila_xlat_nl_cmd_flush(struct sk_buff *skb, struct genl_info *info);
117int ila_xlat_nl_dump_start(struct netlink_callback *cb);
118int ila_xlat_nl_dump_done(struct netlink_callback *cb);
119int ila_xlat_nl_dump(struct sk_buff *skb, struct netlink_callback *cb);
120
121extern unsigned int ila_net_id;
122
123extern struct genl_family ila_nl_family;
124
125#endif /* __ILA_H */