Fork of mbed for KL05Z based smart sensor which has no crystal on the board, so MCG FEI mode is required.

Dependents:   smart-sensor-KL05Z-debug

Fork of mbed-src by Ermanno Brusadin

Committer:
r14793
Date:
Mon Jan 29 15:38:37 2018 +0000
Revision:
1:da408b460382
Parent:
0:0a673c671a56
changed KL05 MCG mode to FEI for smart sensor boards (no crystal)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ebrus 0:0a673c671a56 1 /* mbed Microcontroller Library
ebrus 0:0a673c671a56 2 * Copyright (c) 2006-2013 ARM Limited
ebrus 0:0a673c671a56 3 *
ebrus 0:0a673c671a56 4 * Licensed under the Apache License, Version 2.0 (the "License");
ebrus 0:0a673c671a56 5 * you may not use this file except in compliance with the License.
ebrus 0:0a673c671a56 6 * You may obtain a copy of the License at
ebrus 0:0a673c671a56 7 *
ebrus 0:0a673c671a56 8 * http://www.apache.org/licenses/LICENSE-2.0
ebrus 0:0a673c671a56 9 *
ebrus 0:0a673c671a56 10 * Unless required by applicable law or agreed to in writing, software
ebrus 0:0a673c671a56 11 * distributed under the License is distributed on an "AS IS" BASIS,
ebrus 0:0a673c671a56 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
ebrus 0:0a673c671a56 13 * See the License for the specific language governing permissions and
ebrus 0:0a673c671a56 14 * limitations under the License.
ebrus 0:0a673c671a56 15 */
ebrus 0:0a673c671a56 16 #ifndef MBED_BUSINOUT_H
ebrus 0:0a673c671a56 17 #define MBED_BUSINOUT_H
ebrus 0:0a673c671a56 18
ebrus 0:0a673c671a56 19 #include "DigitalInOut.h"
ebrus 0:0a673c671a56 20
ebrus 0:0a673c671a56 21 namespace mbed {
ebrus 0:0a673c671a56 22
ebrus 0:0a673c671a56 23 /** A digital input output bus, used for setting the state of a collection of pins
ebrus 0:0a673c671a56 24 */
ebrus 0:0a673c671a56 25 class BusInOut {
ebrus 0:0a673c671a56 26
ebrus 0:0a673c671a56 27 public:
ebrus 0:0a673c671a56 28
ebrus 0:0a673c671a56 29 /** Create an BusInOut, connected to the specified pins
ebrus 0:0a673c671a56 30 *
ebrus 0:0a673c671a56 31 * @param p<n> DigitalInOut pin to connect to bus bit p<n> (p5-p30, NC)
ebrus 0:0a673c671a56 32 *
ebrus 0:0a673c671a56 33 * @note
ebrus 0:0a673c671a56 34 * It is only required to specify as many pin variables as is required
ebrus 0:0a673c671a56 35 * for the bus; the rest will default to NC (not connected)
ebrus 0:0a673c671a56 36 */
ebrus 0:0a673c671a56 37 BusInOut(PinName p0, PinName p1 = NC, PinName p2 = NC, PinName p3 = NC,
ebrus 0:0a673c671a56 38 PinName p4 = NC, PinName p5 = NC, PinName p6 = NC, PinName p7 = NC,
ebrus 0:0a673c671a56 39 PinName p8 = NC, PinName p9 = NC, PinName p10 = NC, PinName p11 = NC,
ebrus 0:0a673c671a56 40 PinName p12 = NC, PinName p13 = NC, PinName p14 = NC, PinName p15 = NC);
ebrus 0:0a673c671a56 41
ebrus 0:0a673c671a56 42 BusInOut(PinName pins[16]);
ebrus 0:0a673c671a56 43
ebrus 0:0a673c671a56 44 virtual ~BusInOut();
ebrus 0:0a673c671a56 45
ebrus 0:0a673c671a56 46 /* Group: Access Methods */
ebrus 0:0a673c671a56 47
ebrus 0:0a673c671a56 48 /** Write the value to the output bus
ebrus 0:0a673c671a56 49 *
ebrus 0:0a673c671a56 50 * @param value An integer specifying a bit to write for every corresponding DigitalInOut pin
ebrus 0:0a673c671a56 51 */
ebrus 0:0a673c671a56 52 void write(int value);
ebrus 0:0a673c671a56 53
ebrus 0:0a673c671a56 54
ebrus 0:0a673c671a56 55 /** Read the value currently output on the bus
ebrus 0:0a673c671a56 56 *
ebrus 0:0a673c671a56 57 * @returns
ebrus 0:0a673c671a56 58 * An integer with each bit corresponding to associated DigitalInOut pin setting
ebrus 0:0a673c671a56 59 */
ebrus 0:0a673c671a56 60 int read();
ebrus 0:0a673c671a56 61
ebrus 0:0a673c671a56 62 /** Set as an output
ebrus 0:0a673c671a56 63 */
ebrus 0:0a673c671a56 64 void output();
ebrus 0:0a673c671a56 65
ebrus 0:0a673c671a56 66 /** Set as an input
ebrus 0:0a673c671a56 67 */
ebrus 0:0a673c671a56 68 void input();
ebrus 0:0a673c671a56 69
ebrus 0:0a673c671a56 70 /** Set the input pin mode
ebrus 0:0a673c671a56 71 *
ebrus 0:0a673c671a56 72 * @param mode PullUp, PullDown, PullNone
ebrus 0:0a673c671a56 73 */
ebrus 0:0a673c671a56 74 void mode(PinMode pull);
ebrus 0:0a673c671a56 75
ebrus 0:0a673c671a56 76 #ifdef MBED_OPERATORS
ebrus 0:0a673c671a56 77 /** A shorthand for write()
ebrus 0:0a673c671a56 78 */
ebrus 0:0a673c671a56 79 BusInOut& operator= (int v);
ebrus 0:0a673c671a56 80 BusInOut& operator= (BusInOut& rhs);
ebrus 0:0a673c671a56 81
ebrus 0:0a673c671a56 82 /** A shorthand for read()
ebrus 0:0a673c671a56 83 */
ebrus 0:0a673c671a56 84 operator int();
ebrus 0:0a673c671a56 85 #endif
ebrus 0:0a673c671a56 86
ebrus 0:0a673c671a56 87 protected:
ebrus 0:0a673c671a56 88 DigitalInOut* _pin[16];
ebrus 0:0a673c671a56 89
ebrus 0:0a673c671a56 90 /* disallow copy constructor and assignment operators */
ebrus 0:0a673c671a56 91 private:
ebrus 0:0a673c671a56 92 BusInOut(const BusInOut&);
ebrus 0:0a673c671a56 93 BusInOut & operator = (const BusInOut&);
ebrus 0:0a673c671a56 94 };
ebrus 0:0a673c671a56 95
ebrus 0:0a673c671a56 96 } // namespace mbed
ebrus 0:0a673c671a56 97
ebrus 0:0a673c671a56 98 #endif