Linux Audio

Check our new training course

Loading...
v4.17
 
  1/*
  2 * File: pep.h
  3 *
  4 * Phonet Pipe End Point sockets definitions
  5 *
  6 * Copyright (C) 2008 Nokia Corporation.
  7 *
  8 * This program is free software; you can redistribute it and/or
  9 * modify it under the terms of the GNU General Public License
 10 * version 2 as published by the Free Software Foundation.
 11 *
 12 * This program is distributed in the hope that it will be useful, but
 13 * WITHOUT ANY WARRANTY; without even the implied warranty of
 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 15 * General Public License for more details.
 16 *
 17 * You should have received a copy of the GNU General Public License
 18 * along with this program; if not, write to the Free Software
 19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 20 * 02110-1301 USA
 21 */
 22
 23#ifndef NET_PHONET_PEP_H
 24#define NET_PHONET_PEP_H
 25
 26struct pep_sock {
 27	struct pn_sock		pn_sk;
 28
 29	/* XXX: union-ify listening vs connected stuff ? */
 30	/* Listening socket stuff: */
 31	struct hlist_head	hlist;
 32
 33	/* Connected socket stuff: */
 34	struct sock		*listener;
 35	struct sk_buff_head	ctrlreq_queue;
 36#define PNPIPE_CTRLREQ_MAX	10
 37	atomic_t		tx_credits;
 38	int			ifindex;
 39	u16			peer_type;	/* peer type/subtype */
 40	u8			pipe_handle;
 41
 42	u8			rx_credits;
 43	u8			rx_fc;	/* RX flow control */
 44	u8			tx_fc;	/* TX flow control */
 45	u8			init_enable;	/* auto-enable at creation */
 46	u8			aligned;
 47};
 48
 49static inline struct pep_sock *pep_sk(struct sock *sk)
 50{
 51	return (struct pep_sock *)sk;
 52}
 53
 54extern const struct proto_ops phonet_stream_ops;
 55
 56/* Pipe protocol definitions */
 57struct pnpipehdr {
 58	u8			utid; /* transaction ID */
 59	u8			message_id;
 60	u8			pipe_handle;
 61	union {
 62		u8		state_after_connect;	/* connect request */
 63		u8		state_after_reset;	/* reset request */
 64		u8		error_code;		/* any response */
 65		u8		pep_type;		/* status indication */
 66		u8		data[1];
 67	};
 
 68};
 69#define other_pep_type		data[1]
 70
 71static inline struct pnpipehdr *pnp_hdr(struct sk_buff *skb)
 72{
 73	return (struct pnpipehdr *)skb_transport_header(skb);
 74}
 75
 76#define MAX_PNPIPE_HEADER (MAX_PHONET_HEADER + 4)
 77
 78enum {
 79	PNS_PIPE_CREATE_REQ = 0x00,
 80	PNS_PIPE_CREATE_RESP,
 81	PNS_PIPE_REMOVE_REQ,
 82	PNS_PIPE_REMOVE_RESP,
 83
 84	PNS_PIPE_DATA = 0x20,
 85	PNS_PIPE_ALIGNED_DATA,
 86
 87	PNS_PEP_CONNECT_REQ = 0x40,
 88	PNS_PEP_CONNECT_RESP,
 89	PNS_PEP_DISCONNECT_REQ,
 90	PNS_PEP_DISCONNECT_RESP,
 91	PNS_PEP_RESET_REQ,
 92	PNS_PEP_RESET_RESP,
 93	PNS_PEP_ENABLE_REQ,
 94	PNS_PEP_ENABLE_RESP,
 95	PNS_PEP_CTRL_REQ,
 96	PNS_PEP_CTRL_RESP,
 97	PNS_PEP_DISABLE_REQ = 0x4C,
 98	PNS_PEP_DISABLE_RESP,
 99
100	PNS_PEP_STATUS_IND = 0x60,
101	PNS_PIPE_CREATED_IND,
102	PNS_PIPE_RESET_IND = 0x63,
103	PNS_PIPE_ENABLED_IND,
104	PNS_PIPE_REDIRECTED_IND,
105	PNS_PIPE_DISABLED_IND = 0x66,
106};
107
108#define PN_PIPE_INVALID_HANDLE	0xff
109#define PN_PEP_TYPE_COMMON	0x00
110
111/* Phonet pipe status indication */
112enum {
113	PN_PEP_IND_FLOW_CONTROL,
114	PN_PEP_IND_ID_MCFC_GRANT_CREDITS,
115};
116
117/* Phonet pipe error codes */
118enum {
119	PN_PIPE_NO_ERROR,
120	PN_PIPE_ERR_INVALID_PARAM,
121	PN_PIPE_ERR_INVALID_HANDLE,
122	PN_PIPE_ERR_INVALID_CTRL_ID,
123	PN_PIPE_ERR_NOT_ALLOWED,
124	PN_PIPE_ERR_PEP_IN_USE,
125	PN_PIPE_ERR_OVERLOAD,
126	PN_PIPE_ERR_DEV_DISCONNECTED,
127	PN_PIPE_ERR_TIMEOUT,
128	PN_PIPE_ERR_ALL_PIPES_IN_USE,
129	PN_PIPE_ERR_GENERAL,
130	PN_PIPE_ERR_NOT_SUPPORTED,
131};
132
133/* Phonet pipe states */
134enum {
135	PN_PIPE_DISABLE,
136	PN_PIPE_ENABLE,
137};
138
139/* Phonet pipe sub-block types */
140enum {
141	PN_PIPE_SB_CREATE_REQ_PEP_SUB_TYPE,
142	PN_PIPE_SB_CONNECT_REQ_PEP_SUB_TYPE,
143	PN_PIPE_SB_REDIRECT_REQ_PEP_SUB_TYPE,
144	PN_PIPE_SB_NEGOTIATED_FC,
145	PN_PIPE_SB_REQUIRED_FC_TX,
146	PN_PIPE_SB_PREFERRED_FC_RX,
147	PN_PIPE_SB_ALIGNED_DATA,
148};
149
150/* Phonet pipe flow control models */
151enum {
152	PN_NO_FLOW_CONTROL,
153	PN_LEGACY_FLOW_CONTROL,
154	PN_ONE_CREDIT_FLOW_CONTROL,
155	PN_MULTI_CREDIT_FLOW_CONTROL,
156	PN_MAX_FLOW_CONTROL,
157};
158
159#define pn_flow_safe(fc) ((fc) >> 1)
160
161/* Phonet pipe flow control states */
162enum {
163	PEP_IND_EMPTY,
164	PEP_IND_BUSY,
165	PEP_IND_READY,
166};
167
168#endif
v5.14.15
  1/* SPDX-License-Identifier: GPL-2.0-only */
  2/*
  3 * File: pep.h
  4 *
  5 * Phonet Pipe End Point sockets definitions
  6 *
  7 * Copyright (C) 2008 Nokia Corporation.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  8 */
  9
 10#ifndef NET_PHONET_PEP_H
 11#define NET_PHONET_PEP_H
 12
 13struct pep_sock {
 14	struct pn_sock		pn_sk;
 15
 16	/* XXX: union-ify listening vs connected stuff ? */
 17	/* Listening socket stuff: */
 18	struct hlist_head	hlist;
 19
 20	/* Connected socket stuff: */
 21	struct sock		*listener;
 22	struct sk_buff_head	ctrlreq_queue;
 23#define PNPIPE_CTRLREQ_MAX	10
 24	atomic_t		tx_credits;
 25	int			ifindex;
 26	u16			peer_type;	/* peer type/subtype */
 27	u8			pipe_handle;
 28
 29	u8			rx_credits;
 30	u8			rx_fc;	/* RX flow control */
 31	u8			tx_fc;	/* TX flow control */
 32	u8			init_enable;	/* auto-enable at creation */
 33	u8			aligned;
 34};
 35
 36static inline struct pep_sock *pep_sk(struct sock *sk)
 37{
 38	return (struct pep_sock *)sk;
 39}
 40
 41extern const struct proto_ops phonet_stream_ops;
 42
 43/* Pipe protocol definitions */
 44struct pnpipehdr {
 45	u8			utid; /* transaction ID */
 46	u8			message_id;
 47	u8			pipe_handle;
 48	union {
 49		u8		state_after_connect;	/* connect request */
 50		u8		state_after_reset;	/* reset request */
 51		u8		error_code;		/* any response */
 52		u8		pep_type;		/* status indication */
 53		u8		data0;			/* anything else */
 54	};
 55	u8			data[];
 56};
 57#define other_pep_type		data[0]
 58
 59static inline struct pnpipehdr *pnp_hdr(struct sk_buff *skb)
 60{
 61	return (struct pnpipehdr *)skb_transport_header(skb);
 62}
 63
 64#define MAX_PNPIPE_HEADER (MAX_PHONET_HEADER + 4)
 65
 66enum {
 67	PNS_PIPE_CREATE_REQ = 0x00,
 68	PNS_PIPE_CREATE_RESP,
 69	PNS_PIPE_REMOVE_REQ,
 70	PNS_PIPE_REMOVE_RESP,
 71
 72	PNS_PIPE_DATA = 0x20,
 73	PNS_PIPE_ALIGNED_DATA,
 74
 75	PNS_PEP_CONNECT_REQ = 0x40,
 76	PNS_PEP_CONNECT_RESP,
 77	PNS_PEP_DISCONNECT_REQ,
 78	PNS_PEP_DISCONNECT_RESP,
 79	PNS_PEP_RESET_REQ,
 80	PNS_PEP_RESET_RESP,
 81	PNS_PEP_ENABLE_REQ,
 82	PNS_PEP_ENABLE_RESP,
 83	PNS_PEP_CTRL_REQ,
 84	PNS_PEP_CTRL_RESP,
 85	PNS_PEP_DISABLE_REQ = 0x4C,
 86	PNS_PEP_DISABLE_RESP,
 87
 88	PNS_PEP_STATUS_IND = 0x60,
 89	PNS_PIPE_CREATED_IND,
 90	PNS_PIPE_RESET_IND = 0x63,
 91	PNS_PIPE_ENABLED_IND,
 92	PNS_PIPE_REDIRECTED_IND,
 93	PNS_PIPE_DISABLED_IND = 0x66,
 94};
 95
 96#define PN_PIPE_INVALID_HANDLE	0xff
 97#define PN_PEP_TYPE_COMMON	0x00
 98
 99/* Phonet pipe status indication */
