X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fdrv%2Fdac.h;h=c720f756521257e5c93ec6b2eb8f493112731c1d;hb=00a373a2b0382bcf9fe234db2964eb75a0cd2a5d;hp=82a59a0c89183bc5836a41211d8beb2add6e3961;hpb=a7fcf697f1f458a95127d9778f068d5581c3acfb;p=bertos.git diff --git a/bertos/drv/dac.h b/bertos/drv/dac.h index 82a59a0c..c720f756 100644 --- a/bertos/drv/dac.h +++ b/bertos/drv/dac.h @@ -64,8 +64,9 @@ typedef void (*SetChannelMaskFunc_t) (struct Dac *dac, uint32_t mask); typedef void (*SetSamplingRate_t) (struct Dac *dac, uint32_t rate); typedef void (*DmaConversionBufFunc_t) (struct Dac *dac, void *buf, size_t len); typedef bool (*DmaConversionIsFinished_t) (struct Dac *dac); -typedef void (*DmaStartStreamingFunc_t) (struct Dac *dac, void *buf, size_t len, size_t slicelen); +typedef void (*DmaStartStreamingFunc_t) (struct Dac *dac, void *buf, size_t len, size_t slice_len); typedef void (*DmaStopFunc_t) (struct Dac *dac); +typedef void (*DmaCallbackFunc_t) (struct Dac *dac, void *_buf, size_t len); typedef struct DacContext { @@ -76,7 +77,8 @@ typedef struct DacContext DmaConversionIsFinished_t isFinished; DmaStartStreamingFunc_t start; DmaStopFunc_t stop; - size_t slicelen; + DmaCallbackFunc_t callback; + size_t slice_len; DB(id_t _type); @@ -106,7 +108,7 @@ INLINE void dac_setSamplingRate(Dac *dac, uint32_t rate) dac->ctx.setSampleRate(dac, rate); } -/** +/* * Convert \param len samples stored into \param buf. */ INLINE void dac_dmaConversionBuffer(Dac *dac, void *buf, size_t len) @@ -115,7 +117,7 @@ INLINE void dac_dmaConversionBuffer(Dac *dac, void *buf, size_t len) dac->ctx.conversion(dac, buf, len); } -/** +/* * Check if a dma transfer is finished. * * Useful for kernel-less applications. @@ -126,15 +128,18 @@ INLINE bool dac_dmaIsFinished(Dac *dac) return dac->ctx.isFinished(dac); } -/** +/* * \param slicelen Must be a divisor of len, ie. len % slicelen == 0. */ -INLINE void dac_dmaStartStreaming(Dac *dac, void *buf, size_t len, size_t slicelen) +INLINE void dac_dmaStartStreaming(Dac *dac, void *buf, size_t len, size_t slice_len, DmaCallbackFunc_t callback) { ASSERT(dac->ctx.start); - ASSERT(len % slicelen == 0); - dac->ctx.slicelen = slicelen; - dac->ctx.start(dac, buf, len, slicelen); + ASSERT(len % slice_len == 0); + ASSERT(callback); + + dac->ctx.callback = callback; + dac->ctx.slice_len = slice_len; + dac->ctx.start(dac, buf, len, slice_len); } INLINE void dac_dmaStop(Dac *dac)