1 #include "soc/lldesc.h"
2
lldesc_setup_link_constrained(lldesc_t * dmadesc,const void * data,int len,int max_desc_size,bool isrx)3 void lldesc_setup_link_constrained(lldesc_t *dmadesc, const void *data, int len, int max_desc_size, bool isrx)
4 {
5 int n = 0;
6 uint8_t *buf = (uint8_t *)data;
7 while (len) {
8 int dmachunklen = len;
9 if (dmachunklen > max_desc_size) {
10 dmachunklen = max_desc_size;
11 }
12 if (isrx) {
13 //Receive needs DMA length rounded to next 32-bit boundary
14 dmadesc[n].size = (dmachunklen + 3) & (~3);
15 dmadesc[n].length = (dmachunklen + 3) & (~3);
16 } else {
17 dmadesc[n].size = dmachunklen;
18 dmadesc[n].length = dmachunklen;
19 }
20 dmadesc[n].buf = buf;
21 dmadesc[n].eof = 0;
22 dmadesc[n].sosf = 0;
23 dmadesc[n].owner = 1;
24 dmadesc[n].qe.stqe_next = &dmadesc[n + 1];
25 len -= dmachunklen;
26 buf += dmachunklen;
27 n++;
28 }
29 dmadesc[n - 1].eof = 1; //Mark last DMA desc as end of stream.
30 dmadesc[n - 1].qe.stqe_next = NULL;
31 }
32
lldesc_get_received_len(lldesc_t * head,lldesc_t ** out_next)33 int lldesc_get_received_len(lldesc_t* head, lldesc_t** out_next)
34 {
35 lldesc_t* desc = head;
36 int len = 0;
37 while(desc) {
38 len += desc->length;
39 bool eof = desc->eof;
40 desc = STAILQ_NEXT(desc, qe);
41 if (eof) break;
42 }
43 if (out_next) {
44 *out_next = desc;
45 }
46 return len;
47 }
48