1 | #define DR_ADDRESS ((uint32_t)0x4001244C)
|
2 |
|
3 | void ADC_Configuration (void)
|
4 | {
|
5 | NVIC_InitTypeDef NVIC_InitStructure;
|
6 | ADC_InitTypeDef ADC_InitStructure;
|
7 | DMA_InitTypeDef DMA_InitStructure;
|
8 |
|
9 | /* PCLK2 is the APB2 clock */
|
10 | RCC_ADCCLKConfig (RCC_PCLK2_Div6); /* ADCCLK = PCLK2/6 = 72/6 = 12MHz*/
|
11 |
|
12 | RCC_APB2PeriphClockCmd (RCC_APB2Periph_ADC1, ENABLE); /* Enable ADC1 clock so that we can talk to it */
|
13 | ADC_DeInit (ADC1); /* Put everything back to power-on defaults */
|
14 |
|
15 | /* NVIC DMA interrupt setup */
|
16 | NVIC_InitStructure.NVIC_IRQChannel = DMA1_Channel1_IRQn;
|
17 | NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
|
18 | NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
|
19 | NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
|
20 | NVIC_Init(&NVIC_InitStructure);
|
21 |
|
22 | /* DMA1 channel1 configuration */
|
23 | DMA_DeInit(DMA1_Channel1);
|
24 | DMA_InitStructure.DMA_PeripheralBaseAddr = DR_ADDRESS;
|
25 | DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t) &ADCValues;
|
26 | DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
|
27 | DMA_InitStructure.DMA_BufferSize = 2;
|
28 | DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
|
29 | DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
|
30 | DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
|
31 | DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
|
32 | DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
|
33 | DMA_InitStructure.DMA_Priority = DMA_Priority_High;
|
34 | DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
|
35 | DMA_Init (DMA1_Channel1, &DMA_InitStructure);
|
36 | DMA_Cmd (DMA1_Channel1, ENABLE);
|
37 |
|
38 | /* -------- ADC1 Configuration -------- */
|
39 | ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
|
40 | ADC_InitStructure.ADC_ScanConvMode = ENABLE;
|
41 | ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
|
42 | ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
|
43 | ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
|
44 | ADC_InitStructure.ADC_NbrOfChannel = 2;
|
45 | ADC_Init (ADC1, &ADC_InitStructure);
|
46 |
|
47 | /* ADC Ch1 & CH2 configuration */
|
48 | ADC_RegularChannelConfig (ADC1, ADC_Channel_1, 1, ADC_SampleTime_28Cycles5);
|
49 | ADC_RegularChannelConfig (ADC1, ADC_Channel_2, 2, ADC_SampleTime_28Cycles5);
|
50 | ADC_DMACmd (ADC1, ENABLE); /* Enable ADC1 DMA */
|
51 | ADC_Cmd (ADC1, ENABLE); /* Enable ADC1 */
|
52 |
|
53 |
|
54 | /* Enable DMA1 Channel Transfer Complete interrupt */
|
55 | DMA_ITConfig (DMA1_Channel1, DMA_IT_TC, ENABLE);
|
56 |
|
57 | ADC_ResetCalibration (ADC1); /* Enable Reset Calibration Register */
|
58 | while (ADC_GetResetCalibrationStatus (ADC1)); /* wait until reset of Calibration Register */
|
59 |
|
60 | ADC_StartCalibration (ADC1); /* Start ADC Calibration */
|
61 | while (ADC_GetCalibrationStatus (ADC1)); /* wait until end of calibration */
|
62 | }
|