Class library for internal ADC and DAC connected by SPI. ADC is triggered by TIM2. This library support clock generator using TIM3 for switched-capacitor filter to smooth output signal of DAC. This library includes derivative class to support interrupt occured in end of AD conversion. Slave select of SPI for DAC is generated using TIM4. Validated for ST Nucleo F401RE, F411RE. New version. 内蔵 ADC と,SPI 接続の DAC のためのクラスライブラリ.ADC の変換開始トリガは TIM2 で発生.DAC の出力信号を平滑化するためのスイッチトキャパシタフィルタ用のクロックは TIM3 を使用.DAC の SPI 用スレーブ選択信号は TIM4 で発生.ST Nucleo F401RE,F411RE で動作を確認.新バージョン
Dependents: UIT2_MovingAverage UIT2_AllpassReverb UIT2_CombReverb UIT2_FIR_LPF_Symmetry ... more
DAC_MCP4922.hpp@16:0001d3e93bee, 2015-01-11 (annotated)
- Committer:
- MikamiUitOpen
- Date:
- Sun Jan 11 02:20:04 2015 +0000
- Revision:
- 16:0001d3e93bee
- Parent:
- 14:6c60601c1834
- Child:
- 18:0bfced9d5526
17
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
MikamiUitOpen | 0:6e0ed5adfe47 | 1 | //------------------------------------------------------ |
MikamiUitOpen | 0:6e0ed5adfe47 | 2 | // Class for single DAC in MCP4922 -- Header |
MikamiUitOpen | 0:6e0ed5adfe47 | 3 | // Fast version |
MikamiUitOpen | 0:6e0ed5adfe47 | 4 | // |
MikamiUitOpen | 0:6e0ed5adfe47 | 5 | // Default pin assign |
MikamiUitOpen | 0:6e0ed5adfe47 | 6 | // D11 SPI Master Out Slave In |
MikamiUitOpen | 0:6e0ed5adfe47 | 7 | // D13 SPI Serial Clock |
MikamiUitOpen | 14:6c60601c1834 | 8 | // D10 SPI Slave Select ----------------------- TIM4 |
MikamiUitOpen | 8:f933fcd30408 | 9 | // D12 to MCP4922 LDAC pin |
MikamiUitOpen | 14:6c60601c1834 | 10 | // D9 clock for Switched-capacitor filter ---- TIM3 |
MikamiUitOpen | 0:6e0ed5adfe47 | 11 | // |
MikamiUitOpen | 8:f933fcd30408 | 12 | // Argument cs in constructor must be output of TIM4, |
MikamiUitOpen | 8:f933fcd30408 | 13 | // i.e. D10(PB_6), PB_7, D15(PB_8), or D14(PB_9) |
MikamiUitOpen | 8:f933fcd30408 | 14 | // |
MikamiUitOpen | 14:6c60601c1834 | 15 | // Argument pin in function ScfClockTim3() can be |
MikamiUitOpen | 14:6c60601c1834 | 16 | // PA_6(D12), PB_4(D5), PC_6, PB_5(D4), PC_7(D9), |
MikamiUitOpen | 14:6c60601c1834 | 17 | // PC_8, or PC_9 |
MikamiUitOpen | 8:f933fcd30408 | 18 | // |
MikamiUitOpen | 14:6c60601c1834 | 19 | // 2014/12/21, Copyright (c) 2014 MIKAMI, Naoki |
MikamiUitOpen | 0:6e0ed5adfe47 | 20 | //------------------------------------------------------ |
MikamiUitOpen | 0:6e0ed5adfe47 | 21 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 22 | #ifndef DAC_MCP4922_HPP |
MikamiUitOpen | 0:6e0ed5adfe47 | 23 | #define DAC_MCP4922_HPP |
MikamiUitOpen | 0:6e0ed5adfe47 | 24 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 25 | #include "mbed.h" |
MikamiUitOpen | 0:6e0ed5adfe47 | 26 | #include "tim4_slaveSelect.hpp" |
MikamiUitOpen | 0:6e0ed5adfe47 | 27 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 28 | namespace Mikami |
MikamiUitOpen | 0:6e0ed5adfe47 | 29 | { |
MikamiUitOpen | 0:6e0ed5adfe47 | 30 | class DAC_MCP4922 |
MikamiUitOpen | 0:6e0ed5adfe47 | 31 | { |
MikamiUitOpen | 0:6e0ed5adfe47 | 32 | public: |
MikamiUitOpen | 0:6e0ed5adfe47 | 33 | enum DAC { DAC_A = 0, DAC_B = 0x8000 }; |
MikamiUitOpen | 0:6e0ed5adfe47 | 34 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 35 | // Constructor |
MikamiUitOpen | 0:6e0ed5adfe47 | 36 | DAC_MCP4922( |
MikamiUitOpen | 3:77bc5550dc10 | 37 | DAC dac = DAC_A, // channel A |
MikamiUitOpen | 0:6e0ed5adfe47 | 38 | PinName mosi = SPI_MOSI, // D11 |
MikamiUitOpen | 0:6e0ed5adfe47 | 39 | PinName sclk = SPI_SCK, // D13 |
MikamiUitOpen | 0:6e0ed5adfe47 | 40 | PinName cs = SPI_CS, // D10 |
MikamiUitOpen | 16:0001d3e93bee | 41 | PinName ldac = SPI_MISO); // D12 |
MikamiUitOpen | 0:6e0ed5adfe47 | 42 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 43 | // -1.0f <= value <= 1.0f |
MikamiUitOpen | 0:6e0ed5adfe47 | 44 | void Write(float value); |
MikamiUitOpen | 0:6e0ed5adfe47 | 45 | // 0 <= value <= 4095 |
MikamiUitOpen | 0:6e0ed5adfe47 | 46 | void Write(uint16_t value); |
MikamiUitOpen | 2:2a3b4ed3eb58 | 47 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 48 | // generate LDAC negative-going pulse |
MikamiUitOpen | 0:6e0ed5adfe47 | 49 | void Ldac(); |
MikamiUitOpen | 0:6e0ed5adfe47 | 50 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 51 | // Check busy |
MikamiUitOpen | 0:6e0ed5adfe47 | 52 | bool IsBusy() |
MikamiUitOpen | 0:6e0ed5adfe47 | 53 | { return (mySpi_->SR & SPI_FLAG_BSY) == SPI_FLAG_BSY; } |
MikamiUitOpen | 8:f933fcd30408 | 54 | |
MikamiUitOpen | 8:f933fcd30408 | 55 | // Set clock for switched-capacitor filter |
MikamiUitOpen | 14:6c60601c1834 | 56 | void ScfClockTim3(uint32_t clock, PinName pin = D9); |
MikamiUitOpen | 8:f933fcd30408 | 57 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 58 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 59 | private: |
MikamiUitOpen | 0:6e0ed5adfe47 | 60 | uint16_t wcr_; // write command register |
MikamiUitOpen | 0:6e0ed5adfe47 | 61 | SPI spi_; // SPI object of mbed |
MikamiUitOpen | 2:2a3b4ed3eb58 | 62 | Tim4_ss* ss_; |
MikamiUitOpen | 0:6e0ed5adfe47 | 63 | DigitalOut ld_; // for LDAC |
MikamiUitOpen | 0:6e0ed5adfe47 | 64 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 65 | // Pointer of I2C |
MikamiUitOpen | 0:6e0ed5adfe47 | 66 | SPI_TypeDef* mySpi_; |
MikamiUitOpen | 0:6e0ed5adfe47 | 67 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 68 | // for inhibition of copy constructor |
MikamiUitOpen | 0:6e0ed5adfe47 | 69 | DAC_MCP4922(const DAC_MCP4922&); |
MikamiUitOpen | 0:6e0ed5adfe47 | 70 | // for inhibition of substitute operator |
MikamiUitOpen | 2:2a3b4ed3eb58 | 71 | DAC_MCP4922& operator=(const DAC_MCP4922&); |
MikamiUitOpen | 2:2a3b4ed3eb58 | 72 | |
MikamiUitOpen | 0:6e0ed5adfe47 | 73 | // for internal use |
MikamiUitOpen | 0:6e0ed5adfe47 | 74 | void WriteDac(uint16_t value); |
MikamiUitOpen | 0:6e0ed5adfe47 | 75 | }; |
MikamiUitOpen | 0:6e0ed5adfe47 | 76 | } |
MikamiUitOpen | 0:6e0ed5adfe47 | 77 | #endif // DAC_MCP4922_HPP |