Nico Bollen / LIN

Dependents:   MBED_LIN_RGB_Master_Example

Committer:
bollenn
Date:
Tue May 06 20:17:35 2014 +0000
Revision:
1:58b5d1e8fae3
Parent:
0:c91a9ebab739
Child:
2:6d4c7f841a5d
Updating documentation

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bollenn 1:58b5d1e8fae3 1 /*
bollenn 1:58b5d1e8fae3 2 * A master device LIN communication library for mbed
bollenn 0:c91a9ebab739 3 *
bollenn 0:c91a9ebab739 4 * Copyright (C) 2014 TASS Belgium NV
bollenn 0:c91a9ebab739 5 *
bollenn 0:c91a9ebab739 6 * Released under GPL v2
bollenn 0:c91a9ebab739 7 *
bollenn 0:c91a9ebab739 8 * Other licensing models might apply at the sole discretion of the copyright holders.
bollenn 0:c91a9ebab739 9 *
bollenn 0:c91a9ebab739 10 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
bollenn 0:c91a9ebab739 11 * and associated documentation files (the "Software"), to deal in the Software without restriction,
bollenn 0:c91a9ebab739 12 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
bollenn 0:c91a9ebab739 13 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
bollenn 0:c91a9ebab739 14 * furnished to do so, subject to the following conditions:
bollenn 0:c91a9ebab739 15 *
bollenn 0:c91a9ebab739 16 * The above copyright notice and this permission notice shall be included in all copies or
bollenn 0:c91a9ebab739 17 * substantial portions of the Software.
bollenn 0:c91a9ebab739 18 *
bollenn 0:c91a9ebab739 19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
bollenn 0:c91a9ebab739 20 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
bollenn 0:c91a9ebab739 21 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
bollenn 0:c91a9ebab739 22 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
bollenn 0:c91a9ebab739 23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
bollenn 0:c91a9ebab739 24 */
bollenn 0:c91a9ebab739 25
bollenn 0:c91a9ebab739 26 #include "mbed.h"
bollenn 0:c91a9ebab739 27
bollenn 1:58b5d1e8fae3 28 #ifndef MBED_LIN_MASTER_H
bollenn 1:58b5d1e8fae3 29 #define MBED_LIN_MASTER_H
bollenn 1:58b5d1e8fae3 30
bollenn 1:58b5d1e8fae3 31 #include "mbed.h"
bollenn 1:58b5d1e8fae3 32
bollenn 1:58b5d1e8fae3 33 /** A master device LIN communication library for mbed
bollenn 1:58b5d1e8fae3 34 *
bollenn 1:58b5d1e8fae3 35 * @code
bollenn 1:58b5d1e8fae3 36 * #include "mbed.h"
bollenn 1:58b5d1e8fae3 37 * #include "LinMaster.h"
bollenn 1:58b5d1e8fae3 38 *
bollenn 1:58b5d1e8fae3 39 * LinMaster lin(p30);
bollenn 1:58b5d1e8fae3 40 *
bollenn 1:58b5d1e8fae3 41 * int main() {
bollenn 1:58b5d1e8fae3 42 * (void)lin.init();
bollenn 1:58b5d1e8fae3 43 * (void)lin.sendframe(M2S, 0x3C, (uint8_t*)u8Data, 8);
bollenn 1:58b5d1e8fae3 44 * }
bollenn 1:58b5d1e8fae3 45 * @endcode
bollenn 1:58b5d1e8fae3 46 */
bollenn 0:c91a9ebab739 47 class LinMaster
bollenn 0:c91a9ebab739 48 {
bollenn 0:c91a9ebab739 49 public:
bollenn 0:c91a9ebab739 50 /** LIN master constructor
bollenn 0:c91a9ebab739 51 *
bollenn 0:c91a9ebab739 52 * @param Pin The pinname to be used for LIN communication
bollenn 0:c91a9ebab739 53 */
bollenn 0:c91a9ebab739 54 LinMaster(PinName Pin);
bollenn 0:c91a9ebab739 55
bollenn 0:c91a9ebab739 56 /** LIN master destructor */
bollenn 0:c91a9ebab739 57 ~LinMaster();
bollenn 0:c91a9ebab739 58
bollenn 0:c91a9ebab739 59 /** Initialise the LIN module
bollenn 0:c91a9ebab739 60 * - configure IO
bollenn 0:c91a9ebab739 61 * - configure Timer
bollenn 0:c91a9ebab739 62 *
bollenn 0:c91a9ebab739 63 * @return
bollenn 0:c91a9ebab739 64 * true on succes,
bollenn 0:c91a9ebab739 65 * false on fail
bollenn 0:c91a9ebab739 66 */
bollenn 0:c91a9ebab739 67 bool Init(void);
bollenn 0:c91a9ebab739 68
bollenn 0:c91a9ebab739 69 /** Set the LIN baudrate
bollenn 0:c91a9ebab739 70 *
bollenn 0:c91a9ebab739 71 * @param uBaud baudrate value in kbps (1..20000)
bollenn 0:c91a9ebab739 72 * @return
bollenn 0:c91a9ebab739 73 * true on succes,
bollenn 0:c91a9ebab739 74 * false on fail
bollenn 0:c91a9ebab739 75 */
bollenn 0:c91a9ebab739 76 bool Baudrate(uint16_t uBaud);
bollenn 0:c91a9ebab739 77
bollenn 0:c91a9ebab739 78 /** Get the LIN baudrate
bollenn 0:c91a9ebab739 79 *
bollenn 0:c91a9ebab739 80 * @return
bollenn 0:c91a9ebab739 81 * The current configured LIN baudrate
bollenn 0:c91a9ebab739 82 */
bollenn 0:c91a9ebab739 83 uint16_t Baudrate(void);
bollenn 0:c91a9ebab739 84
bollenn 1:58b5d1e8fae3 85 /** Send frame direction */
bollenn 1:58b5d1e8fae3 86 enum FrameDir {
bollenn 1:58b5d1e8fae3 87 M2S, /**< Master to Slave */
bollenn 1:58b5d1e8fae3 88 S2M /**< Slave to Master */
bollenn 1:58b5d1e8fae3 89 };
bollenn 0:c91a9ebab739 90
bollenn 1:58b5d1e8fae3 91 /** Send a frame on the LIN bus
bollenn 1:58b5d1e8fae3 92 *
bollenn 1:58b5d1e8fae3 93 * @param Dir direction of the frame
bollenn 1:58b5d1e8fae3 94 * @param u8ID LIN Frame ID
bollenn 1:58b5d1e8fae3 95 * @param ptrData pointer to the data to be transmitted/received
bollenn 1:58b5d1e8fae3 96 * @param u8Len lenght of the data to be transmitted/received
bollenn 1:58b5d1e8fae3 97 * @return
bollenn 1:58b5d1e8fae3 98 * true on succes,
bollenn 1:58b5d1e8fae3 99 * false on fail
bollenn 1:58b5d1e8fae3 100 */
bollenn 1:58b5d1e8fae3 101 bool SendFrame(FrameDir Dir, uint8_t u8ID, uint8_t* ptrData, uint8_t u8Len);
bollenn 0:c91a9ebab739 102
bollenn 0:c91a9ebab739 103 private:
bollenn 0:c91a9ebab739 104 uint16_t u16BitPeriod;
bollenn 0:c91a9ebab739 105 uint8_t u8BreakLen;
bollenn 0:c91a9ebab739 106 uint8_t u8DelimLen;
bollenn 0:c91a9ebab739 107 PinName MyPin;
bollenn 0:c91a9ebab739 108 };
bollenn 1:58b5d1e8fae3 109
bollenn 1:58b5d1e8fae3 110 #endif /* MBED_LIN_MASTER_H */