Skip to content
Snippets Groups Projects
Commit 663be1b8 authored by Hauke Petersen's avatar Hauke Petersen
Browse files

cpu/sam3: added DAC (DACC) driver implementation

parent ac95d429
Branches
No related tags found
No related merge requests found
# Put defined MCU peripherals here (in alphabetical order) # Put defined MCU peripherals here (in alphabetical order)
FEATURES_PROVIDED += periph_adc FEATURES_PROVIDED += periph_adc
FEATURES_PROVIDED += periph_cpuid FEATURES_PROVIDED += periph_cpuid
FEATURES_PROVIDED += periph_dac
FEATURES_PROVIDED += periph_gpio FEATURES_PROVIDED += periph_gpio
FEATURES_PROVIDED += periph_hwrng FEATURES_PROVIDED += periph_hwrng
FEATURES_PROVIDED += periph_pwm FEATURES_PROVIDED += periph_pwm
......
...@@ -89,6 +89,19 @@ typedef uint32_t gpio_t; ...@@ -89,6 +89,19 @@ typedef uint32_t gpio_t;
*/ */
#define ADC_NUMOF (16U) #define ADC_NUMOF (16U)
/**
* @brief DAC configuration, valid for all boards using this CPU
*
* The sam3 has a fixed mapping of DAC pins and a fixed number of DAC channels,
* so this DAC configuration is valid for all boards using this CPU. No need for
* any board specific configuration.
*
* The sam3's DAC channels are mapped to the following fixed pins:
* - line 0 (ch0): PB15
* - line 1 (ch1): PB16
*/
#define DAC_NUMOF (2U)
#ifndef DOXYGEN #ifndef DOXYGEN
/** /**
* @brief Override GPIO modes * @brief Override GPIO modes
......
/*
* Copyright (C) 2017 Freie Universität Berlin
*
* 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
* directory for more details.
*/
/**
* @ingroup cpu_sam3
* @{
*
* @file
* @brief Low-level DAC driver implementation
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*
* @}
*/
#include "cpu.h"
#include "assert.h"
#include "periph/dac.h"
#define WP_KEY (0x444143)
#define PMC_BIT (1 << (ID_DACC - 32))
#ifndef DAC_STARTUP
#define DAC_STARTUP (DACC_MR_STARTUP_1984)
#endif
#ifndef DAC_REFRESH
#define DAC_REFRESH (DACC_MR_REFRESH(128))
#endif
int8_t dac_init(dac_t line)
{
assert(line < DAC_NUMOF);
/* power on DACC peripheral */
PMC->PMC_PCER1 = PMC_BIT;
/* unlock DACC registers */
DACC->DACC_WPMR = DACC_WPMR_WPKEY(WP_KEY);
/* configure mode register */
DACC->DACC_MR = (DAC_STARTUP | DACC_MR_TAG_EN | DAC_REFRESH);
/* enable the selected channel/line */
DACC->DACC_CHER = (1 << line);
/* set line initially to 0 volts -> this will startup the channel and the
* channel is ready after the defined number of startup cycles
* (DAC_STARTUP) have passed */
dac_set(line, 0);
return 0;
}
void dac_set(dac_t line, uint16_t value)
{
assert(line < DAC_NUMOF);
DACC->DACC_CDR = ((value >> 4) | (line << 12));
}
void dac_poweron(dac_t line)
{
assert(line < DAC_NUMOF);
PMC->PMC_PCER1 = (1 << (ID_DACC - 32));
DACC->DACC_CHER = PMC_BIT;
}
void dac_poweroff(dac_t line)
{
assert(line < DAC_NUMOF);
DACC->DACC_CHDR = (1 << line);
if (!(DACC->DACC_CHSR)) {
PMC->PMC_PCDR1 = PMC_BIT;
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment