1 /* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */
3 * Copyright 2014-2016 Freescale Semiconductor Inc.
7 #ifndef __FSL_DPAA2_FD_H
8 #define __FSL_DPAA2_FD_H
10 #include <linux/kernel.h>
13 * DOC: DPAA2 FD - Frame Descriptor APIs for DPAA2
15 * Frame Descriptors (FDs) are used to describe frame data in the DPAA2.
16 * Frames can be enqueued and dequeued to Frame Queues (FQs) which are consumed
17 * by the various DPAA accelerators (WRIOP, SEC, PME, DCE)
19 * There are three types of frames: single, scatter gather, and frame lists.
21 * The set of APIs in this file must be used to create, manipulate and
22 * query Frame Descriptors.
26 * struct dpaa2_fd - Struct describing FDs
27 * @words: for easier/faster copying the whole FD structure
28 * @addr: address in the FD
29 * @len: length in the FD
30 * @bpid: buffer pool ID
31 * @format_offset: format, offset, and short-length fields
33 * @ctrl: control bits...including dd, sc, va, err, etc
34 * @flc: flow context address
36 * This structure represents the basic Frame Descriptor used in the system.
41 struct dpaa2_fd_simple
{
53 #define FD_SHORT_LEN_FLAG_MASK 0x1
54 #define FD_SHORT_LEN_FLAG_SHIFT 14
55 #define FD_SHORT_LEN_MASK 0x3FFFF
56 #define FD_OFFSET_MASK 0x0FFF
57 #define FD_FORMAT_MASK 0x3
58 #define FD_FORMAT_SHIFT 12
59 #define FD_BPID_MASK 0x3FFF
60 #define SG_SHORT_LEN_FLAG_MASK 0x1
61 #define SG_SHORT_LEN_FLAG_SHIFT 14
62 #define SG_SHORT_LEN_MASK 0x1FFFF
63 #define SG_OFFSET_MASK 0x0FFF
64 #define SG_FORMAT_MASK 0x3
65 #define SG_FORMAT_SHIFT 12
66 #define SG_BPID_MASK 0x3FFF
67 #define SG_FINAL_FLAG_MASK 0x1
68 #define SG_FINAL_FLAG_SHIFT 15
69 #define FL_SHORT_LEN_FLAG_MASK 0x1
70 #define FL_SHORT_LEN_FLAG_SHIFT 14
71 #define FL_SHORT_LEN_MASK 0x3FFFF
72 #define FL_OFFSET_MASK 0x0FFF
73 #define FL_FORMAT_MASK 0x3
74 #define FL_FORMAT_SHIFT 12
75 #define FL_BPID_MASK 0x3FFF
76 #define FL_FINAL_FLAG_MASK 0x1
77 #define FL_FINAL_FLAG_SHIFT 15
79 /* Error bits in FD CTRL */
80 #define FD_CTRL_ERR_MASK 0x000000FF
81 #define FD_CTRL_UFD 0x00000004
82 #define FD_CTRL_SBE 0x00000008
83 #define FD_CTRL_FLC 0x00000010
84 #define FD_CTRL_FSE 0x00000020
85 #define FD_CTRL_FAERR 0x00000040
87 /* Annotation bits in FD CTRL */
88 #define FD_CTRL_PTA 0x00800000
89 #define FD_CTRL_PTV1 0x00400000
91 enum dpaa2_fd_format
{
98 * dpaa2_fd_get_addr() - get the addr field of frame descriptor
99 * @fd: the given frame descriptor
101 * Return the address in the frame descriptor.
103 static inline dma_addr_t
dpaa2_fd_get_addr(const struct dpaa2_fd
*fd
)
105 return (dma_addr_t
)le64_to_cpu(fd
->simple
.addr
);
109 * dpaa2_fd_set_addr() - Set the addr field of frame descriptor
110 * @fd: the given frame descriptor
111 * @addr: the address needs to be set in frame descriptor
113 static inline void dpaa2_fd_set_addr(struct dpaa2_fd
*fd
, dma_addr_t addr
)
115 fd
->simple
.addr
= cpu_to_le64(addr
);
119 * dpaa2_fd_get_frc() - Get the frame context in the frame descriptor
120 * @fd: the given frame descriptor
122 * Return the frame context field in the frame descriptor.
124 static inline u32
dpaa2_fd_get_frc(const struct dpaa2_fd
*fd
)
126 return le32_to_cpu(fd
->simple
.frc
);
130 * dpaa2_fd_set_frc() - Set the frame context in the frame descriptor
131 * @fd: the given frame descriptor
132 * @frc: the frame context needs to be set in frame descriptor
134 static inline void dpaa2_fd_set_frc(struct dpaa2_fd
*fd
, u32 frc
)
136 fd
->simple
.frc
= cpu_to_le32(frc
);
140 * dpaa2_fd_get_ctrl() - Get the control bits in the frame descriptor
141 * @fd: the given frame descriptor
143 * Return the control bits field in the frame descriptor.
145 static inline u32
dpaa2_fd_get_ctrl(const struct dpaa2_fd
*fd
)
147 return le32_to_cpu(fd
->simple
.ctrl
);
151 * dpaa2_fd_set_ctrl() - Set the control bits in the frame descriptor
152 * @fd: the given frame descriptor
153 * @ctrl: the control bits to be set in the frame descriptor
155 static inline void dpaa2_fd_set_ctrl(struct dpaa2_fd
*fd
, u32 ctrl
)
157 fd
->simple
.ctrl
= cpu_to_le32(ctrl
);
161 * dpaa2_fd_get_flc() - Get the flow context in the frame descriptor
162 * @fd: the given frame descriptor
164 * Return the flow context in the frame descriptor.
166 static inline dma_addr_t
dpaa2_fd_get_flc(const struct dpaa2_fd
*fd
)
168 return (dma_addr_t
)le64_to_cpu(fd
->simple
.flc
);
172 * dpaa2_fd_set_flc() - Set the flow context field of frame descriptor
173 * @fd: the given frame descriptor
174 * @flc_addr: the flow context needs to be set in frame descriptor
176 static inline void dpaa2_fd_set_flc(struct dpaa2_fd
*fd
, dma_addr_t flc_addr
)
178 fd
->simple
.flc
= cpu_to_le64(flc_addr
);
181 static inline bool dpaa2_fd_short_len(const struct dpaa2_fd
*fd
)
183 return !!((le16_to_cpu(fd
->simple
.format_offset
) >>
184 FD_SHORT_LEN_FLAG_SHIFT
) & FD_SHORT_LEN_FLAG_MASK
);
188 * dpaa2_fd_get_len() - Get the length in the frame descriptor
189 * @fd: the given frame descriptor
191 * Return the length field in the frame descriptor.
193 static inline u32
dpaa2_fd_get_len(const struct dpaa2_fd
*fd
)
195 if (dpaa2_fd_short_len(fd
))
196 return le32_to_cpu(fd
->simple
.len
) & FD_SHORT_LEN_MASK
;
198 return le32_to_cpu(fd
->simple
.len
);
202 * dpaa2_fd_set_len() - Set the length field of frame descriptor
203 * @fd: the given frame descriptor
204 * @len: the length needs to be set in frame descriptor
206 static inline void dpaa2_fd_set_len(struct dpaa2_fd
*fd
, u32 len
)
208 fd
->simple
.len
= cpu_to_le32(len
);
212 * dpaa2_fd_get_offset() - Get the offset field in the frame descriptor
213 * @fd: the given frame descriptor
217 static inline uint16_t dpaa2_fd_get_offset(const struct dpaa2_fd
*fd
)
219 return le16_to_cpu(fd
->simple
.format_offset
) & FD_OFFSET_MASK
;
223 * dpaa2_fd_set_offset() - Set the offset field of frame descriptor
224 * @fd: the given frame descriptor
225 * @offset: the offset needs to be set in frame descriptor
227 static inline void dpaa2_fd_set_offset(struct dpaa2_fd
*fd
, uint16_t offset
)
229 fd
->simple
.format_offset
&= cpu_to_le16(~FD_OFFSET_MASK
);
230 fd
->simple
.format_offset
|= cpu_to_le16(offset
);
234 * dpaa2_fd_get_format() - Get the format field in the frame descriptor
235 * @fd: the given frame descriptor
239 static inline enum dpaa2_fd_format
dpaa2_fd_get_format(
240 const struct dpaa2_fd
*fd
)
242 return (enum dpaa2_fd_format
)((le16_to_cpu(fd
->simple
.format_offset
)
243 >> FD_FORMAT_SHIFT
) & FD_FORMAT_MASK
);
247 * dpaa2_fd_set_format() - Set the format field of frame descriptor
248 * @fd: the given frame descriptor
249 * @format: the format needs to be set in frame descriptor
251 static inline void dpaa2_fd_set_format(struct dpaa2_fd
*fd
,
252 enum dpaa2_fd_format format
)
254 fd
->simple
.format_offset
&=
255 cpu_to_le16(~(FD_FORMAT_MASK
<< FD_FORMAT_SHIFT
));
256 fd
->simple
.format_offset
|= cpu_to_le16(format
<< FD_FORMAT_SHIFT
);
260 * dpaa2_fd_get_bpid() - Get the bpid field in the frame descriptor
261 * @fd: the given frame descriptor
263 * Return the buffer pool id.
265 static inline uint16_t dpaa2_fd_get_bpid(const struct dpaa2_fd
*fd
)
267 return le16_to_cpu(fd
->simple
.bpid
) & FD_BPID_MASK
;
271 * dpaa2_fd_set_bpid() - Set the bpid field of frame descriptor
272 * @fd: the given frame descriptor
273 * @bpid: buffer pool id to be set
275 static inline void dpaa2_fd_set_bpid(struct dpaa2_fd
*fd
, uint16_t bpid
)
277 fd
->simple
.bpid
&= cpu_to_le16(~(FD_BPID_MASK
));
278 fd
->simple
.bpid
|= cpu_to_le16(bpid
);
282 * struct dpaa2_sg_entry - the scatter-gathering structure
283 * @addr: address of the sg entry
284 * @len: length in this sg entry
285 * @bpid: buffer pool id
286 * @format_offset: format and offset fields
288 struct dpaa2_sg_entry
{
292 __le16 format_offset
;
295 enum dpaa2_sg_format
{
301 /* Accessors for SG entry fields */
304 * dpaa2_sg_get_addr() - Get the address from SG entry
305 * @sg: the given scatter-gathering object
307 * Return the address.
309 static inline dma_addr_t
dpaa2_sg_get_addr(const struct dpaa2_sg_entry
*sg
)
311 return (dma_addr_t
)le64_to_cpu(sg
->addr
);
315 * dpaa2_sg_set_addr() - Set the address in SG entry
316 * @sg: the given scatter-gathering object
317 * @addr: the address to be set
319 static inline void dpaa2_sg_set_addr(struct dpaa2_sg_entry
*sg
, dma_addr_t addr
)
321 sg
->addr
= cpu_to_le64(addr
);
324 static inline bool dpaa2_sg_short_len(const struct dpaa2_sg_entry
*sg
)
326 return !!((le16_to_cpu(sg
->format_offset
) >> SG_SHORT_LEN_FLAG_SHIFT
)
327 & SG_SHORT_LEN_FLAG_MASK
);
331 * dpaa2_sg_get_len() - Get the length in SG entry
332 * @sg: the given scatter-gathering object
336 static inline u32
dpaa2_sg_get_len(const struct dpaa2_sg_entry
*sg
)
338 if (dpaa2_sg_short_len(sg
))
339 return le32_to_cpu(sg
->len
) & SG_SHORT_LEN_MASK
;
341 return le32_to_cpu(sg
->len
);
345 * dpaa2_sg_set_len() - Set the length in SG entry
346 * @sg: the given scatter-gathering object
347 * @len: the length to be set
349 static inline void dpaa2_sg_set_len(struct dpaa2_sg_entry
*sg
, u32 len
)
351 sg
->len
= cpu_to_le32(len
);
355 * dpaa2_sg_get_offset() - Get the offset in SG entry
356 * @sg: the given scatter-gathering object
360 static inline u16
dpaa2_sg_get_offset(const struct dpaa2_sg_entry
*sg
)
362 return le16_to_cpu(sg
->format_offset
) & SG_OFFSET_MASK
;
366 * dpaa2_sg_set_offset() - Set the offset in SG entry
367 * @sg: the given scatter-gathering object
368 * @offset: the offset to be set
370 static inline void dpaa2_sg_set_offset(struct dpaa2_sg_entry
*sg
,
373 sg
->format_offset
&= cpu_to_le16(~SG_OFFSET_MASK
);
374 sg
->format_offset
|= cpu_to_le16(offset
);
378 * dpaa2_sg_get_format() - Get the SG format in SG entry
379 * @sg: the given scatter-gathering object
383 static inline enum dpaa2_sg_format
384 dpaa2_sg_get_format(const struct dpaa2_sg_entry
*sg
)
386 return (enum dpaa2_sg_format
)((le16_to_cpu(sg
->format_offset
)
387 >> SG_FORMAT_SHIFT
) & SG_FORMAT_MASK
);
391 * dpaa2_sg_set_format() - Set the SG format in SG entry
392 * @sg: the given scatter-gathering object
393 * @format: the format to be set
395 static inline void dpaa2_sg_set_format(struct dpaa2_sg_entry
*sg
,
396 enum dpaa2_sg_format format
)
398 sg
->format_offset
&= cpu_to_le16(~(SG_FORMAT_MASK
<< SG_FORMAT_SHIFT
));
399 sg
->format_offset
|= cpu_to_le16(format
<< SG_FORMAT_SHIFT
);
403 * dpaa2_sg_get_bpid() - Get the buffer pool id in SG entry
404 * @sg: the given scatter-gathering object
408 static inline u16
dpaa2_sg_get_bpid(const struct dpaa2_sg_entry
*sg
)
410 return le16_to_cpu(sg
->bpid
) & SG_BPID_MASK
;
414 * dpaa2_sg_set_bpid() - Set the buffer pool id in SG entry
415 * @sg: the given scatter-gathering object
416 * @bpid: the bpid to be set
418 static inline void dpaa2_sg_set_bpid(struct dpaa2_sg_entry
*sg
, u16 bpid
)
420 sg
->bpid
&= cpu_to_le16(~(SG_BPID_MASK
));
421 sg
->bpid
|= cpu_to_le16(bpid
);
425 * dpaa2_sg_is_final() - Check final bit in SG entry
426 * @sg: the given scatter-gathering object
430 static inline bool dpaa2_sg_is_final(const struct dpaa2_sg_entry
*sg
)
432 return !!(le16_to_cpu(sg
->format_offset
) >> SG_FINAL_FLAG_SHIFT
);
436 * dpaa2_sg_set_final() - Set the final bit in SG entry
437 * @sg: the given scatter-gathering object
438 * @final: the final boolean to be set
440 static inline void dpaa2_sg_set_final(struct dpaa2_sg_entry
*sg
, bool final
)
442 sg
->format_offset
&= cpu_to_le16((~(SG_FINAL_FLAG_MASK
443 << SG_FINAL_FLAG_SHIFT
)) & 0xFFFF);
444 sg
->format_offset
|= cpu_to_le16(final
<< SG_FINAL_FLAG_SHIFT
);
448 * struct dpaa2_fl_entry - structure for frame list entry.
449 * @addr: address in the FLE
450 * @len: length in the FLE
451 * @bpid: buffer pool ID
452 * @format_offset: format, offset, and short-length fields
453 * @frc: frame context
454 * @ctrl: control bits...including pta, pvt1, pvt2, err, etc
455 * @flc: flow context address
457 struct dpaa2_fl_entry
{
461 __le16 format_offset
;
467 enum dpaa2_fl_format
{
474 * dpaa2_fl_get_addr() - get the addr field of FLE
475 * @fle: the given frame list entry
477 * Return the address in the frame list entry.
479 static inline dma_addr_t
dpaa2_fl_get_addr(const struct dpaa2_fl_entry
*fle
)
481 return (dma_addr_t
)le64_to_cpu(fle
->addr
);
485 * dpaa2_fl_set_addr() - Set the addr field of FLE
486 * @fle: the given frame list entry
487 * @addr: the address needs to be set in frame list entry
489 static inline void dpaa2_fl_set_addr(struct dpaa2_fl_entry
*fle
,
492 fle
->addr
= cpu_to_le64(addr
);
496 * dpaa2_fl_get_frc() - Get the frame context in the FLE
497 * @fle: the given frame list entry
499 * Return the frame context field in the frame lsit entry.
501 static inline u32
dpaa2_fl_get_frc(const struct dpaa2_fl_entry
*fle
)
503 return le32_to_cpu(fle
->frc
);
507 * dpaa2_fl_set_frc() - Set the frame context in the FLE
508 * @fle: the given frame list entry
509 * @frc: the frame context needs to be set in frame list entry
511 static inline void dpaa2_fl_set_frc(struct dpaa2_fl_entry
*fle
, u32 frc
)
513 fle
->frc
= cpu_to_le32(frc
);
517 * dpaa2_fl_get_ctrl() - Get the control bits in the FLE
518 * @fle: the given frame list entry
520 * Return the control bits field in the frame list entry.
522 static inline u32
dpaa2_fl_get_ctrl(const struct dpaa2_fl_entry
*fle
)
524 return le32_to_cpu(fle
->ctrl
);
528 * dpaa2_fl_set_ctrl() - Set the control bits in the FLE
529 * @fle: the given frame list entry
530 * @ctrl: the control bits to be set in the frame list entry
532 static inline void dpaa2_fl_set_ctrl(struct dpaa2_fl_entry
*fle
, u32 ctrl
)
534 fle
->ctrl
= cpu_to_le32(ctrl
);
538 * dpaa2_fl_get_flc() - Get the flow context in the FLE
539 * @fle: the given frame list entry
541 * Return the flow context in the frame list entry.
543 static inline dma_addr_t
dpaa2_fl_get_flc(const struct dpaa2_fl_entry
*fle
)
545 return (dma_addr_t
)le64_to_cpu(fle
->flc
);
549 * dpaa2_fl_set_flc() - Set the flow context field of FLE
550 * @fle: the given frame list entry
551 * @flc_addr: the flow context needs to be set in frame list entry
553 static inline void dpaa2_fl_set_flc(struct dpaa2_fl_entry
*fle
,
556 fle
->flc
= cpu_to_le64(flc_addr
);
559 static inline bool dpaa2_fl_short_len(const struct dpaa2_fl_entry
*fle
)
561 return !!((le16_to_cpu(fle
->format_offset
) >>
562 FL_SHORT_LEN_FLAG_SHIFT
) & FL_SHORT_LEN_FLAG_MASK
);
566 * dpaa2_fl_get_len() - Get the length in the FLE
567 * @fle: the given frame list entry
569 * Return the length field in the frame list entry.
571 static inline u32
dpaa2_fl_get_len(const struct dpaa2_fl_entry
*fle
)
573 if (dpaa2_fl_short_len(fle
))
574 return le32_to_cpu(fle
->len
) & FL_SHORT_LEN_MASK
;
576 return le32_to_cpu(fle
->len
);
580 * dpaa2_fl_set_len() - Set the length field of FLE
581 * @fle: the given frame list entry
582 * @len: the length needs to be set in frame list entry
584 static inline void dpaa2_fl_set_len(struct dpaa2_fl_entry
*fle
, u32 len
)
586 fle
->len
= cpu_to_le32(len
);
590 * dpaa2_fl_get_offset() - Get the offset field in the frame list entry
591 * @fle: the given frame list entry
595 static inline u16
dpaa2_fl_get_offset(const struct dpaa2_fl_entry
*fle
)
597 return le16_to_cpu(fle
->format_offset
) & FL_OFFSET_MASK
;
601 * dpaa2_fl_set_offset() - Set the offset field of FLE
602 * @fle: the given frame list entry
603 * @offset: the offset needs to be set in frame list entry
605 static inline void dpaa2_fl_set_offset(struct dpaa2_fl_entry
*fle
, u16 offset
)
607 fle
->format_offset
&= cpu_to_le16(~FL_OFFSET_MASK
);
608 fle
->format_offset
|= cpu_to_le16(offset
);
612 * dpaa2_fl_get_format() - Get the format field in the FLE
613 * @fle: the given frame list entry
617 static inline enum dpaa2_fl_format
dpaa2_fl_get_format(const struct dpaa2_fl_entry
*fle
)
619 return (enum dpaa2_fl_format
)((le16_to_cpu(fle
->format_offset
) >>
620 FL_FORMAT_SHIFT
) & FL_FORMAT_MASK
);
624 * dpaa2_fl_set_format() - Set the format field of FLE
625 * @fle: the given frame list entry
626 * @format: the format needs to be set in frame list entry
628 static inline void dpaa2_fl_set_format(struct dpaa2_fl_entry
*fle
,
629 enum dpaa2_fl_format format
)
631 fle
->format_offset
&= cpu_to_le16(~(FL_FORMAT_MASK
<< FL_FORMAT_SHIFT
));
632 fle
->format_offset
|= cpu_to_le16(format
<< FL_FORMAT_SHIFT
);
636 * dpaa2_fl_get_bpid() - Get the bpid field in the FLE
637 * @fle: the given frame list entry
639 * Return the buffer pool id.
641 static inline u16
dpaa2_fl_get_bpid(const struct dpaa2_fl_entry
*fle
)
643 return le16_to_cpu(fle
->bpid
) & FL_BPID_MASK
;
647 * dpaa2_fl_set_bpid() - Set the bpid field of FLE
648 * @fle: the given frame list entry
649 * @bpid: buffer pool id to be set
651 static inline void dpaa2_fl_set_bpid(struct dpaa2_fl_entry
*fle
, u16 bpid
)
653 fle
->bpid
&= cpu_to_le16(~(FL_BPID_MASK
));
654 fle
->bpid
|= cpu_to_le16(bpid
);
658 * dpaa2_fl_is_final() - Check final bit in FLE
659 * @fle: the given frame list entry
663 static inline bool dpaa2_fl_is_final(const struct dpaa2_fl_entry
*fle
)
665 return !!(le16_to_cpu(fle
->format_offset
) >> FL_FINAL_FLAG_SHIFT
);
669 * dpaa2_fl_set_final() - Set the final bit in FLE
670 * @fle: the given frame list entry
671 * @final: the final boolean to be set
673 static inline void dpaa2_fl_set_final(struct dpaa2_fl_entry
*fle
, bool final
)
675 fle
->format_offset
&= cpu_to_le16((~(FL_FINAL_FLAG_MASK
<<
676 FL_FINAL_FLAG_SHIFT
)) & 0xFFFF);
677 fle
->format_offset
|= cpu_to_le16(final
<< FL_FINAL_FLAG_SHIFT
);
680 #endif /* __FSL_DPAA2_FD_H */