xref: /openbmc/linux/include/net/caif/cfpkt.h (revision 75bf465f0bc33e9b776a46d6a1b9b990f5fb7c37)
1*af873fceSThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
209009f30SSjur Braendeland /*
309009f30SSjur Braendeland  * Copyright (C) ST-Ericsson AB 2010
426ee65e6Ssjur.brandeland@stericsson.com  * Author:	Sjur Brendeland
509009f30SSjur Braendeland  */
609009f30SSjur Braendeland 
709009f30SSjur Braendeland #ifndef CFPKT_H_
809009f30SSjur Braendeland #define CFPKT_H_
909009f30SSjur Braendeland #include <net/caif/caif_layer.h>
1009009f30SSjur Braendeland #include <linux/types.h>
1109009f30SSjur Braendeland struct cfpkt;
1209009f30SSjur Braendeland 
1309009f30SSjur Braendeland /* Create a CAIF packet.
1409009f30SSjur Braendeland  * len: Length of packet to be created
1509009f30SSjur Braendeland  * @return New packet.
1609009f30SSjur Braendeland  */
1709009f30SSjur Braendeland struct cfpkt *cfpkt_create(u16 len);
1809009f30SSjur Braendeland 
1909009f30SSjur Braendeland /*
2009009f30SSjur Braendeland  * Destroy a CAIF Packet.
2109009f30SSjur Braendeland  * pkt Packet to be destoyed.
2209009f30SSjur Braendeland  */
2309009f30SSjur Braendeland void cfpkt_destroy(struct cfpkt *pkt);
2409009f30SSjur Braendeland 
2509009f30SSjur Braendeland /*
2609009f30SSjur Braendeland  * Extract header from packet.
2709009f30SSjur Braendeland  *
2809009f30SSjur Braendeland  * pkt Packet to extract header data from.
2909009f30SSjur Braendeland  * data Pointer to copy the header data into.
3009009f30SSjur Braendeland  * len Length of head data to copy.
3109009f30SSjur Braendeland  * @return zero on success and error code upon failure
3209009f30SSjur Braendeland  */
3309009f30SSjur Braendeland int cfpkt_extr_head(struct cfpkt *pkt, void *data, u16 len);
3409009f30SSjur Braendeland 
cfpkt_extr_head_u8(struct cfpkt * pkt)35ce628966SArnd Bergmann static inline u8 cfpkt_extr_head_u8(struct cfpkt *pkt)
36ce628966SArnd Bergmann {
37ce628966SArnd Bergmann 	u8 tmp;
38ce628966SArnd Bergmann 
39ce628966SArnd Bergmann 	cfpkt_extr_head(pkt, &tmp, 1);
40ce628966SArnd Bergmann 
41ce628966SArnd Bergmann 	return tmp;
42ce628966SArnd Bergmann }
43ce628966SArnd Bergmann 
cfpkt_extr_head_u16(struct cfpkt * pkt)44ce628966SArnd Bergmann static inline u16 cfpkt_extr_head_u16(struct cfpkt *pkt)
45ce628966SArnd Bergmann {
46ce628966SArnd Bergmann 	__le16 tmp;
47ce628966SArnd Bergmann 
48ce628966SArnd Bergmann 	cfpkt_extr_head(pkt, &tmp, 2);
49ce628966SArnd Bergmann 
50ce628966SArnd Bergmann 	return le16_to_cpu(tmp);
51ce628966SArnd Bergmann }
52ce628966SArnd Bergmann 
cfpkt_extr_head_u32(struct cfpkt * pkt)53ce628966SArnd Bergmann static inline u32 cfpkt_extr_head_u32(struct cfpkt *pkt)
54ce628966SArnd Bergmann {
55ce628966SArnd Bergmann 	__le32 tmp;
56ce628966SArnd Bergmann 
57ce628966SArnd Bergmann 	cfpkt_extr_head(pkt, &tmp, 4);
58ce628966SArnd Bergmann 
59ce628966SArnd Bergmann 	return le32_to_cpu(tmp);
60ce628966SArnd Bergmann }
61ce628966SArnd Bergmann 
6209009f30SSjur Braendeland /*
6309009f30SSjur Braendeland  * Peek header from packet.
6409009f30SSjur Braendeland  * Reads data from packet without changing packet.
6509009f30SSjur Braendeland  *
6609009f30SSjur Braendeland  * pkt Packet to extract header data from.
6709009f30SSjur Braendeland  * data Pointer to copy the header data into.
6809009f30SSjur Braendeland  * len Length of head data to copy.
6909009f30SSjur Braendeland  * @return zero on success and error code upon failure
7009009f30SSjur Braendeland  */
7109009f30SSjur Braendeland int cfpkt_peek_head(struct cfpkt *pkt, void *data, u16 len);
7209009f30SSjur Braendeland 
7309009f30SSjur Braendeland /*
7409009f30SSjur Braendeland  * Extract header from trailer (end of packet).
7509009f30SSjur Braendeland  *
7609009f30SSjur Braendeland  * pkt Packet to extract header data from.
7709009f30SSjur Braendeland  * data Pointer to copy the trailer data into.
7809009f30SSjur Braendeland  * len Length of header data to copy.
7909009f30SSjur Braendeland  * @return zero on success and error code upon failure
8009009f30SSjur Braendeland  */
8109009f30SSjur Braendeland int cfpkt_extr_trail(struct cfpkt *pkt, void *data, u16 len);
8209009f30SSjur Braendeland 
8309009f30SSjur Braendeland /*
8409009f30SSjur Braendeland  * Add header to packet.
8509009f30SSjur Braendeland  *
8609009f30SSjur Braendeland  *
8709009f30SSjur Braendeland  * pkt Packet to add header data to.
8809009f30SSjur Braendeland  * data Pointer to data to copy into the header.
8909009f30SSjur Braendeland  * len Length of header data to copy.
9009009f30SSjur Braendeland  * @return zero on success and error code upon failure
9109009f30SSjur Braendeland  */
9209009f30SSjur Braendeland int cfpkt_add_head(struct cfpkt *pkt, const void *data, u16 len);
9309009f30SSjur Braendeland 
9409009f30SSjur Braendeland /*
9509009f30SSjur Braendeland  * Add trailer to packet.
9609009f30SSjur Braendeland  *
9709009f30SSjur Braendeland  *
9809009f30SSjur Braendeland  * pkt Packet to add trailer data to.
9909009f30SSjur Braendeland  * data Pointer to data to copy into the trailer.
10009009f30SSjur Braendeland  * len Length of trailer data to copy.
10109009f30SSjur Braendeland  * @return zero on success and error code upon failure
10209009f30SSjur Braendeland  */
10309009f30SSjur Braendeland int cfpkt_add_trail(struct cfpkt *pkt, const void *data, u16 len);
10409009f30SSjur Braendeland 
10509009f30SSjur Braendeland /*
10609009f30SSjur Braendeland  * Pad trailer on packet.
10709009f30SSjur Braendeland  * Moves data pointer in packet, no content copied.
10809009f30SSjur Braendeland  *
10909009f30SSjur Braendeland  * pkt Packet in which to pad trailer.
11009009f30SSjur Braendeland  * len Length of padding to add.
11109009f30SSjur Braendeland  * @return zero on success and error code upon failure
11209009f30SSjur Braendeland  */
11309009f30SSjur Braendeland int cfpkt_pad_trail(struct cfpkt *pkt, u16 len);
11409009f30SSjur Braendeland 
11509009f30SSjur Braendeland /*
11609009f30SSjur Braendeland  * Add a single byte to packet body (tail).
11709009f30SSjur Braendeland  *
11809009f30SSjur Braendeland  * pkt Packet in which to add byte.
11909009f30SSjur Braendeland  * data Byte to add.
12009009f30SSjur Braendeland  * @return zero on success and error code upon failure
12109009f30SSjur Braendeland  */
12209009f30SSjur Braendeland int cfpkt_addbdy(struct cfpkt *pkt, const u8 data);
12309009f30SSjur Braendeland 
12409009f30SSjur Braendeland /*
12509009f30SSjur Braendeland  * Add a data to packet body (tail).
12609009f30SSjur Braendeland  *
12709009f30SSjur Braendeland  * pkt Packet in which to add data.
12809009f30SSjur Braendeland  * data Pointer to data to copy into the packet body.
12909009f30SSjur Braendeland  * len Length of data to add.
13009009f30SSjur Braendeland  * @return zero on success and error code upon failure
13109009f30SSjur Braendeland  */
13209009f30SSjur Braendeland int cfpkt_add_body(struct cfpkt *pkt, const void *data, u16 len);
13309009f30SSjur Braendeland 
13409009f30SSjur Braendeland /*
13509009f30SSjur Braendeland  * Checks whether there are more data to process in packet.
13609009f30SSjur Braendeland  * pkt Packet to check.
13709009f30SSjur Braendeland  * @return true if more data are available in packet false otherwise
13809009f30SSjur Braendeland  */
13909009f30SSjur Braendeland bool cfpkt_more(struct cfpkt *pkt);
14009009f30SSjur Braendeland 
14109009f30SSjur Braendeland /*
14209009f30SSjur Braendeland  * Checks whether the packet is erroneous,
14309009f30SSjur Braendeland  * i.e. if it has been attempted to extract more data than available in packet
14409009f30SSjur Braendeland  * or writing more data than has been allocated in cfpkt_create().
14509009f30SSjur Braendeland  * pkt Packet to check.
14609009f30SSjur Braendeland  * @return true on error false otherwise
14709009f30SSjur Braendeland  */
14809009f30SSjur Braendeland bool cfpkt_erroneous(struct cfpkt *pkt);
14909009f30SSjur Braendeland 
15009009f30SSjur Braendeland /*
15109009f30SSjur Braendeland  * Get the packet length.
15209009f30SSjur Braendeland  * pkt Packet to get length from.
15309009f30SSjur Braendeland  * @return Number of bytes in packet.
15409009f30SSjur Braendeland  */
15509009f30SSjur Braendeland u16 cfpkt_getlen(struct cfpkt *pkt);
15609009f30SSjur Braendeland 
15709009f30SSjur Braendeland /*
15809009f30SSjur Braendeland  * Set the packet length, by adjusting the trailer pointer according to length.
15909009f30SSjur Braendeland  * pkt Packet to set length.
16009009f30SSjur Braendeland  * len Packet length.
16109009f30SSjur Braendeland  * @return Number of bytes in packet.
16209009f30SSjur Braendeland  */
16309009f30SSjur Braendeland int cfpkt_setlen(struct cfpkt *pkt, u16 len);
16409009f30SSjur Braendeland 
16509009f30SSjur Braendeland /*
16609009f30SSjur Braendeland  * cfpkt_append - Appends a packet's data to another packet.
16709009f30SSjur Braendeland  * dstpkt:    Packet to append data into, WILL BE FREED BY THIS FUNCTION
16809009f30SSjur Braendeland  * addpkt:    Packet to be appended and automatically released,
16909009f30SSjur Braendeland  *            WILL BE FREED BY THIS FUNCTION.
17009009f30SSjur Braendeland  * expectlen: Packet's expected total length. This should be considered
17109009f30SSjur Braendeland  *            as a hint.
17209009f30SSjur Braendeland  * NB: Input packets will be destroyed after appending and cannot be used
17309009f30SSjur Braendeland  * after calling this function.
17409009f30SSjur Braendeland  * @return    The new appended packet.
17509009f30SSjur Braendeland  */
17609009f30SSjur Braendeland struct cfpkt *cfpkt_append(struct cfpkt *dstpkt, struct cfpkt *addpkt,
17709009f30SSjur Braendeland 		      u16 expectlen);
17809009f30SSjur Braendeland 
17909009f30SSjur Braendeland /*
18009009f30SSjur Braendeland  * cfpkt_split - Split a packet into two packets at the specified split point.
18109009f30SSjur Braendeland  * pkt: Packet to be split (will contain the first part of the data on exit)
18209009f30SSjur Braendeland  * pos: Position to split packet in two parts.
18309009f30SSjur Braendeland  * @return The new packet, containing the second part of the data.
18409009f30SSjur Braendeland  */
18509009f30SSjur Braendeland struct cfpkt *cfpkt_split(struct cfpkt *pkt, u16 pos);
18609009f30SSjur Braendeland 
18709009f30SSjur Braendeland /*
18809009f30SSjur Braendeland  * Iteration function, iterates the packet buffers from start to end.
18909009f30SSjur Braendeland  *
19009009f30SSjur Braendeland  * Checksum iteration function used to iterate buffers
19109009f30SSjur Braendeland  * (we may have packets consisting of a chain of buffers)
19209009f30SSjur Braendeland  * pkt:       Packet to calculate checksum for
19309009f30SSjur Braendeland  * iter_func: Function pointer to iteration function
19409009f30SSjur Braendeland  * chks:      Checksum calculated so far.
19509009f30SSjur Braendeland  * buf:       Pointer to the buffer to checksum
19609009f30SSjur Braendeland  * len:       Length of buf.
19709009f30SSjur Braendeland  * data:      Initial checksum value.
19809009f30SSjur Braendeland  * @return    Checksum of buffer.
19909009f30SSjur Braendeland  */
20009009f30SSjur Braendeland 
201278f7b4fSDan Carpenter int cfpkt_iterate(struct cfpkt *pkt,
20209009f30SSjur Braendeland 		u16 (*iter_func)(u16 chks, void *buf, u16 len),
20309009f30SSjur Braendeland 		u16 data);
20409009f30SSjur Braendeland 
20509009f30SSjur Braendeland /* Map from a "native" packet (e.g. Linux Socket Buffer) to a CAIF packet.
20609009f30SSjur Braendeland  *  dir - Direction indicating whether this packet is to be sent or received.
20709009f30SSjur Braendeland  *  nativepkt  - The native packet to be transformed to a CAIF packet
20809009f30SSjur Braendeland  *  @return The mapped CAIF Packet CFPKT.
20909009f30SSjur Braendeland  */
21009009f30SSjur Braendeland struct cfpkt *cfpkt_fromnative(enum caif_direction dir, void *nativepkt);
21109009f30SSjur Braendeland 
21209009f30SSjur Braendeland /* Map from a CAIF packet to a "native" packet (e.g. Linux Socket Buffer).
21309009f30SSjur Braendeland  *  pkt  - The CAIF packet to be transformed into a "native" packet.
21409009f30SSjur Braendeland  *  @return The native packet transformed from a CAIF packet.
21509009f30SSjur Braendeland  */
21609009f30SSjur Braendeland void *cfpkt_tonative(struct cfpkt *pkt);
21709009f30SSjur Braendeland 
21809009f30SSjur Braendeland /*
21909009f30SSjur Braendeland  * Returns packet information for a packet.
22009009f30SSjur Braendeland  * pkt Packet to get info from;
22109009f30SSjur Braendeland  * @return Packet information
22209009f30SSjur Braendeland  */
22309009f30SSjur Braendeland struct caif_payload_info *cfpkt_info(struct cfpkt *pkt);
22444764812SDmitry Tarnyagin 
22544764812SDmitry Tarnyagin /** cfpkt_set_prio - set priority for a CAIF packet.
22644764812SDmitry Tarnyagin  *
22744764812SDmitry Tarnyagin  * @pkt: The CAIF packet to be adjusted.
22844764812SDmitry Tarnyagin  * @prio: one of TC_PRIO_ constants.
22944764812SDmitry Tarnyagin  */
23044764812SDmitry Tarnyagin void cfpkt_set_prio(struct cfpkt *pkt, int prio);
23144764812SDmitry Tarnyagin 
23209009f30SSjur Braendeland #endif				/* CFPKT_H_ */
233