162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0+ */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci *  IPv6 IOAM implementation
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci *  Author:
662306a36Sopenharmony_ci *  Justin Iurman <justin.iurman@uliege.be>
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#ifndef _NET_IOAM6_H
1062306a36Sopenharmony_ci#define _NET_IOAM6_H
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci#include <linux/net.h>
1362306a36Sopenharmony_ci#include <linux/ipv6.h>
1462306a36Sopenharmony_ci#include <linux/ioam6.h>
1562306a36Sopenharmony_ci#include <linux/rhashtable-types.h>
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_cistruct ioam6_namespace {
1862306a36Sopenharmony_ci	struct rhash_head head;
1962306a36Sopenharmony_ci	struct rcu_head rcu;
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci	struct ioam6_schema __rcu *schema;
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci	__be16 id;
2462306a36Sopenharmony_ci	__be32 data;
2562306a36Sopenharmony_ci	__be64 data_wide;
2662306a36Sopenharmony_ci};
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_cistruct ioam6_schema {
2962306a36Sopenharmony_ci	struct rhash_head head;
3062306a36Sopenharmony_ci	struct rcu_head rcu;
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	struct ioam6_namespace __rcu *ns;
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci	u32 id;
3562306a36Sopenharmony_ci	int len;
3662306a36Sopenharmony_ci	__be32 hdr;
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci	u8 data[];
3962306a36Sopenharmony_ci};
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_cistruct ioam6_pernet_data {
4262306a36Sopenharmony_ci	struct mutex lock;
4362306a36Sopenharmony_ci	struct rhashtable namespaces;
4462306a36Sopenharmony_ci	struct rhashtable schemas;
4562306a36Sopenharmony_ci};
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_cistatic inline struct ioam6_pernet_data *ioam6_pernet(struct net *net)
4862306a36Sopenharmony_ci{
4962306a36Sopenharmony_ci#if IS_ENABLED(CONFIG_IPV6)
5062306a36Sopenharmony_ci	return net->ipv6.ioam6_data;
5162306a36Sopenharmony_ci#else
5262306a36Sopenharmony_ci	return NULL;
5362306a36Sopenharmony_ci#endif
5462306a36Sopenharmony_ci}
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cistruct ioam6_namespace *ioam6_namespace(struct net *net, __be16 id);
5762306a36Sopenharmony_civoid ioam6_fill_trace_data(struct sk_buff *skb,
5862306a36Sopenharmony_ci			   struct ioam6_namespace *ns,
5962306a36Sopenharmony_ci			   struct ioam6_trace_hdr *trace,
6062306a36Sopenharmony_ci			   bool is_input);
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ciint ioam6_init(void);
6362306a36Sopenharmony_civoid ioam6_exit(void);
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ciint ioam6_iptunnel_init(void);
6662306a36Sopenharmony_civoid ioam6_iptunnel_exit(void);
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci#endif /* _NET_IOAM6_H */
69