A library for Freescale MCU which contain TSI peripheral, just for Kinetis L version. Because they use "lighter" version of TSI peripheral.
Fork of tsi_sensor by
tsi_sensor.cpp@1:8a2098a10330, 2014-02-22 (annotated)
- Committer:
- Kojto
- Date:
- Sat Feb 22 11:25:35 2014 +0000
- Revision:
- 1:8a2098a10330
- Parent:
- 0:9331e373c138
- Child:
- 3:20ffa9b18488
Header correction
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Kojto | 0:9331e373c138 | 1 | /* Freescale Semiconductor Inc. |
Kojto | 0:9331e373c138 | 2 | * mbed Microcontroller Library |
Kojto | 0:9331e373c138 | 3 | * (c) Copyright 2014 ARM Limited. |
Kojto | 0:9331e373c138 | 4 | * |
Kojto | 0:9331e373c138 | 5 | * Permission is hereby granted, free of charge, to any person obtaining a copy of this software |
Kojto | 0:9331e373c138 | 6 | * and associated documentation files (the "Software"), to deal in the Software without |
Kojto | 0:9331e373c138 | 7 | * restriction, including without limitation the rights to use, copy, modify, merge, publish, |
Kojto | 0:9331e373c138 | 8 | * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the |
Kojto | 0:9331e373c138 | 9 | * Software is furnished to do so, subject to the following conditions: |
Kojto | 0:9331e373c138 | 10 | * |
Kojto | 0:9331e373c138 | 11 | * The above copyright notice and this permission notice shall be included in all copies or |
Kojto | 0:9331e373c138 | 12 | * substantial portions of the Software. |
Kojto | 0:9331e373c138 | 13 | * |
Kojto | 0:9331e373c138 | 14 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING |
Kojto | 0:9331e373c138 | 15 | * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
Kojto | 0:9331e373c138 | 16 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
Kojto | 0:9331e373c138 | 17 | * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
Kojto | 0:9331e373c138 | 18 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
Kojto | 0:9331e373c138 | 19 | */ |
Kojto | 0:9331e373c138 | 20 | |
Kojto | 0:9331e373c138 | 21 | #include "mbed.h" |
Kojto | 1:8a2098a10330 | 22 | #include "tsi_sensor.h" |
Kojto | 0:9331e373c138 | 23 | |
Kojto | 0:9331e373c138 | 24 | void tsi_irq(void); |
Kojto | 0:9331e373c138 | 25 | TSIAnalogSlider *TSIAnalogSlider::_instance; |
Kojto | 0:9331e373c138 | 26 | |
Kojto | 0:9331e373c138 | 27 | TSIAnalogSlider::TSIAnalogSlider(TSIElectrode& elec0, TSIElectrode& elec1, |
Kojto | 0:9331e373c138 | 28 | uint32_t range) |
Kojto | 0:9331e373c138 | 29 | : _elec0(elec0), _elec1(elec1), _range(range) { |
Kojto | 0:9331e373c138 | 30 | _instance = this; |
Kojto | 0:9331e373c138 | 31 | _current_elec = &elec0; |
Kojto | 0:9331e373c138 | 32 | SIM->SCGC5 |= SIM_SCGC5_TSI_MASK; |
Kojto | 0:9331e373c138 | 33 | |
Kojto | 0:9331e373c138 | 34 | TSI0->GENCS |= (TSI_GENCS_ESOR_MASK | TSI_GENCS_MODE(0) | TSI_GENCS_REFCHRG(4) |
Kojto | 0:9331e373c138 | 35 | | TSI_GENCS_DVOLT(0) | TSI_GENCS_EXTCHRG(7) | TSI_GENCS_PS(4) |
Kojto | 0:9331e373c138 | 36 | | TSI_GENCS_NSCN(11) | TSI_GENCS_TSIIEN_MASK | TSI_GENCS_STPE_MASK); |
Kojto | 0:9331e373c138 | 37 | TSI0->GENCS |= TSI_GENCS_TSIEN_MASK; |
Kojto | 0:9331e373c138 | 38 | |
Kojto | 0:9331e373c138 | 39 | NVIC_SetVector(TSI0_IRQn, (uint32_t)&tsi_irq); |
Kojto | 0:9331e373c138 | 40 | NVIC_EnableIRQ(TSI0_IRQn); |
Kojto | 0:9331e373c138 | 41 | |
Kojto | 0:9331e373c138 | 42 | selfCalibration(); |
Kojto | 0:9331e373c138 | 43 | } |
Kojto | 0:9331e373c138 | 44 | |
Kojto | 0:9331e373c138 | 45 | static void initBaseline(TSIElectrode& elec) |
Kojto | 0:9331e373c138 | 46 | { |
Kojto | 0:9331e373c138 | 47 | uint32_t channel0 = elec.getChannel(); |
Kojto | 0:9331e373c138 | 48 | TSI0->DATA = ((channel0 << TSI_DATA_TSICH_SHIFT) ); |
Kojto | 0:9331e373c138 | 49 | TSI0->DATA |= TSI_DATA_SWTS_MASK; |
Kojto | 0:9331e373c138 | 50 | while(!(TSI0->GENCS & TSI_GENCS_EOSF_MASK)); |
Kojto | 0:9331e373c138 | 51 | TSI0->GENCS |= TSI_GENCS_EOSF_MASK; |
Kojto | 0:9331e373c138 | 52 | elec.setBaseline(TSI0->DATA & TSI_DATA_TSICNT_MASK); |
Kojto | 0:9331e373c138 | 53 | } |
Kojto | 0:9331e373c138 | 54 | |
Kojto | 0:9331e373c138 | 55 | void TSIAnalogSlider::selfCalibration(void) |
Kojto | 0:9331e373c138 | 56 | { |
Kojto | 0:9331e373c138 | 57 | TSI0->GENCS |= TSI_GENCS_EOSF_MASK; // Clear End of Scan Flag |
Kojto | 0:9331e373c138 | 58 | TSI0->GENCS &= ~TSI_GENCS_TSIEN_MASK; // Disable TSI module |
Kojto | 0:9331e373c138 | 59 | |
Kojto | 0:9331e373c138 | 60 | uint32_t trigger_backup; |
Kojto | 0:9331e373c138 | 61 | if(TSI0->GENCS & TSI_GENCS_STM_MASK) { // Back-up TSI Trigger mode from Application |
Kojto | 0:9331e373c138 | 62 | trigger_backup = 1; |
Kojto | 0:9331e373c138 | 63 | } else { |
Kojto | 0:9331e373c138 | 64 | trigger_backup = 0; |
Kojto | 0:9331e373c138 | 65 | } |
Kojto | 0:9331e373c138 | 66 | |
Kojto | 0:9331e373c138 | 67 | TSI0->GENCS &= ~TSI_GENCS_STM_MASK; // Use SW trigger |
Kojto | 0:9331e373c138 | 68 | TSI0->GENCS &= ~TSI_GENCS_TSIIEN_MASK; // Enable TSI interrupts |
Kojto | 0:9331e373c138 | 69 | TSI0->GENCS |= TSI_GENCS_TSIEN_MASK; // Enable TSI module |
Kojto | 0:9331e373c138 | 70 | |
Kojto | 0:9331e373c138 | 71 | initBaseline(_elec0); |
Kojto | 0:9331e373c138 | 72 | initBaseline(_elec1); |
Kojto | 0:9331e373c138 | 73 | |
Kojto | 0:9331e373c138 | 74 | TSI0->DATA = ((_elec0.getChannel() << TSI_DATA_TSICH_SHIFT)); |
Kojto | 0:9331e373c138 | 75 | |
Kojto | 0:9331e373c138 | 76 | TSI0->GENCS &= ~TSI_GENCS_TSIEN_MASK; // Disable TSI module |
Kojto | 0:9331e373c138 | 77 | TSI0->GENCS |= TSI_GENCS_TSIIEN_MASK; // Enale TSI interrupt |
Kojto | 0:9331e373c138 | 78 | if (trigger_backup) { // Restore trigger mode |
Kojto | 0:9331e373c138 | 79 | TSI0->GENCS |= TSI_GENCS_STM_MASK; |
Kojto | 0:9331e373c138 | 80 | } else { |
Kojto | 0:9331e373c138 | 81 | TSI0->GENCS &= ~TSI_GENCS_STM_MASK; |
Kojto | 0:9331e373c138 | 82 | } |
Kojto | 0:9331e373c138 | 83 | |
Kojto | 0:9331e373c138 | 84 | TSI0->GENCS |= TSI_GENCS_TSIEN_MASK; // Enable TSI module |
Kojto | 0:9331e373c138 | 85 | TSI0->DATA |= TSI_DATA_SWTS_MASK; |
Kojto | 0:9331e373c138 | 86 | } |
Kojto | 0:9331e373c138 | 87 | |
Kojto | 0:9331e373c138 | 88 | |
Kojto | 0:9331e373c138 | 89 | void TSIAnalogSlider::sliderRead(void ) { |
Kojto | 0:9331e373c138 | 90 | if (_scan_in_progress) { |
Kojto | 0:9331e373c138 | 91 | _scan_in_progress = 0; |
Kojto | 0:9331e373c138 | 92 | uint32_t delta0 = _elec0.getDelta(); |
Kojto | 0:9331e373c138 | 93 | uint32_t delta1 = _elec1.getDelta(); |
Kojto | 0:9331e373c138 | 94 | |
Kojto | 0:9331e373c138 | 95 | if ((delta0 > _elec0.getThreshold()) || (delta1 > _elec1.getThreshold())) { |
Kojto | 0:9331e373c138 | 96 | uint32_t perc_pos0 = (delta0 * 100) / (delta0 + delta1); |
Kojto | 0:9331e373c138 | 97 | uint32_t perc_pos1 = (delta1 * 100) / (delta0 + delta1); |
Kojto | 0:9331e373c138 | 98 | setSliderPercPosition(0, perc_pos0); |
Kojto | 0:9331e373c138 | 99 | setSliderPercPosition(1, perc_pos1); |
Kojto | 0:9331e373c138 | 100 | uint32_t dist_pos0 = (perc_pos0 * _range) / 100; |
Kojto | 0:9331e373c138 | 101 | uint32_t dist_pos1 = (perc_pos0 * _range) / 100; |
Kojto | 0:9331e373c138 | 102 | setSliderDisPosition(0, dist_pos0); |
Kojto | 0:9331e373c138 | 103 | setSliderDisPosition(1, dist_pos1); |
Kojto | 0:9331e373c138 | 104 | |
Kojto | 0:9331e373c138 | 105 | setAbsolutePosition(((100 - perc_pos0) + perc_pos1) / 2); |
Kojto | 0:9331e373c138 | 106 | setAbsoluteDistance(((_range - dist_pos0) + dist_pos1) / 2); |
Kojto | 0:9331e373c138 | 107 | } else { |
Kojto | 0:9331e373c138 | 108 | setSliderPercPosition(0, 0); |
Kojto | 0:9331e373c138 | 109 | setSliderPercPosition(1, 0); |
Kojto | 0:9331e373c138 | 110 | setSliderDisPosition(0, 0); |
Kojto | 0:9331e373c138 | 111 | setSliderDisPosition(1, 0); |
Kojto | 0:9331e373c138 | 112 | setAbsolutePosition(0); |
Kojto | 0:9331e373c138 | 113 | setAbsoluteDistance(0); |
Kojto | 0:9331e373c138 | 114 | } |
Kojto | 0:9331e373c138 | 115 | } |
Kojto | 0:9331e373c138 | 116 | } |
Kojto | 0:9331e373c138 | 117 | |
Kojto | 0:9331e373c138 | 118 | float TSIAnalogSlider::readPercentage() { |
Kojto | 0:9331e373c138 | 119 | sliderRead(); |
Kojto | 0:9331e373c138 | 120 | return (float)getAbsolutePosition() / 100.0; |
Kojto | 0:9331e373c138 | 121 | } |
Kojto | 0:9331e373c138 | 122 | |
Kojto | 0:9331e373c138 | 123 | uint32_t TSIAnalogSlider::readDistance() { |
Kojto | 0:9331e373c138 | 124 | sliderRead(); |
Kojto | 0:9331e373c138 | 125 | return getAbsoluteDistance(); |
Kojto | 0:9331e373c138 | 126 | } |
Kojto | 0:9331e373c138 | 127 | |
Kojto | 0:9331e373c138 | 128 | static void changeElectrode(TSIAnalogSlider *analog_slider) |
Kojto | 0:9331e373c138 | 129 | { |
Kojto | 0:9331e373c138 | 130 | TSIElectrode* elec = analog_slider->getCurrentElectrode(); |
Kojto | 0:9331e373c138 | 131 | uint32_t signal = (TSI0->DATA & TSI_DATA_TSICNT_MASK); |
Kojto | 0:9331e373c138 | 132 | elec->setSignal(signal); |
Kojto | 0:9331e373c138 | 133 | |
Kojto | 0:9331e373c138 | 134 | TSIElectrode *next_elec = analog_slider->getNextElectrode(elec); |
Kojto | 0:9331e373c138 | 135 | |
Kojto | 0:9331e373c138 | 136 | analog_slider->setCurrentElectrode(next_elec); |
Kojto | 0:9331e373c138 | 137 | TSI0->DATA = ((next_elec->getChannel() << TSI_DATA_TSICH_SHIFT) ); |
Kojto | 0:9331e373c138 | 138 | TSI0->DATA |= TSI_DATA_SWTS_MASK; |
Kojto | 0:9331e373c138 | 139 | } |
Kojto | 0:9331e373c138 | 140 | |
Kojto | 0:9331e373c138 | 141 | |
Kojto | 0:9331e373c138 | 142 | void tsi_irq(void) |
Kojto | 0:9331e373c138 | 143 | { |
Kojto | 0:9331e373c138 | 144 | TSIAnalogSlider *analog_slider = TSIAnalogSlider::getInstance(); |
Kojto | 0:9331e373c138 | 145 | analog_slider->setScan(1); |
Kojto | 0:9331e373c138 | 146 | TSI0->GENCS |= TSI_GENCS_EOSF_MASK; // Clear End of Scan Flag |
Kojto | 0:9331e373c138 | 147 | changeElectrode(analog_slider); |
Kojto | 0:9331e373c138 | 148 | } |