Teensy 4.1 core updated for C++20
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

42 lines
961B

  1. #include "DMAChannel.h"
  2. // The channel allocation bitmask is accessible from "C" namespace,
  3. // so C-only code can reserve DMA channels
  4. uint16_t dma_channel_allocated_mask = 0;
  5. DMAChannel::DMAChannel(uint8_t channelRequest) : TCD(*(TCD_t *)0), channel(16)
  6. {
  7. uint8_t next, ch=channelRequest;
  8. __disable_irq();
  9. while (1) {
  10. if (!(dma_channel_allocated_mask & (1 << ch))) {
  11. dma_channel_allocated_mask |= (1 << ch);
  12. __enable_irq();
  13. break;
  14. }
  15. next = (ch + 1) & 15;
  16. if (next == channelRequest) {
  17. __enable_irq();
  18. return; // no more channels available
  19. // attempts to use this object will hardfault
  20. }
  21. }
  22. channel = ch;
  23. SIM_SCGC7 |= SIM_SCGC7_DMA;
  24. SIM_SCGC6 |= SIM_SCGC6_DMAMUX;
  25. DMA_CR = DMA_CR_EMLM | DMA_CR_EDBG ; // minor loop mapping is available
  26. DMA_CERQ = ch;
  27. DMA_CERR = ch;
  28. DMA_CEEI = ch;
  29. DMA_CINT = ch;
  30. TCD = *(TCD_t *)(0x40009000 + ch * 32);
  31. TCD.CSR = 0;
  32. TCD.ATTR = 0;
  33. TCD.NBYTES = 0;
  34. TCD.BITER = 0;
  35. TCD.CITER = 0;
  36. }