100enum {
101	PN_PEP_IND_FLOW_CONTROL,
102	PN_PEP_IND_ID_MCFC_GRANT_CREDITS,
103};
104
105/* Phonet pipe error codes */
106enum {
107	PN_PIPE_NO_ERROR,
108	PN_PIPE_ERR_INVALID_PARAM,
109	PN_PIPE_ERR_INVALID_HANDLE,
110	PN_PIPE_ERR_INVALID_CTRL_ID,
111	PN_PIPE_ERR_NOT_ALLOWED,
112	PN_PIPE_ERR_PEP_IN_USE,
113	PN_PIPE_ERR_OVERLOAD,
114	PN_PIPE_ERR_DEV_DISCONNECTED,
115	PN_PIPE_ERR_TIMEOUT,
116	PN_PIPE_ERR_ALL_PIPES_IN_USE,
117	PN_PIPE_ERR_GENERAL,
118	PN_PIPE_ERR_NOT_SUPPORTED,
119};
120
121/* Phonet pipe states */
122enum {
123	PN_PIPE_DISABLE,
124	PN_PIPE_ENABLE,
125};
126
127/* Phonet pipe sub-block types */
128enum {
129	PN_PIPE_SB_CREATE_REQ_PEP_SUB_TYPE,
130	PN_PIPE_SB_CONNECT_REQ_PEP_SUB_TYPE,
131	PN_PIPE_SB_REDIRECT_REQ_PEP_SUB_TYPE,
132	PN_PIPE_SB_NEGOTIATED_FC,
133	PN_PIPE_SB_REQUIRED_FC_TX,
134	PN_PIPE_SB_PREFERRED_FC_RX,
135	PN_PIPE_SB_ALIGNED_DATA,
136};
137
138/* Phonet pipe flow control models */
139enum {
140	PN_NO_FLOW_CONTROL,
141	PN_LEGACY_FLOW_CONTROL,
142	PN_ONE_CREDIT_FLOW_CONTROL,
143	PN_MULTI_CREDIT_FLOW_CONTROL,
144	PN_MAX_FLOW_CONTROL,
145};
146
147#define pn_flow_safe(fc) ((fc) >> 1)
148
149/* Phonet pipe flow control states */
150enum {
151	PEP_IND_EMPTY,
152	PEP_IND_BUSY,
153	PEP_IND_READY,
154};
155
156#endif