This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

MSP430FR2353 AD多通道采集 现在采集通道8 和内部温度通道A12 只采集这两个通道求指点下,以下是我的配置读取参考官方例子,参考电压内部2.5V,不顺序采集AD ,只采集指定的通道AD的采集

#include <msp430.h>
unsigned int ADC_Result[13]; // 12-bit ADC conversion result array
unsigned char i;
#define CALADC_15V_30C *((unsigned int *)0x1A1A) // Temperature Sensor Calibration-30 C
// See device datasheet for TLV table memory mapping
#define CALADC_15V_85C *((unsigned int *)0x1A1C) // Temperature Sensor Calibration-High Temperature (85 for Industrial, 105 for Extended)

int main(void)
{
WDTCTL = WDTPW | WDTHOLD; // Stop WDT
// Configure ADC
// Configure ADC A1 pin
P5SEL0 |= BIT0;
P5SEL1 |= BIT0;
ADCCTL0 |= ADCSHT_8 | ADCON; // ADCON, S&H=16 ADC clks
ADCCTL1 |= ADCSHP | ADCCONSEQ_1 | ADCSSEL_1; // ADCCLK = MODOSC; sampling timer
ADCCTL2 &= ~ADCRES; // clear ADCRES in ADCCTL
ADCCTL2 |= ADCRES_2; // 12-bit conversion results
ADCIE |= ADCIE0; // Enable ADC conv complete interrupt
ADCMCTL0 = ADCINCH_12 | ADCSREF_1; // A1 ADC input select; Vref=2.5V
// Configure reference module
PMMCTL0_H = PMMPW_H; // Unlock the PMM registers
PMMCTL2 |= INTREFEN | REFVSEL_2 | TSENSOREN ; // Enable internal 2.5V reference
__delay_cycles(400); // Delay for reference settling
_EINT();
while(1)
{
while(ADCCTL2 & ADCBUSY); // Wait if ADC core is active
ADCCTL0 |= ADCENC | ADCSC; // Sampling and conversion start
__delay_cycles(5000);
}

}
// ADC interrupt service routine
#if defined(__TI_COMPILER_VERSION__) || defined(__IAR_SYSTEMS_ICC__)
#pragma vector=ADC_VECTOR
__interrupt void ADC_ISR(void)
#elif defined(__GNUC__)
void __attribute__ ((interrupt(ADC_VECTOR))) ADC_ISR (void)
#else
#error Compiler not supported!
#endif
{
volatile float temp;
volatile float IntDegF;
volatile float IntDegC;

switch(__even_in_range(ADCIV,ADCIV_ADCIFG))
{
case ADCIV_NONE:
break;
case ADCIV_ADCOVIFG:
break;
case ADCIV_ADCTOVIFG:
break;
case ADCIV_ADCHIIFG:
break;
case ADCIV_ADCLOIFG:
break;
case ADCIV_ADCINIFG:
break;
case ADCIV_ADCIFG:

ADC_Result[i] = ADCMEM0;
if(i == 0)
{
i =12;
temp =ADC_Result[11];
// Temperature in Celsius
// The temperature (Temp, C)=
IntDegC = (temp-CALADC_15V_30C)*(85-30)/(CALADC_15V_85C-CALADC_15V_30C)+30;

// Temperature in Fahrenheit
// Tf = (9/5)*Tc | 32
IntDegF = 9*IntDegC/5+32;
//__bic_SR_register_on_exit(LPM3_bits); // Exit LPM3
}
else
{
i--;
}

break;
default:
break;
}
}

  • 您现在程序运行结果如何?
  • 那您上述程序运行如何?是自己制作的板子?建议先运行下TI例程,看是否能正常采集转换

    您可以参考下面的例子,是采集A2/A1/A0, 使用internal 2V Ref

    /* --COPYRIGHT--,BSD_EX
     * Copyright (c) 2016, Texas Instruments Incorporated
     * All rights reserved.
     *
     * Redistribution and use in source and binary forms, with or without
     * modification, are permitted provided that the following conditions
     * are met:
     *
     * *  Redistributions of source code must retain the above copyright
     *    notice, this list of conditions and the following disclaimer.
     *
     * *  Redistributions in binary form must reproduce the above copyright
     *    notice, this list of conditions and the following disclaimer in the
     *    documentation and/or other materials provided with the distribution.
     *
     * *  Neither the name of Texas Instruments Incorporated nor the names of
     *    its contributors may be used to endorse or promote products derived
     *    from this software without specific prior written permission.
     *
     * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
     * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
     * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
     * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
     * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
     * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
     * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
     * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
     * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
     * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     *
     *******************************************************************************
     *
     *                       MSP430 CODE EXAMPLE DISCLAIMER
     *
     * MSP430 code examples are self-contained low-level programs that typically
     * demonstrate a single peripheral function or device feature in a highly
     * concise manner. For this the code may rely on the device's power-on default
     * register values and settings such as the clock configuration and care must
     * be taken when combining code from several examples to avoid potential side
     * effects. Also see www.ti.com/grace for a GUI- and www.ti.com/msp430ware
     * for an API functional library-approach to peripheral configuration.
     *
     * --/COPYRIGHT--*/
    //******************************************************************************
    //  MSP430FR235x Demo - ADC, Sample A2/A1/A0, internal 2V Ref.
    //
    //  Description: This example works on Sequence-of-Channels Mode.
    //  A2/A1/A0 is sampled 16ADCclks with reference to 2V.
    //  Internal oscillator times sample (16x) and conversion(13x).
    //  Inside ADC_ISR A2/A1/A0 sample value put into array ADC_Result[3].
    //  ACLK = default REFO ~32768Hz, MCLK = SMCLK = default DCODIV ~1MHz.
    //
    //
    //                MSP430FR2355
    //             -----------------
    //         /|\|                 |
    //          | |                 |
    //          --|RST              |
    //            |                 |
    //        >---|P1.2/A2          |
    //        >---|P1.1/A1          |
    //        >---|P1.0/A0          |
    //
    //
    //   Cash Hao
    //   Texas Instruments Inc.
    //   November 2016
    //   Built with IAR Embedded Workbench v6.50.0 & Code Composer Studio v6.2.0
    //******************************************************************************
    #include <msp430.h>
    
    unsigned int ADC_Result[3];                                    // 12-bit ADC conversion result array
    unsigned char i;
    
    int main(void)
    {
        WDTCTL = WDTPW | WDTHOLD;                                   // Stop WDT
    
        // Configure ADC A1~2 pins
        P1SEL0 |=  BIT1 + BIT2;
        P1SEL1 |=  BIT1 + BIT2;
    
        // Disable the GPIO power-on default high-impedance mode to activate
        // previously configured port settings
        PM5CTL0 &= ~LOCKLPM5;
    
        // Configure ADC
        ADCCTL0 |= ADCSHT_2 | ADCMSC | ADCON;                       // 16ADCclks, MSC, ADC ON
        ADCCTL1 |= ADCSHP | ADCCONSEQ_1 | ADCSSEL_1;                // ADC clock ACLK, sampling timer, s/w trig.,single sequence
        ADCCTL2 &= ~ADCRES;                                         // clear ADCRES in ADCCTL
        ADCCTL2 |= ADCRES_2;                                        // 12-bit conversion results
        ADCMCTL0 |= ADCINCH_2 | ADCSREF_1;                          // A0~2(EoS); Vref=2V
        ADCIE |= ADCIE0;                                            // Enable ADC conv complete interrupt
    
        // Configure reference
        PMMCTL0_H = PMMPW_H;                                        // Unlock the PMM registers
        PMMCTL2 |= INTREFEN | REFVSEL_1;                            // Enable internal 2V reference
        __delay_cycles(400);                                        // Delay for reference settling
        __no_operation();
    
        while(1)
        {
            i = 2;
            while(ADCCTL1 & ADCBUSY);                                // Wait if ADC core is active
            ADCCTL0 |= ADCENC | ADCSC;                               // Sampling and conversion start
            __bis_SR_register(LPM0_bits | GIE);                      // Enter LPM0 w/ interrupts
            __no_operation();                                        // Only for debug
            __delay_cycles(5000);
            __no_operation();
        }
    }
    
    // ADC interrupt service routine
    #if defined(__TI_COMPILER_VERSION__) || defined(__IAR_SYSTEMS_ICC__)
    #pragma vector=ADC_VECTOR
    __interrupt void ADC_ISR(void)
    #elif defined(__GNUC__)
    void __attribute__ ((interrupt(ADC_VECTOR))) ADC_ISR (void)
    #else
    #error Compiler not supported!
    #endif
    {
        switch(__even_in_range(ADCIV,ADCIV_ADCIFG))
        {
            case ADCIV_NONE:
                break;
            case ADCIV_ADCOVIFG:
                break;
            case ADCIV_ADCTOVIFG:
                break;
            case ADCIV_ADCHIIFG:
                break;
            case ADCIV_ADCLOIFG:
                break;
            case ADCIV_ADCINIFG:
                break;
            case ADCIV_ADCIFG:
                ADC_Result[i] = ADCMEM0;
                if(i == 0)
                {
                    __bic_SR_register_on_exit(LPM0_bits);              // Exist LPM0
                }
                else
                {
                    i--;
                }
                break;
            default:
                break;
        }
    }
    

  • 采集到的数据很乱, 下面是我采集到的数据 感觉[0] 很像我内部温度的采集 [9] 很像我A8通道的采集,是不是我哪里配置的错了,还是别的什么?求指点下,
    ADC_Result unsigned int[13] [1303,2056,4095,1245,1488...] 0x002000
    [0] unsigned int 1303 0x002000
    [1] unsigned int 2056 0x002002
    [2] unsigned int 4095 0x002004
    [3] unsigned int 1245 0x002006
    [4] unsigned int 1488 0x002008
    [5] unsigned int 2415 0x00200A
    [6] unsigned int 4095 0x00200C
    [7] unsigned int 725 0x00200E
    [8] unsigned int 51 0x002010
    [9] unsigned int 0 0x002012
    [10]unsigned int 375 0x002014
    [11]unsigned int 1038 0x002016
    [12]unsigned int 1053 0x002018
    刚才你说的配置A8 做了如下配置
    ADCMCTL0 = ADCINCH_12 | ADCINCH_8 | ADCSREF_1; // A8 ADC input select; Vref=2.5V
    采集的结果就是上面的
  • 那您单独测A8或者A12呢?是否正常?
  • 我参考了这个例子
    // Configure ADC A1~2 pins
    P1SEL0 |= BIT1 + BIT2;
    P1SEL1 |= BIT1 + BIT2;
    这行配置好像没对A0 进行选择吧,我看了寄存器是没有,
    ADCMCTL0 |= ADCINCH_2 | ADCSREF_1; // A0~2(EoS); Vref=2V
    咱们通道只指定了指定的2 通道循环从 0 1 2 采集,有没有办法不循环呢,指定几个通道进行循环, 比如 2 4 8 三个通道进行循环 ,这样的话该如何进行配置,板子是我们自己的制作的,只是,我现在进行简单的多通道采集,然后单片机直接接地采集到数据就是错误的
  • 单独测试时OK的,我都单独测试过了,包含咱们温度提供的公式,都是正常的,还有就是A8 IO口我以前配置过,仅仅A8 口 没有什么问题,两个结合起来不知道如何配置下,咱们提供的例子,是指定循环 0 1 2 的配置