diff --git a/boards/cc2538dk/include/periph_conf.h b/boards/cc2538dk/include/periph_conf.h index ecce1b51f3d9730a5611f5805abac0d3f01268cf..75597e4d7e6bf0820d371adbd1698cd742010943 100644 --- a/boards/cc2538dk/include/periph_conf.h +++ b/boards/cc2538dk/include/periph_conf.h @@ -118,7 +118,7 @@ static const spi_conf_t spi_config[] = { * @name ADC configuration * @{ */ -#define SOC_ADC_ADCCON_REF SOC_ADC_ADCCON_REF_AVDD5 +#define SOC_ADC_ADCCON3_EREF SOC_ADC_ADCCON3_EREF_AVDD5 static const adc_conf_t adc_config[] = { GPIO_PIN(0, 6), /**< GPIO_PA6 = ADC_ALS_PIN */ diff --git a/boards/openmote-b/include/periph_conf.h b/boards/openmote-b/include/periph_conf.h index cadfc6b8aeac78c0d45dfb8612a5b3a3e70a8b3b..97b915a392d8beed5546fe46de1cdd670f8b20f9 100644 --- a/boards/openmote-b/include/periph_conf.h +++ b/boards/openmote-b/include/periph_conf.h @@ -71,7 +71,7 @@ static const timer_conf_t timer_config[] = { * @name ADC configuration * @{ */ -#define SOC_ADC_ADCCON_REF SOC_ADC_ADCCON_REF_AVDD5 +#define SOC_ADC_ADCCON3_EREF SOC_ADC_ADCCON3_EREF_AVDD5 static const adc_conf_t adc_config[] = { GPIO_PIN(1, 0), /**< GPIO_PB0 = GPIO0_PIN */ diff --git a/boards/openmote-cc2538/include/periph_conf.h b/boards/openmote-cc2538/include/periph_conf.h index 8cd35e4d50a0baa579c1fa1e11a606d122126d1a..c82d63bb7db87f5aa9304bf68bb9c87cec03c885 100644 --- a/boards/openmote-cc2538/include/periph_conf.h +++ b/boards/openmote-cc2538/include/periph_conf.h @@ -69,7 +69,7 @@ static const timer_conf_t timer_config[] = { * @name ADC configuration * @{ */ -#define SOC_ADC_ADCCON_REF SOC_ADC_ADCCON_REF_AVDD5 +#define SOC_ADC_ADCCON3_EREF SOC_ADC_ADCCON3_EREF_AVDD5 static const adc_conf_t adc_config[] = { GPIO_PIN(0, 2), /**< GPIO_PA2 = AD4_PIN */ diff --git a/boards/remote-pa/include/periph_conf.h b/boards/remote-pa/include/periph_conf.h index e5049f9221d8914b371f98d3c9829bbc1dff024d..ad0269b11a5a09bc993afbfdd38a9b832b4121b2 100644 --- a/boards/remote-pa/include/periph_conf.h +++ b/boards/remote-pa/include/periph_conf.h @@ -73,7 +73,7 @@ static const spi_conf_t spi_config[] = { * @name ADC configuration * @{ */ -#define SOC_ADC_ADCCON_REF SOC_ADC_ADCCON_REF_AVDD5 +#define SOC_ADC_ADCCON3_EREF SOC_ADC_ADCCON3_EREF_AVDD5 static const adc_conf_t adc_config[] = { GPIO_PIN(0, 6), /**< GPIO_PA6 = ADC2_PIN */ diff --git a/boards/remote-reva/include/periph_conf.h b/boards/remote-reva/include/periph_conf.h index e2044e77a15e03c07b4a94527bdd4511f83646d7..4186dc970563dcca593923e29bf2c308fbc6a32c 100644 --- a/boards/remote-reva/include/periph_conf.h +++ b/boards/remote-reva/include/periph_conf.h @@ -73,7 +73,7 @@ static const spi_conf_t spi_config[] = { * @name ADC configuration * @{ */ -#define SOC_ADC_ADCCON_REF SOC_ADC_ADCCON_REF_AVDD5 +#define SOC_ADC_ADCCON3_EREF SOC_ADC_ADCCON3_EREF_AVDD5 static const adc_conf_t adc_config[] = { GPIO_PIN(0, 5), /**< GPIO_PA5 = ADC1_PIN */ diff --git a/boards/remote-revb/include/periph_conf.h b/boards/remote-revb/include/periph_conf.h index 14139802b5755f04f99769818ee872b718ec6358..e6bb958b2b83d825d6b845a28aa641d10b96edda 100644 --- a/boards/remote-revb/include/periph_conf.h +++ b/boards/remote-revb/include/periph_conf.h @@ -75,7 +75,7 @@ static const spi_conf_t spi_config[] = { * @name ADC configuration * @{ */ -#define SOC_ADC_ADCCON_REF SOC_ADC_ADCCON_REF_AVDD5 +#define SOC_ADC_ADCCON3_EREF SOC_ADC_ADCCON3_EREF_AVDD5 static const adc_conf_t adc_config[] = { GPIO_PIN(0, 5), /**< GPIO_PA5 = ADC1_PIN */ diff --git a/cpu/cc2538/include/cc2538.h b/cpu/cc2538/include/cc2538.h index bca9ff73760d0d6b17e71344f425eba91dbe680f..ece7f659a1b20fea6aefc7e357c80538a499fc7b 100644 --- a/cpu/cc2538/include/cc2538.h +++ b/cpu/cc2538/include/cc2538.h @@ -675,14 +675,6 @@ typedef volatile uint32_t cc2538_reg_t; /**< Least-significant 32 bits of the IE #define SMWDTHROSC_STCV2 ( *(cc2538_reg_t*)0x400d5064 ) /**< Sleep Timer Capture value byte 2 */ #define SMWDTHROSC_STCV3 ( *(cc2538_reg_t*)0x400d5068 ) /**< Sleep Timer Capture value byte 3 */ #define ANA_REGS_IVCTRL ( *(cc2538_reg_t*)0x400d6004 ) /**< Analog control register */ -#define SOC_ADC_ADCCON1 ( *(cc2538_reg_t*)0x400d7000 ) /**< ADC Control Register 1 */ -#define SOC_ADC_ADCCON2 ( *(cc2538_reg_t*)0x400d7004 ) /**< ADC Control Register 2 */ -#define SOC_ADC_ADCCON3 ( *(cc2538_reg_t*)0x400d7008 ) /**< ADC Control Register 3 */ -#define SOC_ADC_ADCL ( *(cc2538_reg_t*)0x400d700c ) /**< Least-significant part of ADC conversion result. */ -#define SOC_ADC_ADCH ( *(cc2538_reg_t*)0x400d7010 ) /**< Most-significant part of ADC conversion result. */ -#define SOC_ADC_RNDL ( *(cc2538_reg_t*)0x400d7014 ) /**< Random-number-generator data; low byte. */ -#define SOC_ADC_RNDH ( *(cc2538_reg_t*)0x400d7018 ) /**< Random-number-generator data; high byte. */ -#define SOC_ADC_CMPCTL ( *(cc2538_reg_t*)0x400d7024 ) /**< Analog comparator control and status register. */ #define GPIO_A_DATA ( *(cc2538_reg_t*)0x400d9000 ) /**< GPIO_A Data Register */ #define GPIO_A_DIR ( *(cc2538_reg_t*)0x400d9400 ) /**< GPIO_A data direction register */ #define GPIO_A_IS ( *(cc2538_reg_t*)0x400d9404 ) /**< GPIO_A Interrupt Sense register */ diff --git a/cpu/cc2538/include/cc2538_soc_adc.h b/cpu/cc2538/include/cc2538_soc_adc.h index 0caf3f7e7648a20b67feedafc8612cba45462fd6..6f2f835d82c33cb6da8d1fa1de8828e22b7e038b 100644 --- a/cpu/cc2538/include/cc2538_soc_adc.h +++ b/cpu/cc2538/include/cc2538_soc_adc.h @@ -1,5 +1,6 @@ /* * Copyright (C) 2014 Loci Controls Inc. + * 2018 HAW Hamburg * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level @@ -15,6 +16,7 @@ * @brief CC2538 SOC ADC interface * * @author Ian Martin <ian@locicontrols.com> + * @author Sebastian Meiling <s@mlng.net> */ #ifndef CC2538_SOC_ADC_H @@ -30,34 +32,17 @@ extern "C" { * @brief SOC ADC component registers */ typedef struct { - - /** - * @brief ADC control register - */ - union { - cc2538_reg_t ADCCON1; /**< ADC Control Register 1 */ - struct { - cc2538_reg_t RESERVED2 : 2; /**< Reserved bits */ - cc2538_reg_t RCTRL : 2; /**< Random number generator control */ - cc2538_reg_t STSEL : 2; /**< Start select */ - cc2538_reg_t ST : 1; /**< Start conversion */ - cc2538_reg_t EOC : 1; /**< End of conversion */ - cc2538_reg_t RESERVED1 : 24; /**< Reserved bits */ - } ADCCON1bits; - } cc2538_adc_adccon1; - - cc2538_reg_t ADCCON2; /**< ADC Control Register 2 */ - cc2538_reg_t ADCCON3; /**< ADC Control Register 3 */ - cc2538_reg_t ADCL; /**< Least-significant part of ADC conversion result. */ - cc2538_reg_t ADCH; /**< Most-significant part of ADC conversion result. */ - cc2538_reg_t RNDL; /**< Random-number-generator data; low byte. */ - cc2538_reg_t RNDH; /**< Random-number-generator data; high byte. */ - cc2538_reg_t RESERVED[2]; /**< Reserved bytes */ - cc2538_reg_t CMPCTL; /**< Analog comparator control and status register. */ + cc2538_reg_t ADCCON1; /**< ADC Control Register 1 */ + cc2538_reg_t ADCCON2; /**< ADC Control Register 2 */ + cc2538_reg_t ADCCON3; /**< ADC Control Register 3 */ + cc2538_reg_t ADCL; /**< Least-significant part of ADC conversion result. */ + cc2538_reg_t ADCH; /**< Most-significant part of ADC conversion result. */ + cc2538_reg_t RNDL; /**< Random-number-generator data; low byte. */ + cc2538_reg_t RNDH; /**< Random-number-generator data; high byte. */ + cc2538_reg_t RESERVED[2]; /**< Reserved bytes */ + cc2538_reg_t CMPCTL; /**< Analog comparator control and status register. */ } cc2538_soc_adc_t; -#define SOC_ADC ( (cc2538_soc_adc_t*)0x400d7000 ) /**< One and only instance of the SOC ADC component */ - #ifdef __cplusplus } /* end extern "C" */ #endif diff --git a/cpu/cc2538/include/periph_cpu.h b/cpu/cc2538/include/periph_cpu.h index 807727e6dd91df0025e8e29d5633738c5c304762..47386b8570885baf653744bca61309b3d94d7086 100644 --- a/cpu/cc2538/include/periph_cpu.h +++ b/cpu/cc2538/include/periph_cpu.h @@ -24,6 +24,8 @@ #include <stdint.h> #include <stdio.h> +#include "vendor/hw_soc_adc.h" + #include "cpu.h" #include "vendor/hw_ssi.h" @@ -264,36 +266,13 @@ typedef enum { typedef gpio_t adc_conf_t; /** - * @name SOC_ADC_ADCCON3 register bit masks - * @{ - */ -#define SOC_ADC_ADCCON3_EREF (0x000000C0) /**< Reference voltage for extra */ -#define SOC_ADC_ADCCON3_EDIV (0x00000030) /**< Decimation rate for extra */ -#define SOC_ADC_ADCCON3_ECH (0x0000000F) /**< Single channel select */ -/** @} */ - -/** - * @name SOC_ADC_ADCCONx registers field values - * @{ - */ -#define SOC_ADC_ADCCON_REF_INT (0 << 6) /**< Internal reference */ -#define SOC_ADC_ADCCON_REF_EXT (1 << 6) /**< External reference on AIN7 pin */ -#define SOC_ADC_ADCCON_REF_AVDD5 (2 << 6) /**< AVDD5 pin */ -#define SOC_ADC_ADCCON_REF_DIFF (3 << 6) /**< External reference on AIN6-AIN7 differential input */ -#define SOC_ADC_ADCCON_CH_GND (0xC) /**< GND */ -/** @} */ - -/** - * @brief Mask to check end-of-conversion (EOC) bit - */ -#define SOC_ADC_ADCCON1_EOC_MASK (0x80) - -/** - * @name Masks for ADC raw data + * @name SOC_ADC_ADCCON3_EREF registers field values * @{ */ -#define SOC_ADC_ADCL_MASK (0x000000FC) -#define SOC_ADC_ADCH_MASK (0x000000FF) +#define SOC_ADC_ADCCON3_EREF_INT (0 << SOC_ADC_ADCCON3_EREF_S) /**< Internal reference */ +#define SOC_ADC_ADCCON3_EREF_EXT (1 << SOC_ADC_ADCCON3_EREF_S) /**< External reference on AIN7 pin */ +#define SOC_ADC_ADCCON3_EREF_AVDD5 (2 << SOC_ADC_ADCCON3_EREF_S) /**< AVDD5 pin */ +#define SOC_ADC_ADCCON3_EREF_DIFF (3 << SOC_ADC_ADCCON3_EREF_S) /**< External reference on AIN6-AIN7 differential input */ /** @} */ /** diff --git a/cpu/cc2538/periph/adc.c b/cpu/cc2538/periph/adc.c index ac3fe04907ad26b3a10666aec0a654eef1dc0b92..db6ecb2f25becfc2f740f6fa90f9eeee76300531 100644 --- a/cpu/cc2538/periph/adc.c +++ b/cpu/cc2538/periph/adc.c @@ -20,6 +20,9 @@ * @} */ +#include "vendor/hw_memmap.h" +#include "vendor/hw_soc_adc.h" + #include "board.h" #include "cpu.h" #include "periph_conf.h" @@ -29,6 +32,8 @@ #define ENABLE_DEBUG (0) #include "debug.h" +static cc2538_soc_adc_t *soc_adc = (cc2538_soc_adc_t *)SOC_ADC_BASE; + int adc_init(adc_t line) { if (line >= ADC_NUMOF) { @@ -36,11 +41,10 @@ int adc_init(adc_t line) return -1; } - cc2538_soc_adc_t *adca = SOC_ADC; /* stop random number generator, and set STSEL = 1 */ - adca->cc2538_adc_adccon1.ADCCON1 = 0x3c; + soc_adc->ADCCON1 = (SOC_ADC_ADCCON1_STSEL_M | SOC_ADC_ADCCON1_RCTRL_M); /* disable any DMA, continous ADC settings */ - adca->ADCCON2 = 0x0; + soc_adc->ADCCON2 = 0x0; /* configure ADC GPIO as analog input */ gpio_init(adc_config[line], GPIO_IN_ANALOG); @@ -83,25 +87,23 @@ int adc_sample(adc_t line, adc_res_t res) */ rshift--; - cc2538_soc_adc_t *adca = SOC_ADC; /* configure adc line with parameters and trigger a single conversion*/ - uint32_t reg = (adca->ADCCON3) & ~(SOC_ADC_ADCCON3_EREF | - SOC_ADC_ADCCON3_EDIV | - SOC_ADC_ADCCON3_ECH); - adca->ADCCON3 = reg | res | SOC_ADC_ADCCON_REF | - (adc_config[line] & GPIO_PIN_MASK); + uint32_t reg = (soc_adc->ADCCON3) & ~(SOC_ADC_ADCCON3_EREF_M | + SOC_ADC_ADCCON3_EDIV_M | + SOC_ADC_ADCCON3_ECH_M); + soc_adc->ADCCON3 = reg | res | SOC_ADC_ADCCON3_EREF | + (adc_config[line] & GPIO_PIN_MASK); DEBUG("ADCCON1: %"PRIu32" ADCCON2: %"PRIu32" ADCCON3: %"PRIu32"\n", - adca->cc2538_adc_adccon1.ADCCON1, adca->ADCCON2, adca->ADCCON3); + soc_adc->ADCCON1, soc_adc->ADCCON2, soc_adc->ADCCON3); /* Poll/wait until end of conversion */ - while ((adca->cc2538_adc_adccon1.ADCCON1 & - SOC_ADC_ADCCON1_EOC_MASK) == 0) {} + while ((soc_adc->ADCCON1 & SOC_ADC_ADCCON1_EOC_M) == 0) {} /* Read result after conversion completed, * reading SOC_ADC_ADCH last will clear SOC_ADC_ADCCON1.EOC */ - int16_t sample = adca->ADCL & SOC_ADC_ADCL_MASK; - sample |= (adca->ADCH & SOC_ADC_ADCH_MASK) << 8; + int16_t sample = soc_adc->ADCL & SOC_ADC_ADCL_ADC_M; + sample |= (soc_adc->ADCH & SOC_ADC_ADCH_ADC_M) << 8; /* sample right shifted depending on resolution */ sample = sample >> rshift; DEBUG("adc_sample: raw value %"PRIi16"\n", sample); diff --git a/cpu/cc2538/periph/hwrng.c b/cpu/cc2538/periph/hwrng.c index 6d0d9a850b7b0e059bc8ecc615e2370919672599..008bce9d01d4a4ae40e23a6c0b8d69453f5f7e49 100644 --- a/cpu/cc2538/periph/hwrng.c +++ b/cpu/cc2538/periph/hwrng.c @@ -21,22 +21,31 @@ * @} */ +#include "vendor/hw_memmap.h" +#include "vendor/hw_soc_adc.h" + #include "cpu.h" #include "periph/hwrng.h" +#define ENABLE_DEBUG (0) +#include "debug.h" + +static cc2538_soc_adc_t *soc_adc = (cc2538_soc_adc_t *)SOC_ADC_BASE; + void hwrng_init(void) { uint16_t seed = 0; int i; /* Make sure the RNG is on */ - SOC_ADC->cc2538_adc_adccon1.ADCCON1bits.RCTRL = 0; + uint32_t reg32 = soc_adc->ADCCON1 & ~(SOC_ADC_ADCCON1_RCTRL_M); + soc_adc->ADCCON1 = reg32; /* Enable clock for the RF Core */ SYS_CTRL_RCGCRFC = 1; /* Wait for the clock ungating to take effect */ - while (SYS_CTRL_RCGCRFC != 1); + while (SYS_CTRL_RCGCRFC != 1) {} /* Infinite RX - FRMCTRL0[3:2] = 10. This will mess with radio operation */ RFCORE_XREG_FRMCTRL0 = 0x00000008; @@ -63,8 +72,8 @@ void hwrng_init(void) } /* Seed the high byte first: */ - SOC_ADC_RNDL = (seed >> 8) & 0xff; - SOC_ADC_RNDL = seed & 0xff; + soc_adc->RNDH = (seed >> 8) & 0xff; + soc_adc->RNDL = seed & 0xff; /* Turn RF off: */ RFCORE_SFR_RFST = ISRFOFF; @@ -72,16 +81,16 @@ void hwrng_init(void) void hwrng_read(void *buf, unsigned int num) { - unsigned count; uint8_t *b = (uint8_t *)buf; - for (count = 0; count < num; ) { + for (unsigned count = 0; count < num; count++) { /* Clock the RNG LSFR once: */ - SOC_ADC->cc2538_adc_adccon1.ADCCON1bits.RCTRL = 1; - + soc_adc->ADCCON1 = soc_adc->ADCCON1 | (1UL << SOC_ADC_ADCCON1_RCTRL_S); /* Read up to 2 bytes of hwrng data: */ - b[count++] = SOC_ADC_RNDL; - if (count >= num) break; - b[count++] = SOC_ADC_RNDH; + b[count] = soc_adc->RNDL; + count++; + if (count < num) { + b[count] = soc_adc->RNDH; + } } }