162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci#ifndef _MPC_H_
362306a36Sopenharmony_ci#define _MPC_H_
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci#include <linux/types.h>
662306a36Sopenharmony_ci#include <linux/atm.h>
762306a36Sopenharmony_ci#include <linux/atmmpc.h>
862306a36Sopenharmony_ci#include <linux/skbuff.h>
962306a36Sopenharmony_ci#include <linux/spinlock.h>
1062306a36Sopenharmony_ci#include "mpoa_caches.h"
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci/* kernel -> mpc-daemon */
1362306a36Sopenharmony_ciint msg_to_mpoad(struct k_message *msg, struct mpoa_client *mpc);
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cistruct mpoa_client {
1662306a36Sopenharmony_ci	struct mpoa_client *next;
1762306a36Sopenharmony_ci	struct net_device *dev;      /* lec in question                     */
1862306a36Sopenharmony_ci	int dev_num;                 /* e.g. 2 for lec2                     */
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci	struct atm_vcc *mpoad_vcc;   /* control channel to mpoad            */
2162306a36Sopenharmony_ci	uint8_t mps_ctrl_addr[ATM_ESA_LEN];  /* MPS control ATM address     */
2262306a36Sopenharmony_ci	uint8_t our_ctrl_addr[ATM_ESA_LEN];  /* MPC's control ATM address   */
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci	rwlock_t ingress_lock;
2562306a36Sopenharmony_ci	const struct in_cache_ops *in_ops; /* ingress cache operations      */
2662306a36Sopenharmony_ci	in_cache_entry *in_cache;    /* the ingress cache of this MPC       */
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci	rwlock_t egress_lock;
2962306a36Sopenharmony_ci	const struct eg_cache_ops *eg_ops; /* egress cache operations       */
3062306a36Sopenharmony_ci	eg_cache_entry *eg_cache;    /* the egress  cache of this MPC       */
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	uint8_t *mps_macs;           /* array of MPS MAC addresses, >=1     */
3362306a36Sopenharmony_ci	int number_of_mps_macs;      /* number of the above MAC addresses   */
3462306a36Sopenharmony_ci	struct mpc_parameters parameters;  /* parameters for this client    */
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci	const struct net_device_ops *old_ops;
3762306a36Sopenharmony_ci	struct net_device_ops new_ops;
3862306a36Sopenharmony_ci};
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_cistruct atm_mpoa_qos {
4262306a36Sopenharmony_ci	struct atm_mpoa_qos *next;
4362306a36Sopenharmony_ci	__be32 ipaddr;
4462306a36Sopenharmony_ci	struct atm_qos qos;
4562306a36Sopenharmony_ci};
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci/* MPOA QoS operations */
4962306a36Sopenharmony_cistruct atm_mpoa_qos *atm_mpoa_add_qos(__be32 dst_ip, struct atm_qos *qos);
5062306a36Sopenharmony_cistruct atm_mpoa_qos *atm_mpoa_search_qos(__be32 dst_ip);
5162306a36Sopenharmony_ciint atm_mpoa_delete_qos(struct atm_mpoa_qos *qos);
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci/* Display QoS entries. This is for the procfs */
5462306a36Sopenharmony_cistruct seq_file;
5562306a36Sopenharmony_civoid atm_mpoa_disp_qos(struct seq_file *m);
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci#ifdef CONFIG_PROC_FS
5862306a36Sopenharmony_ciint mpc_proc_init(void);
5962306a36Sopenharmony_civoid mpc_proc_clean(void);
6062306a36Sopenharmony_ci#else
6162306a36Sopenharmony_ci#define mpc_proc_init() (0)
6262306a36Sopenharmony_ci#define mpc_proc_clean() do { } while(0)
6362306a36Sopenharmony_ci#endif
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci#endif /* _MPC_H_ */
66