xref: /linux-6.15/include/net/caif/cfctrl.h (revision af873fce)
1*af873fceSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
209009f30SSjur Braendeland /*
309009f30SSjur Braendeland  * Copyright (C) ST-Ericsson AB 2010
426ee65e6S[email protected]  * Author:	Sjur Brendeland
509009f30SSjur Braendeland  */
609009f30SSjur Braendeland 
709009f30SSjur Braendeland #ifndef CFCTRL_H_
809009f30SSjur Braendeland #define CFCTRL_H_
909009f30SSjur Braendeland #include <net/caif/caif_layer.h>
1009009f30SSjur Braendeland #include <net/caif/cfsrvl.h>
1109009f30SSjur Braendeland 
1209009f30SSjur Braendeland /* CAIF Control packet commands */
1309009f30SSjur Braendeland enum cfctrl_cmd {
1409009f30SSjur Braendeland 	CFCTRL_CMD_LINK_SETUP = 0,
1509009f30SSjur Braendeland 	CFCTRL_CMD_LINK_DESTROY = 1,
1609009f30SSjur Braendeland 	CFCTRL_CMD_LINK_ERR = 2,
1709009f30SSjur Braendeland 	CFCTRL_CMD_ENUM = 3,
1809009f30SSjur Braendeland 	CFCTRL_CMD_SLEEP = 4,
1909009f30SSjur Braendeland 	CFCTRL_CMD_WAKE = 5,
2009009f30SSjur Braendeland 	CFCTRL_CMD_LINK_RECONF = 6,
2109009f30SSjur Braendeland 	CFCTRL_CMD_START_REASON = 7,
2209009f30SSjur Braendeland 	CFCTRL_CMD_RADIO_SET = 8,
2309009f30SSjur Braendeland 	CFCTRL_CMD_MODEM_SET = 9,
2409009f30SSjur Braendeland 	CFCTRL_CMD_MASK = 0xf
2509009f30SSjur Braendeland };
2609009f30SSjur Braendeland 
2709009f30SSjur Braendeland /* Channel types */
2809009f30SSjur Braendeland enum cfctrl_srv {
2909009f30SSjur Braendeland 	CFCTRL_SRV_DECM = 0,
3009009f30SSjur Braendeland 	CFCTRL_SRV_VEI = 1,
3109009f30SSjur Braendeland 	CFCTRL_SRV_VIDEO = 2,
3209009f30SSjur Braendeland 	CFCTRL_SRV_DBG = 3,
3309009f30SSjur Braendeland 	CFCTRL_SRV_DATAGRAM = 4,
3409009f30SSjur Braendeland 	CFCTRL_SRV_RFM = 5,
3509009f30SSjur Braendeland 	CFCTRL_SRV_UTIL = 6,
3609009f30SSjur Braendeland 	CFCTRL_SRV_MASK = 0xf
3709009f30SSjur Braendeland };
3809009f30SSjur Braendeland 
3909009f30SSjur Braendeland #define CFCTRL_RSP_BIT 0x20
4009009f30SSjur Braendeland #define CFCTRL_ERR_BIT 0x10
4109009f30SSjur Braendeland 
4209009f30SSjur Braendeland struct cfctrl_rsp {
4309009f30SSjur Braendeland 	void (*linksetup_rsp)(struct cflayer *layer, u8 linkid,
4409009f30SSjur Braendeland 			      enum cfctrl_srv serv, u8 phyid,
4509009f30SSjur Braendeland 			      struct cflayer *adapt_layer);
468d545c8fSSjur Braendeland 	void (*linkdestroy_rsp)(struct cflayer *layer, u8 linkid);
4709009f30SSjur Braendeland 	void (*linkerror_ind)(void);
4809009f30SSjur Braendeland 	void (*enum_rsp)(void);
4909009f30SSjur Braendeland 	void (*sleep_rsp)(void);
5009009f30SSjur Braendeland 	void (*wake_rsp)(void);
5109009f30SSjur Braendeland 	void (*restart_rsp)(void);
5209009f30SSjur Braendeland 	void (*radioset_rsp)(void);
5309009f30SSjur Braendeland 	void (*reject_rsp)(struct cflayer *layer, u8 linkid,
54d577f1ccSJoe Perches 				struct cflayer *client_layer);
5509009f30SSjur Braendeland };
5609009f30SSjur Braendeland 
5709009f30SSjur Braendeland /* Link Setup Parameters for CAIF-Links. */
5809009f30SSjur Braendeland struct cfctrl_link_param {
5909009f30SSjur Braendeland 	enum cfctrl_srv linktype;/* (T3,T0) Type of Channel */
6009009f30SSjur Braendeland 	u8 priority;		  /* (P4,P0) Priority of the channel */
6109009f30SSjur Braendeland 	u8 phyid;		  /* (U2-U0) Physical interface to connect */
6209009f30SSjur Braendeland 	u8 endpoint;		  /* (E1,E0) Endpoint for data channels */
6309009f30SSjur Braendeland 	u8 chtype;		  /* (H1,H0) Channel-Type, applies to
6409009f30SSjur Braendeland 				   *            VEI, DEBUG */
6509009f30SSjur Braendeland 	union {
6609009f30SSjur Braendeland 		struct {
6709009f30SSjur Braendeland 			u8 connid;	/*  (D7,D0) Video LinkId */
6809009f30SSjur Braendeland 		} video;
6909009f30SSjur Braendeland 
7009009f30SSjur Braendeland 		struct {
7109009f30SSjur Braendeland 			u32 connid;	/* (N31,Ngit0) Connection ID used
7209009f30SSjur Braendeland 					 *  for Datagram */
7309009f30SSjur Braendeland 		} datagram;
7409009f30SSjur Braendeland 
7509009f30SSjur Braendeland 		struct {
7609009f30SSjur Braendeland 			u32 connid;	/* Connection ID used for RFM */
7709009f30SSjur Braendeland 			char volume[20];	/* Volume to mount for RFM */
7809009f30SSjur Braendeland 		} rfm;		/* Configuration for RFM */
7909009f30SSjur Braendeland 
8009009f30SSjur Braendeland 		struct {
8109009f30SSjur Braendeland 			u16 fifosize_kb;	/* Psock FIFO size in KB */
8209009f30SSjur Braendeland 			u16 fifosize_bufs;	/* Psock # signal buffers */
8309009f30SSjur Braendeland 			char name[16];	/* Name of the PSOCK service */
8409009f30SSjur Braendeland 			u8 params[255];	/* Link setup Parameters> */
8509009f30SSjur Braendeland 			u16 paramlen;	/* Length of Link Setup
8609009f30SSjur Braendeland 						 *   Parameters */
8709009f30SSjur Braendeland 		} utility;	/* Configuration for Utility Links (Psock) */
8809009f30SSjur Braendeland 	} u;
8909009f30SSjur Braendeland };
9009009f30SSjur Braendeland 
9109009f30SSjur Braendeland /* This structure is used internally in CFCTRL */
9209009f30SSjur Braendeland struct cfctrl_request_info {
9309009f30SSjur Braendeland 	int sequence_no;
9409009f30SSjur Braendeland 	enum cfctrl_cmd cmd;
9509009f30SSjur Braendeland 	u8 channel_id;
9609009f30SSjur Braendeland 	struct cfctrl_link_param param;
9709009f30SSjur Braendeland 	struct cflayer *client_layer;
987aecf494SSjur Braendeland 	struct list_head list;
9909009f30SSjur Braendeland };
10009009f30SSjur Braendeland 
10109009f30SSjur Braendeland struct cfctrl {
10209009f30SSjur Braendeland 	struct cfsrvl serv;
10309009f30SSjur Braendeland 	struct cfctrl_rsp res;
10409009f30SSjur Braendeland 	atomic_t req_seq_no;
10509009f30SSjur Braendeland 	atomic_t rsp_seq_no;
1067aecf494SSjur Braendeland 	struct list_head list;
10709009f30SSjur Braendeland 	/* Protects from simultaneous access to first_req list */
10809009f30SSjur Braendeland 	spinlock_t info_list_lock;
10909009f30SSjur Braendeland #ifndef CAIF_NO_LOOP
11009009f30SSjur Braendeland 	u8 loop_linkid;
11109009f30SSjur Braendeland 	int loop_linkused[256];
11209009f30SSjur Braendeland 	/* Protects simultaneous access to loop_linkid and loop_linkused */
11309009f30SSjur Braendeland 	spinlock_t loop_linkid_lock;
11409009f30SSjur Braendeland #endif
11509009f30SSjur Braendeland 
11609009f30SSjur Braendeland };
11709009f30SSjur Braendeland 
11809009f30SSjur Braendeland void cfctrl_enum_req(struct cflayer *cfctrl, u8 physlinkid);
1198d545c8fSSjur Braendeland int cfctrl_linkup_request(struct cflayer *cfctrl,
12009009f30SSjur Braendeland 			   struct cfctrl_link_param *param,
12109009f30SSjur Braendeland 			   struct cflayer *user_layer);
12209009f30SSjur Braendeland int  cfctrl_linkdown_req(struct cflayer *cfctrl, u8 linkid,
12309009f30SSjur Braendeland 			 struct cflayer *client);
12473d6ac63SStephen Hemminger 
12509009f30SSjur Braendeland struct cflayer *cfctrl_create(void);
12609009f30SSjur Braendeland struct cfctrl_rsp *cfctrl_get_respfuncs(struct cflayer *layer);
127c85c2951S[email protected] int cfctrl_cancel_req(struct cflayer *layr, struct cflayer *adap_layer);
128c85c2951S[email protected] void cfctrl_remove(struct cflayer *layr);
1298d545c8fSSjur Braendeland 
13009009f30SSjur Braendeland #endif				/* CFCTRL_H_ */
131