⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 msp430dmam.nc

📁 无线通信的主要编程软件,是无线通信工作人员的必备工具,关天相关教程我会在后续传上.
💻 NC
📖 第 1 页 / 共 2 页
字号:
    DMA1CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA1CTL |= DMADT2;  }  async command void DMAChannelCtrl1.setRepeatedBlockMode(){    DMA1CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA1CTL |= (DMADT2 | DMADT0);  }  async command void DMAChannelCtrl1.setRepeatedBurstMode(){    DMA1CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA1CTL |= (DMADT2 | DMADT1);  }  // ----- DMA Address Incrementation -----  async command void DMAChannelCtrl1.setSrcNoIncrement(){    DMA1CTL &= ~(DMASRCINCR0 | DMASRCINCR1);  }  async command void DMAChannelCtrl1.setSrcDecrement(){    DMA1CTL |= DMASRCINCR1;  }  async command void DMAChannelCtrl1.setSrcIncrement(){    DMA1CTL |= (DMASRCINCR0 | DMASRCINCR1);  }  async command void DMAChannelCtrl1.setDstNoIncrement(){    DMA1CTL &= ~(DMADSTINCR0 | DMADSTINCR1);  }  async command void DMAChannelCtrl1.setDstDecrement(){    DMA1CTL |= DMADSTINCR1;  }  async command void DMAChannelCtrl1.setDstIncrement(){    DMA1CTL |= (DMADSTINCR0 | DMADSTINCR1);  }  // ----- DMA Word Size Mode -----  async command void DMAChannelCtrl1.setWordToWord(){     DMA1CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA1CTL |= DMASWDW;  }  async command void DMAChannelCtrl1.setByteToWord(){     DMA1CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA1CTL |= DMASBDW;  }  async command void DMAChannelCtrl1.setWordToByte(){     DMA1CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA1CTL |= DMASWDB;  }  async command void DMAChannelCtrl1.setByteToByte(){     DMA1CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA1CTL |= DMASBDB;  }  // ----- DMA Level -----  async command void DMAChannelCtrl1.setEdgeSensitive(){    DMA1CTL &= ~DMALEVEL;  }  async command void DMAChannelCtrl1.setLevelSensitive(){    DMA1CTL |= DMALEVEL;  }  // ----- DMA Enable -----  async command void DMAChannelCtrl1.enableDMA(){ DMA1CTL |= DMAEN; }  async command void DMAChannelCtrl1.disableDMA(){ DMA1CTL &= ~DMAEN; }  // ----- DMA Interrupt -----  async command void DMAChannelCtrl1.enableInterrupt() {     DMA1CTL  |= DMAIE;   }  async command void DMAChannelCtrl1.disableInterrupt() {     DMA1CTL  &= ~DMAIE;   }  async command bool DMAChannelCtrl1.interruptPending(){    bool ret = FALSE;    if (DMA1CTL & DMAIFG) ret = TRUE;    return ret;  }  // ----- DMA Abort -----  // todo: should this trigger an interrupt  async command bool DMAChannelCtrl1.aborted(){    bool ret = FALSE;    if (DMA1CTL & DMAABORT) ret = TRUE;    return ret;  }  // ----- DMA Software Request -----  async command void DMAChannelCtrl1.triggerDMA() { DMA1CTL  |= DMAREQ; }  // ----- DMA Source Address -----  async command void DMAChannelCtrl1.setSrc(void *saddr){    DMA1SA = (uint16_t)saddr;  }  // ----- DMA Destination Address ----  async command void DMAChannelCtrl1.setDst(void *daddr){    DMA1DA = (uint16_t)daddr;  }  // ----- DMA Destination Address ----  async command void DMAChannelCtrl1.setSize(uint16_t sz){    DMA1SZ = sz;  }  async command void DMAChannelCtrl1.setState(dma_channel_state_t s){    uint16_t dmactl0 = DMACTL0;    uint16_t dma1ctl = 0;    dmactl0 |= ((s.trigger & DMATSEL_MASK) << DMA1TSEL_SHIFT);    dma1ctl |= (s.request         ? DMAREQ     : 0);    dma1ctl |= (s.abort           ? DMAABORT   : 0);    dma1ctl |= (s.interruptEnable ? DMAIE      : 0);    dma1ctl |= (s.interruptFlag   ? DMAIFG     : 0);    dma1ctl |= (s.enable          ? DMAEN      : 0);    dma1ctl |= (s.level           ? DMALEVEL   : 0);    dma1ctl |= (s.srcByte         ? DMASRCBYTE : 0);    dma1ctl |= (s.dstByte         ? DMADSTBYTE : 0);    dma1ctl |= ((s.srcIncrement & DMAINCR_MASK) << DMASRCINCR_SHIFT);    dma1ctl |= ((s.dstIncrement & DMAINCR_MASK) << DMADSTINCR_SHIFT);    dma1ctl |= ((s.transferMode & DMADT_MASK) << DMADT_SHIFT);    DMA1SA = (uint16_t)(s.srcAddr);    DMA1DA = (uint16_t)(s.dstAddr);    DMA1SZ = s.size;    DMACTL0 = dmactl0;    DMA1CTL= dma1ctl;    return;  }  async command dma_channel_state_t DMAChannelCtrl1.getState(){    dma_channel_state_t s;    s.trigger = ((DMACTL0 >> DMA1TSEL_SHIFT) & DMATSEL_MASK);    s.reserved = 0;    s.request         = (DMA1CTL & DMAREQ     ? 1 : 0);    s.abort           = (DMA1CTL & DMAABORT   ? 1 : 0);    s.interruptEnable = (DMA1CTL & DMAIE      ? 1 : 0);    s.interruptFlag   = (DMA1CTL & DMAIFG     ? 1 : 0);    s.enable          = (DMA1CTL & DMAEN      ? 1 : 0);    s.level           = (DMA1CTL & DMALEVEL   ? 1 : 0);    s.srcByte         = (DMA1CTL & DMASRCBYTE ? 1 : 0);    s.dstByte         = (DMA1CTL & DMADSTBYTE ? 1 : 0);    s.srcIncrement    = ((DMA1CTL >> DMASRCINCR_SHIFT) & DMAINCR_MASK);    s.dstIncrement    = ((DMA1CTL >> DMADSTINCR_SHIFT) & DMAINCR_MASK);    s.reserved2 = 0;    s.transferMode    = ((DMA1CTL >> DMADT_SHIFT) & DMADT_MASK);    s.srcAddr = (void *)DMA1SA;    s.dstAddr = (void *)DMA1DA;    s.size = DMA1SZ;  }   async command void DMAChannelCtrl1.reset(){    DMA1CTL = 0;    DMA1SA = 0;    DMA1DA = 0;    DMA1SZ = 0;  }  // ----------------------------------------------------------  // DMA Channel 2 Control  // ----------------------------------------------------------  // ----- DMA Trigger Mode -----  async command result_t DMAChannelCtrl2.setTrigger(dma_trigger_t trigger){    result_t res = SUCCESS;    if (DMA2CTL & DMAEN) res = FAIL;    else {      DMACTL0 &= ~(DMA2TSEL0 | DMA2TSEL1 | DMA2TSEL2 | DMA2TSEL3);      DMACTL0 |= ((DMATSEL_MASK & trigger)<<DMA2TSEL_SHIFT);    }    return res;  }  async command void DMAChannelCtrl2.clearTrigger(){        DMACTL0 &= ~(DMA2TSEL0 | DMA2TSEL1 | DMA2TSEL2 | DMA2TSEL3);  }    // ----- DMA Transfer Mode -----  async command void DMAChannelCtrl2.setSingleMode(){    DMA2CTL &= ~(DMADT0 | DMADT1 | DMADT2);  }  async command void DMAChannelCtrl2.setBlockMode(){    DMA2CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA2CTL |= DMADT0;  }  async command void DMAChannelCtrl2.setBurstMode(){    DMA2CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA2CTL |= DMADT1;  }  async command void DMAChannelCtrl2.setRepeatedSingleMode(){    DMA2CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA2CTL |= DMADT2;  }  async command void DMAChannelCtrl2.setRepeatedBlockMode(){    DMA2CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA2CTL |= (DMADT2 | DMADT0);  }  async command void DMAChannelCtrl2.setRepeatedBurstMode(){    DMA2CTL &= ~(DMADT0 | DMADT1 | DMADT2);    DMA2CTL |= (DMADT2 | DMADT1);  }  // ----- DMA Address Incrementation -----  async command void DMAChannelCtrl2.setSrcNoIncrement(){    DMA2CTL &= ~(DMASRCINCR0 | DMASRCINCR1);  }  async command void DMAChannelCtrl2.setSrcDecrement(){    DMA2CTL |= DMASRCINCR1;  }  async command void DMAChannelCtrl2.setSrcIncrement(){    DMA2CTL |= (DMASRCINCR0 | DMASRCINCR1);  }  async command void DMAChannelCtrl2.setDstNoIncrement(){    DMA2CTL &= ~(DMADSTINCR0 | DMADSTINCR1);  }  async command void DMAChannelCtrl2.setDstDecrement(){    DMA2CTL |= DMADSTINCR1;  }  async command void DMAChannelCtrl2.setDstIncrement(){    DMA2CTL |= (DMADSTINCR0 | DMADSTINCR1);  }  // ----- DMA Word Size Mode -----  async command void DMAChannelCtrl2.setWordToWord(){     DMA2CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA2CTL |= DMASWDW;  }  async command void DMAChannelCtrl2.setByteToWord(){     DMA2CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA2CTL |= DMASBDW;  }  async command void DMAChannelCtrl2.setWordToByte(){     DMA2CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA2CTL |= DMASWDB;  }  async command void DMAChannelCtrl2.setByteToByte(){     DMA2CTL &= ~(DMASRCBYTE | DMADSTBYTE);    DMA2CTL |= DMASBDB;  }  // ----- DMA Level -----  async command void DMAChannelCtrl2.setEdgeSensitive(){    DMA2CTL &= ~DMALEVEL;  }  async command void DMAChannelCtrl2.setLevelSensitive(){    DMA2CTL |= DMALEVEL;  }  // ----- DMA Enable -----  async command void DMAChannelCtrl2.enableDMA(){ DMA2CTL |= DMAEN; }  async command void DMAChannelCtrl2.disableDMA(){ DMA2CTL &= ~DMAEN; }  // ----- DMA Interrupt -----  async command void DMAChannelCtrl2.enableInterrupt() {     DMA2CTL  |= DMAIE;   }  async command void DMAChannelCtrl2.disableInterrupt() {     DMA2CTL  &= ~DMAIE;   }  async command bool DMAChannelCtrl2.interruptPending(){    bool ret = FALSE;    if (DMA2CTL & DMAIFG) ret = TRUE;    return ret;  }  // ----- DMA Abort -----  // todo: should this trigger an interrupt  async command bool DMAChannelCtrl2.aborted(){    bool ret = FALSE;    if (DMA2CTL & DMAABORT) ret = TRUE;    return ret;  }  // ----- DMA Software Request -----  async command void DMAChannelCtrl2.triggerDMA() { DMA2CTL  |= DMAREQ; }  // ----- DMA Source Address -----  async command void DMAChannelCtrl2.setSrc(void *saddr){    DMA2SA = (uint16_t)saddr;  }  // ----- DMA Destination Address ----  async command void DMAChannelCtrl2.setDst(void *daddr){    DMA2DA = (uint16_t)daddr;  }  // ----- DMA Destination Address ----  async command void DMAChannelCtrl2.setSize(uint16_t sz){    DMA2SZ = sz;  }  async command void DMAChannelCtrl2.setState(dma_channel_state_t s){    uint16_t dmactl0 = DMACTL0;    uint16_t dma2ctl = 0;    dmactl0 |= ((s.trigger & DMATSEL_MASK) << DMA2TSEL_SHIFT);    dma2ctl |= (s.request         ? DMAREQ     : 0);    dma2ctl |= (s.abort           ? DMAABORT   : 0);    dma2ctl |= (s.interruptEnable ? DMAIE      : 0);    dma2ctl |= (s.interruptFlag   ? DMAIFG     : 0);    dma2ctl |= (s.enable          ? DMAEN      : 0);    dma2ctl |= (s.level           ? DMALEVEL   : 0);    dma2ctl |= (s.srcByte         ? DMASRCBYTE : 0);    dma2ctl |= (s.dstByte         ? DMADSTBYTE : 0);    dma2ctl |= ((s.srcIncrement & DMAINCR_MASK) << DMASRCINCR_SHIFT);    dma2ctl |= ((s.dstIncrement & DMAINCR_MASK) << DMADSTINCR_SHIFT);    dma2ctl |= ((s.transferMode & DMADT_MASK) << DMADT_SHIFT);    DMA2SA = (uint16_t)(s.srcAddr);    DMA2DA = (uint16_t)(s.dstAddr);    DMA2SZ = s.size;    DMACTL0 = dmactl0;    DMA2CTL= dma2ctl;    return;  }  async command dma_channel_state_t DMAChannelCtrl2.getState(){    dma_channel_state_t s;    s.trigger = ((DMACTL0 >> DMA2TSEL_SHIFT) & DMATSEL_MASK);    s.reserved = 0;    s.request         = (DMA2CTL & DMAREQ     ? 1 : 0);    s.abort           = (DMA2CTL & DMAABORT   ? 1 : 0);    s.interruptEnable = (DMA2CTL & DMAIE      ? 1 : 0);    s.interruptFlag   = (DMA2CTL & DMAIFG     ? 1 : 0);    s.enable          = (DMA2CTL & DMAEN      ? 1 : 0);    s.level           = (DMA2CTL & DMALEVEL   ? 1 : 0);    s.srcByte         = (DMA2CTL & DMASRCBYTE ? 1 : 0);    s.dstByte         = (DMA2CTL & DMADSTBYTE ? 1 : 0);    s.srcIncrement    = ((DMA2CTL >> DMASRCINCR_SHIFT) & DMAINCR_MASK);    s.dstIncrement    = ((DMA2CTL >> DMADSTINCR_SHIFT) & DMAINCR_MASK);    s.reserved2 = 0;    s.transferMode    = ((DMA2CTL >> DMADT_SHIFT) & DMADT_MASK);    s.srcAddr = (void *)DMA2SA;    s.dstAddr = (void *)DMA2DA;    s.size = DMA2SZ;  }   async command void DMAChannelCtrl2.reset(){    DMA2CTL = 0;    DMA2SA = 0;    DMA2DA = 0;    DMA2SZ = 0;  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -