switch (s->pdma_origin) {
case TI:
- val = s->ti_buf[s->ti_rptr++];
- break;
- case CMD:
- val = s->cmdbuf[s->cmdlen++];
+ if (s->do_cmd) {
+ val = s->cmdbuf[s->cmdlen++];
+ } else {
+ val = s->ti_buf[s->ti_rptr++];
+ }
break;
case ASYNC:
val = s->async_buf[0];
switch (s->pdma_origin) {
case TI:
- s->ti_buf[s->ti_wptr++] = val;
- break;
- case CMD:
- s->cmdbuf[s->cmdlen++] = val;
+ if (s->do_cmd) {
+ s->cmdbuf[s->cmdlen++] = val;
+ } else {
+ s->ti_buf[s->ti_wptr++] = val;
+ }
break;
case ASYNC:
s->async_buf[0] = val;
if (s->dma_memory_read) {
s->dma_memory_read(s->dma_opaque, buf, dmalen);
} else {
- set_pdma(s, CMD);
+ set_pdma(s, TI);
esp_raise_drq(s);
return 0;
}
if (s->dma_memory_read) {
s->dma_memory_read(s->dma_opaque, &s->cmdbuf[s->cmdlen], len);
} else {
- set_pdma(s, CMD);
+ set_pdma(s, TI);
s->pdma_cb = do_dma_pdma_cb;
esp_raise_drq(s);
return;