xtensa/esp32: Fix wrong math round operation on DMA init
This commit is contained in:
parent
eb505ed866
commit
d3342795a8
@ -43,6 +43,10 @@
|
|||||||
# define MIN(a,b) (a < b ? a : b)
|
# define MIN(a,b) (a < b ? a : b)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef ALIGN_UP
|
||||||
|
# define ALIGN_UP(num, align) (((num) + ((align) - 1)) & ~((align) - 1))
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -82,11 +86,9 @@ uint32_t esp32_dma_init(struct esp32_dmadesc_s *dmadesc, uint32_t num,
|
|||||||
{
|
{
|
||||||
data_len = MIN(bytes, ESP32_DMA_DATALEN_MAX);
|
data_len = MIN(bytes, ESP32_DMA_DATALEN_MAX);
|
||||||
|
|
||||||
/* Round the number of bytes to the nearest word, since the buffer
|
/* Buffer length must be rounded to next 32-bit boundary. */
|
||||||
* length must be word-aligned.
|
|
||||||
*/
|
|
||||||
|
|
||||||
buf_len = (data_len + sizeof(uintptr_t) - 1) / sizeof(uintptr_t);
|
buf_len = ALIGN_UP(data_len, sizeof(uintptr_t));
|
||||||
|
|
||||||
dmadesc[i].ctrl = (data_len << DMA_CTRL_DATALEN_S) |
|
dmadesc[i].ctrl = (data_len << DMA_CTRL_DATALEN_S) |
|
||||||
(buf_len << DMA_CTRL_BUFLEN_S) |
|
(buf_len << DMA_CTRL_BUFLEN_S) |
|
||||||
|
Loading…
Reference in New Issue
Block a user