[技术问答] NM1200 ADC Sequential Mode 使用问题

[复制链接]
458|9
 楼主 | 2019-1-10 22:57 | 显示全部楼层 |阅读模式
我在使用NM1200使用PWM触发ADC时,当使能ADC模块的SEQEN(ADC_SEQCTL[0])时,PWM触发ADC动作就不工作了。当清除SEQEN时,PWM才可以正常的触发ADC,并完成转换。请问这是什么问题?
 楼主 | 2019-1-10 23:11 | 显示全部楼层
使用  ADC Sequential Mode 时,目前有问题的配置如下
        ADC->CTL = 0;
        ADC->EXTSMPT = 0;                                                                                                                        //6 SAMPLE CLK
        ADC->CHEN = ADC3_V_BUS;
        ADC->SEQCTL = (RISING_TRIGGER << ADC_SEQCTL_TRG1TYPE_Pos);       
        ADC->TRGDLY = 8;                                                                                                                        //4*DELAY*ADC_CLK = 4us
        ADC->CTL |= ADC_CTL_ADCIEN_Msk;
        ADC->SEQCTL |= ADC_SEQCTL_SEQEN_Msk;
        ADC->CTL |= ADC_CTL_HWTRGEN_Msk | ADC_CTL_HWTRGSEL_Msk | ADC_CTL_ADCEN_Msk;
        ADC->CTL |= ADC_CTL_SWTRG_Msk;
pwm已经正常运行并输出波形,pwm触发信号配置如下;
        PWM->ADCTCTL0 = PWM_ADCTCTL0_CDTRGEN0_Msk;
目前没有找到问题,请教有经验的大神,看看配置哪里有问题。谢谢!

使用特权

评论回复
| 2019-1-10 23:30 | 显示全部楼层
SEQEN这个是啥,不清楚啊。这个系列资料不公开吧

使用特权

评论回复
| 2019-1-10 23:36 | 显示全部楼层
看手册说明,这个位的作用是啥。

使用特权

评论回复
 楼主 | 2019-1-11 08:49 | 显示全部楼层
手册里这样说:
6.12.5.8 PWM Sequential
Support sequential mode for 2 channels to reduce half interrupt frequency. When the SEQEN
(ADC_SEQCTL[0]) is set to high to enable A/D PWM sequential function, setting the
TRG1SRC/TRG1TYPE (ADC_SEQCTL[11:8]) and TRG2SRC/TRG2TYPE
(ADC_SEQCTL[19:16]) are to select external trigger input from the PWM channel 0/2/4, type can
be rising/center/falling/period, When ADC sequential mode is enabled, two of three ADC channels
from 0 to 2 will automatically convert analog data in the sequence of channel [0, 1] or channel[1,2]
or channel[0,2] defined by MODESEL (ADC_SEQCTL[3:2]). By the way, if SEQTYPE
(ADC_SEQCTL[1]) is set to low, ADC delay time is only inserted before the first conversion. The
second conversion starts immediately after the first conversion is completed. (for 2/3-shunt type),
if SEQTYPE (ADC_SEQCTL[1]) is set to high, ADC delay time is inserted before each
conversion. (for 1-shunt type), By the way, Valid ADC channel are CH0~2 in 2/3-shunt type, Valid
ADC channel are CH0~7 in 1-shunt type, Figure 6.12-8 and Figure 6.12-9 show the function
diagram.
For 2-shunt Mode (SEQTYPE=0), ADC uses 2 channels among channel 0, 1 and 2, selected by
MODESEL and 1 PWM trigger sources are selected TRG1SRC, then ADC start to convert and
save data to ADC_SEQDAT0. Then, immediately start next conversion without delay and store
data to ADC_SEQDAT1. It also supports trigger delay timer DELAY (ADC_TRGDLY[7:0]).
742385c37e7cf38a88.png
For 1-shunt Mode (SEQTYPE=1), ADC uses 1 channel and 2 PWM trigger sources are selected
TRG1SRC and TRG2SRC. It’s first-come-first-service strategy if TRG2 triggers first, then ADC
start to convert and save data to ADC_SEQDAT0. Then, wait for TRG1 for next conversion and
store data to ADC_SEQDAT1. It also supports trigger delay timer DELAY (ADC_TRGDLY[7:0]).
910995c37e802f1f31.png
不知道有没有用过的大神?

使用特权

评论回复
| 2019-1-12 14:21 | 显示全部楼层
能完成你要的功能吗,如果那么设置。

使用特权

