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