评论回复
| 2019-1-12 23:36 | 显示全部楼层
  1. /****************************************************************************
  2. * [url=home.php?mod=space&uid=288409]@file[/url]     main.c
  3. * [url=home.php?mod=space&uid=895143]@version[/url]  V2.0
  4. * $Revision: 4 $
  5. * $Date: 14/11/27 2:37p $
  6. * [url=home.php?mod=space&uid=247401]@brief[/url]    Demonstrate how to trigger ADC by PWM.
  7. * @note
  8. * Copyright (C) 2014 Nuvoton Technology Corp. All rights reserved.
  9. *
  10. ******************************************************************************/
  11. #include <stdio.h>
  12. #include "NUC200Series.h"


  13. #define PLL_CLOCK       50000000


  14. /*---------------------------------------------------------------------------------------------------------*/
  15. /* Define Function Prototypes                                                                              */
  16. /*---------------------------------------------------------------------------------------------------------*/
  17. void SYS_Init(void);
  18. void UART0_Init(void);
  19. void ADC_PWMTrigTest_SingleOpMode(void);


  20. void SYS_Init(void)
  21. {
  22.     /*---------------------------------------------------------------------------------------------------------*/
  23.     /* Init System Clock                                                                                       */
  24.     /*---------------------------------------------------------------------------------------------------------*/

  25.     /* Enable Internal RC 22.1184MHz clock */
  26.     CLK_EnableXtalRC(CLK_PWRCON_OSC22M_EN_Msk);

  27.     /* Waiting for Internal RC clock ready */
  28.     CLK_WaitClockReady(CLK_CLKSTATUS_OSC22M_STB_Msk);

  29.     /* Switch HCLK clock source to Internal RC and HCLK source divide 1 */
  30.     CLK_SetHCLK(CLK_CLKSEL0_HCLK_S_HIRC, CLK_CLKDIV_HCLK(1));

  31.     /* Enable external XTAL 12MHz clock */
  32.     CLK_EnableXtalRC(CLK_PWRCON_XTL12M_EN_Msk);

  33.     /* Waiting for external XTAL clock ready */
  34.     CLK_WaitClockReady(CLK_CLKSTATUS_XTL12M_STB_Msk);

  35.     /* Set core clock as PLL_CLOCK from PLL */
  36.     CLK_SetCoreClock(PLL_CLOCK);

  37.     /* Enable UART module clock */
  38.     CLK_EnableModuleClock(UART0_MODULE);

  39.     /* Enable ADC module clock */
  40.     CLK_EnableModuleClock(ADC_MODULE);

  41.     /* Enable PWM01 module clock */
  42.     CLK_EnableModuleClock(PWM01_MODULE);

  43.     /* Select UART module clock source */
  44.     CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UART_S_HXT, CLK_CLKDIV_UART(1));

  45.     /* Select PWM01 module clock source */
  46.     CLK_SetModuleClock(PWM01_MODULE, CLK_CLKSEL1_PWM01_S_HXT, 0);

  47.     /* ADC clock source is 22.1184MHz, set divider to 7, ADC clock is 22.1184/7 MHz */
  48.     CLK_SetModuleClock(ADC_MODULE, CLK_CLKSEL1_ADC_S_HIRC, CLK_CLKDIV_ADC(7));

  49.     /*---------------------------------------------------------------------------------------------------------*/
  50.     /* Init I/O Multi-function                                                                                 */
  51.     /*---------------------------------------------------------------------------------------------------------*/

  52.     /* Set GPB multi-function pins for UART0 RXD and TXD */
  53.     SYS->GPB_MFP &= ~(SYS_GPB_MFP_PB0_Msk | SYS_GPB_MFP_PB1_Msk);
  54.     SYS->GPB_MFP |= SYS_GPB_MFP_PB0_UART0_RXD | SYS_GPB_MFP_PB1_UART0_TXD;

  55.     /* Disable the GPA0 - GPA3 digital input path to avoid the leakage current. */
  56.     GPIO_DISABLE_DIGITAL_PATH(PA, 0xF);

  57.     /* Configure the GPA0 - GPA3 ADC analog input pins */
  58.     SYS->GPA_MFP &= ~(SYS_GPA_MFP_PA0_Msk | SYS_GPA_MFP_PA1_Msk | SYS_GPA_MFP_PA2_Msk | SYS_GPA_MFP_PA3_Msk) ;
  59.     SYS->GPA_MFP |= SYS_GPA_MFP_PA0_ADC0 | SYS_GPA_MFP_PA1_ADC1 | SYS_GPA_MFP_PA2_ADC2 | SYS_GPA_MFP_PA3_ADC3 ;
  60.     SYS->ALT_MFP1 = 0;

  61.     /* Configure the PA12 as PWM0 output pin */
  62.     SYS->GPA_MFP &= ~SYS_GPA_MFP_PA12_Msk;
  63.     SYS->GPA_MFP |= SYS_GPA_MFP_PA12_PWM0;


  64. }

  65. /*---------------------------------------------------------------------------------------------------------*/
  66. /* Init UART                                                                                               */
  67. /*---------------------------------------------------------------------------------------------------------*/
  68. void UART0_Init()
  69. {
  70.     /* Reset IP */
  71.     SYS_ResetModule(UART0_RST);

  72.     /* Configure UART0 and set UART0 Baudrate */
  73.     UART_Open(UART0, 115200);
  74. }

  75. /*---------------------------------------------------------------------------------------------------------*/
  76. /* Function: ADC_PWMTrigTest_SingleOpMode                                                                  */
  77. /*                                                                                                         */
  78. /* Parameters:                                                                                             */
  79. /*   None.                                                                                                 */
  80. /*                                                                                                         */
  81. /* Returns:                                                                                                */
  82. /*   None.                                                                                                 */
  83. /*                                                                                                         */
  84. /* Description:                                                                                            */
  85. /*   ADC hardware trigger test.                                                                            */
  86. /*---------------------------------------------------------------------------------------------------------*/
  87. void ADC_PWMTrigTest_SingleOpMode()
  88. {
  89.     printf("\n<<< PWM trigger test (Single mode) >>>\n");

  90.     /* Set the ADC operation mode as single, input mode as single-end and enable the analog input channel 2 */
  91.     ADC_Open(ADC, ADC_ADCR_DIFFEN_SINGLE_END, ADC_ADCR_ADMD_SINGLE, 0x1 << 2);

  92.     /* Power on ADC module */
  93.     ADC_POWER_ON(ADC);

  94.     /* Configure the hardware trigger condition and enable hardware trigger; PWM trigger delay: (4*10) system clock cycles*/
  95.     ADC_EnableHWTrigger(ADC, ADC_ADCR_TRGS_PWM, 0);

  96.     /* Clear the A/D interrupt flag for safe */
  97.     ADC_CLR_INT_FLAG(ADC, ADC_ADF_INT);

  98.     /* Center-aligned type; one-shot mode. */
  99.     PWM_SET_ALIGNED_TYPE(PWMA, 0x1, PWM_CENTER_ALIGNED);
  100.     /* Clock prescaler */
  101.     PWM_SET_PRESCALER(PWMA, 0, 2);
  102.     /* Timer 0 divisor=1 */
  103.     PWM_SET_DIVIDER(PWMA, 0, PWM_CLK_DIV_1);
  104.     /* PWM counter value */ /* PWM frequency = PWM clock source/(clock prescaler setting + 1)/divisor/(CNR+1) */
  105.     PWM_SET_CNR(PWMA, 0, 5);
  106.     /* PWM compare value */
  107.     PWM_SET_CMR(PWMA, 0, 1);
  108.     /* Enable PWM0 to trigger ADC */
  109.     PWM_EnableADCTrigger(PWMA, 0, 0);
  110.     /* PWM0 pin output enabled. PWM frequency 1MHz, duty 30%. */
  111.     PWM_EnableOutput(PWMA, 0x1);

  112.     /* Start PWM module */
  113.     PWM_Start(PWMA, 0x1);

  114.     /* Wait conversion done */
  115.     while(!ADC_GET_INT_FLAG(ADC, ADC_ADF_INT));

  116.     /* Clear the ADC interrupt flag */
  117.     ADC_CLR_INT_FLAG(ADC, ADC_ADF_INT);

  118.     printf("Channel 2: 0x%X\n", ADC_GET_CONVERSION_DATA(ADC, 2));

  119.     /* Disable ADC */
  120.     ADC_POWER_DOWN(ADC);
  121.     /* Stop PWM generation */
  122.     PWM_ForceStop(PWMA, 0x1);

  123. }





  124. /*---------------------------------------------------------------------------------------------------------*/
  125. /* MAIN function                                                                                           */
  126. /*---------------------------------------------------------------------------------------------------------*/
  127. main(void)
  128. {

  129.     /* Unlock protected registers */
  130.     SYS_UnlockReg();

  131.     /* Init System, IP clock and multi-function I/O */
  132.     SYS_Init();

  133.     /* Lock protected registers */
  134.     SYS_LockReg();

  135.     /* Init UART0 for printf */
  136.     UART0_Init();

  137.     /*---------------------------------------------------------------------------------------------------------*/
  138.     /* SAMPLE CODE                                                                                             */
  139.     /*---------------------------------------------------------------------------------------------------------*/

  140.     printf("\nSystem clock rate: %d Hz", SystemCoreClock);

  141.     /* ADC hardware trigger test */
  142.     ADC_PWMTrigTest_SingleOpMode();

  143.     /* Disable ADC module */
  144.     ADC_Close(ADC);

  145.     /* Disable ADC IP clock */
  146.     CLK_DisableModuleClock(ADC_MODULE);

  147.     /* Disable External Interrupt */
  148.     NVIC_DisableIRQ(ADC_IRQn);

  149.     printf("\nExit ADC sample code\n");

  150.     while(1);

  151. }

复制代码

使用特权

评论回复
| 2019-1-12 23:37 | 显示全部楼层
用库函数操作啊。寄存器的,看不太懂。

使用特权

评论回复
| 2019-1-12 23:40 | 显示全部楼层
搞错了,上面不是1200的,看错了。

使用特权

评论回复
| 2019-1-12 23:41 | 显示全部楼层

使用特权

评论回复
扫描二维码,随时随地手机跟帖
您需要登录后才可以回帖 登录 | 注册

本版积分规则

我要发帖 投诉建议 创建版块 申请版主

快速回复

您需要登录后才可以回帖
登录 | 注册
高级模式

论坛热帖

在线客服 快速回复 返回顶部 返回列表