Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: LoRaWAN-lmic-app_tjm
Fork of LMiC by
oslmic.h@0:62d1edcc13d1, 2015-01-22 (annotated)
- Committer:
- mluis
- Date:
- Thu Jan 22 12:50:49 2015 +0000
- Revision:
- 0:62d1edcc13d1
- Child:
- 1:d3b7bde3995c
Porting of IBM LoRa MAC in C (LMiC) to the mbed platform.
Who changed what in which revision?
| User | Revision | Line number | New contents of line | 
|---|---|---|---|
| mluis | 0:62d1edcc13d1 | 1 | /******************************************************************************* | 
| mluis | 0:62d1edcc13d1 | 2 | * Copyright (c) 2014 IBM Corporation. | 
| mluis | 0:62d1edcc13d1 | 3 | * All rights reserved. This program and the accompanying materials | 
| mluis | 0:62d1edcc13d1 | 4 | * are made available under the terms of the Eclipse Public License v1.0 | 
| mluis | 0:62d1edcc13d1 | 5 | * which accompanies this distribution, and is available at | 
| mluis | 0:62d1edcc13d1 | 6 | * http://www.eclipse.org/legal/epl-v10.html | 
| mluis | 0:62d1edcc13d1 | 7 | * | 
| mluis | 0:62d1edcc13d1 | 8 | * Contributors: | 
| mluis | 0:62d1edcc13d1 | 9 | * IBM Zurich Research Lab - initial API, implementation and documentation | 
| mluis | 0:62d1edcc13d1 | 10 | *******************************************************************************/ | 
| mluis | 0:62d1edcc13d1 | 11 | |
| mluis | 0:62d1edcc13d1 | 12 | #ifndef _oslmic_h_ | 
| mluis | 0:62d1edcc13d1 | 13 | #define _oslmic_h_ | 
| mluis | 0:62d1edcc13d1 | 14 | |
| mluis | 0:62d1edcc13d1 | 15 | // Dependencies required for the LoRa MAC in C to run. | 
| mluis | 0:62d1edcc13d1 | 16 | // These settings can be adapted to the underlying system. | 
| mluis | 0:62d1edcc13d1 | 17 | // You should not, however, change the lmic.[hc] | 
| mluis | 0:62d1edcc13d1 | 18 | |
| mluis | 0:62d1edcc13d1 | 19 | |
| mluis | 0:62d1edcc13d1 | 20 | |
| mluis | 0:62d1edcc13d1 | 21 | //================================================================================ | 
| mluis | 0:62d1edcc13d1 | 22 | //================================================================================ | 
| mluis | 0:62d1edcc13d1 | 23 | // Target platform as C library | 
| mluis | 0:62d1edcc13d1 | 24 | typedef unsigned char bit_t; | 
| mluis | 0:62d1edcc13d1 | 25 | typedef unsigned char u1_t; | 
| mluis | 0:62d1edcc13d1 | 26 | typedef signed char s1_t; | 
| mluis | 0:62d1edcc13d1 | 27 | typedef unsigned short u2_t; | 
| mluis | 0:62d1edcc13d1 | 28 | typedef short s2_t; | 
| mluis | 0:62d1edcc13d1 | 29 | typedef unsigned int u4_t; | 
| mluis | 0:62d1edcc13d1 | 30 | typedef int s4_t; | 
| mluis | 0:62d1edcc13d1 | 31 | typedef unsigned long long u8_t; | 
| mluis | 0:62d1edcc13d1 | 32 | typedef long long s8_t; | 
| mluis | 0:62d1edcc13d1 | 33 | typedef unsigned int uint; | 
| mluis | 0:62d1edcc13d1 | 34 | typedef const char* str_t; | 
| mluis | 0:62d1edcc13d1 | 35 | |
| mluis | 0:62d1edcc13d1 | 36 | #define CFG_noassert 1 | 
| mluis | 0:62d1edcc13d1 | 37 | #include <string.h> | 
| mluis | 0:62d1edcc13d1 | 38 | #include "hal.h" | 
| mluis | 0:62d1edcc13d1 | 39 | #define EV(a,b,c) /**/ | 
| mluis | 0:62d1edcc13d1 | 40 | #define DO_DEVDB(meth,...) /**/ | 
| mluis | 0:62d1edcc13d1 | 41 | #if !CFG_noassert | 
| mluis | 0:62d1edcc13d1 | 42 | #define ASSERT(cond) if(!(cond)) hal_failed() | 
| mluis | 0:62d1edcc13d1 | 43 | #else | 
| mluis | 0:62d1edcc13d1 | 44 | #define ASSERT(cond) /**/ | 
| mluis | 0:62d1edcc13d1 | 45 | #endif | 
| mluis | 0:62d1edcc13d1 | 46 | |
| mluis | 0:62d1edcc13d1 | 47 | #define os_clearMem(a,b) memset(a,0,b) | 
| mluis | 0:62d1edcc13d1 | 48 | #define os_copyMem(a,b,c) memcpy(a,b,c) | 
| mluis | 0:62d1edcc13d1 | 49 | |
| mluis | 0:62d1edcc13d1 | 50 | typedef struct osjob_t osjob_t; | 
| mluis | 0:62d1edcc13d1 | 51 | typedef struct band_t band_t; | 
| mluis | 0:62d1edcc13d1 | 52 | typedef struct rxqu_t rxqu_t; | 
| mluis | 0:62d1edcc13d1 | 53 | typedef struct chnldef_t chnldef_t; | 
| mluis | 0:62d1edcc13d1 | 54 | typedef struct rxsched_t rxsched_t; | 
| mluis | 0:62d1edcc13d1 | 55 | typedef struct bcninfo_t bcninfo_t; | 
| mluis | 0:62d1edcc13d1 | 56 | typedef const u1_t* xref2cu1_t; | 
| mluis | 0:62d1edcc13d1 | 57 | typedef u1_t* xref2u1_t; | 
| mluis | 0:62d1edcc13d1 | 58 | #define TYPEDEF_xref2rps_t typedef rps_t* xref2rps_t | 
| mluis | 0:62d1edcc13d1 | 59 | #define TYPEDEF_xref2rxqu_t typedef rxqu_t* xref2rxqu_t | 
| mluis | 0:62d1edcc13d1 | 60 | #define TYPEDEF_xref2rxsched_t typedef rxsched_t* xref2rxsched_t | 
| mluis | 0:62d1edcc13d1 | 61 | #define TYPEDEF_xref2chnldef_t typedef chnldef_t* xref2chnldef_t | 
| mluis | 0:62d1edcc13d1 | 62 | #define TYPEDEF_xref2band_t typedef band_t* xref2band_t | 
| mluis | 0:62d1edcc13d1 | 63 | #define TYPEDEF_xref2osjob_t typedef osjob_t* xref2osjob_t | 
| mluis | 0:62d1edcc13d1 | 64 | |
| mluis | 0:62d1edcc13d1 | 65 | #define SIZEOFEXPR(x) sizeof(x) | 
| mluis | 0:62d1edcc13d1 | 66 | |
| mluis | 0:62d1edcc13d1 | 67 | #define ON_LMIC_EVENT(ev) onEvent(ev) | 
| mluis | 0:62d1edcc13d1 | 68 | #define DECL_ON_LMIC_EVENT void onEvent(ev_t e) | 
| mluis | 0:62d1edcc13d1 | 69 | |
| mluis | 0:62d1edcc13d1 | 70 | extern u4_t AESAUX[]; | 
| mluis | 0:62d1edcc13d1 | 71 | extern u4_t AESKEY[]; | 
| mluis | 0:62d1edcc13d1 | 72 | #define AESkey ((u1_t*)AESKEY) | 
| mluis | 0:62d1edcc13d1 | 73 | #define AESaux ((u1_t*)AESAUX) | 
| mluis | 0:62d1edcc13d1 | 74 | #define FUNC_ADDR(func) (&(func)) | 
| mluis | 0:62d1edcc13d1 | 75 | |
| mluis | 0:62d1edcc13d1 | 76 | u1_t radio_rand1 (void); | 
| mluis | 0:62d1edcc13d1 | 77 | #define os_getRndU1() radio_rand1() | 
| mluis | 0:62d1edcc13d1 | 78 | |
| mluis | 0:62d1edcc13d1 | 79 | #define DEFINE_LMIC struct lmic_t LMIC | 
| mluis | 0:62d1edcc13d1 | 80 | #define DECLARE_LMIC extern struct lmic_t LMIC | 
| mluis | 0:62d1edcc13d1 | 81 | |
| mluis | 0:62d1edcc13d1 | 82 | void radio_init(void); | 
| mluis | 0:62d1edcc13d1 | 83 | void radio_irq_handler (u1_t dio); | 
| mluis | 0:62d1edcc13d1 | 84 | void os_init (void); | 
| mluis | 0:62d1edcc13d1 | 85 | void os_runloop (void); | 
| mluis | 0:62d1edcc13d1 | 86 | |
| mluis | 0:62d1edcc13d1 | 87 | //================================================================================ | 
| mluis | 0:62d1edcc13d1 | 88 | |
| mluis | 0:62d1edcc13d1 | 89 | |
| mluis | 0:62d1edcc13d1 | 90 | #ifndef RX_RAMPUP | 
| mluis | 0:62d1edcc13d1 | 91 | #define RX_RAMPUP (us2osticks(2000)) | 
| mluis | 0:62d1edcc13d1 | 92 | #endif | 
| mluis | 0:62d1edcc13d1 | 93 | #ifndef TX_RAMPUP | 
| mluis | 0:62d1edcc13d1 | 94 | #define TX_RAMPUP (us2osticks(2000)) | 
| mluis | 0:62d1edcc13d1 | 95 | #endif | 
| mluis | 0:62d1edcc13d1 | 96 | |
| mluis | 0:62d1edcc13d1 | 97 | #ifndef OSTICKS_PER_SEC | 
| mluis | 0:62d1edcc13d1 | 98 | #define OSTICKS_PER_SEC 15625 | 
| mluis | 0:62d1edcc13d1 | 99 | #elif OSTICKS_PER_SEC < 10000 || OSTICKS_PER_SEC > 64516 | 
| mluis | 0:62d1edcc13d1 | 100 | #error Illegal OSTICKS_PER_SEC - must be in range [10000:64516]. One tick must be 15.5us .. 100us long. | 
| mluis | 0:62d1edcc13d1 | 101 | #endif | 
| mluis | 0:62d1edcc13d1 | 102 | |
| mluis | 0:62d1edcc13d1 | 103 | typedef s4_t ostime_t; | 
| mluis | 0:62d1edcc13d1 | 104 | |
| mluis | 0:62d1edcc13d1 | 105 | #if !HAS_ostick_conv | 
| mluis | 0:62d1edcc13d1 | 106 | #define us2osticks(us) ((ostime_t)( ((s8_t)(us) * OSTICKS_PER_SEC) / 1000000)) | 
| mluis | 0:62d1edcc13d1 | 107 | #define ms2osticks(ms) ((ostime_t)( ((s8_t)(ms) * OSTICKS_PER_SEC) / 1000)) | 
| mluis | 0:62d1edcc13d1 | 108 | #define sec2osticks(sec) ((ostime_t)( (s8_t)(sec) * OSTICKS_PER_SEC)) | 
| mluis | 0:62d1edcc13d1 | 109 | #define osticks2ms(os) ((s4_t)(((os)*(s8_t)1000 ) / OSTICKS_PER_SEC)) | 
| mluis | 0:62d1edcc13d1 | 110 | #define osticks2us(os) ((s4_t)(((os)*(s8_t)1000000 ) / OSTICKS_PER_SEC)) | 
| mluis | 0:62d1edcc13d1 | 111 | // Special versions | 
| mluis | 0:62d1edcc13d1 | 112 | #define us2osticksCeil(us) ((ostime_t)( ((s8_t)(us) * OSTICKS_PER_SEC + 999999) / 1000000)) | 
| mluis | 0:62d1edcc13d1 | 113 | #define us2osticksRound(us) ((ostime_t)( ((s8_t)(us) * OSTICKS_PER_SEC + 500000) / 1000000)) | 
| mluis | 0:62d1edcc13d1 | 114 | #define ms2osticksCeil(ms) ((ostime_t)( ((s8_t)(ms) * OSTICKS_PER_SEC + 999) / 1000)) | 
| mluis | 0:62d1edcc13d1 | 115 | #define ms2osticksRound(ms) ((ostime_t)( ((s8_t)(ms) * OSTICKS_PER_SEC + 500) / 1000)) | 
| mluis | 0:62d1edcc13d1 | 116 | #endif | 
| mluis | 0:62d1edcc13d1 | 117 | |
| mluis | 0:62d1edcc13d1 | 118 | |
| mluis | 0:62d1edcc13d1 | 119 | struct osjob_t; // fwd decl. | 
| mluis | 0:62d1edcc13d1 | 120 | typedef void (*osjobcb_t) (struct osjob_t*); | 
| mluis | 0:62d1edcc13d1 | 121 | struct osjob_t { | 
| mluis | 0:62d1edcc13d1 | 122 | struct osjob_t* next; | 
| mluis | 0:62d1edcc13d1 | 123 | ostime_t deadline; | 
| mluis | 0:62d1edcc13d1 | 124 | osjobcb_t func; | 
| mluis | 0:62d1edcc13d1 | 125 | }; | 
| mluis | 0:62d1edcc13d1 | 126 | TYPEDEF_xref2osjob_t; | 
| mluis | 0:62d1edcc13d1 | 127 | |
| mluis | 0:62d1edcc13d1 | 128 | |
| mluis | 0:62d1edcc13d1 | 129 | #if !HAS_os_calls | 
| mluis | 0:62d1edcc13d1 | 130 | |
| mluis | 0:62d1edcc13d1 | 131 | #ifndef os_getDevKey | 
| mluis | 0:62d1edcc13d1 | 132 | void os_getDevKey (xref2u1_t buf); | 
| mluis | 0:62d1edcc13d1 | 133 | #endif | 
| mluis | 0:62d1edcc13d1 | 134 | #ifndef os_getArtEui | 
| mluis | 0:62d1edcc13d1 | 135 | void os_getArtEui (xref2u1_t buf); | 
| mluis | 0:62d1edcc13d1 | 136 | #endif | 
| mluis | 0:62d1edcc13d1 | 137 | #ifndef os_getDevEui | 
| mluis | 0:62d1edcc13d1 | 138 | void os_getDevEui (xref2u1_t buf); | 
| mluis | 0:62d1edcc13d1 | 139 | #endif | 
| mluis | 0:62d1edcc13d1 | 140 | #ifndef os_setCallback | 
| mluis | 0:62d1edcc13d1 | 141 | void os_setCallback (xref2osjob_t job, osjobcb_t cb); | 
| mluis | 0:62d1edcc13d1 | 142 | #endif | 
| mluis | 0:62d1edcc13d1 | 143 | #ifndef os_setTimedCallback | 
| mluis | 0:62d1edcc13d1 | 144 | void os_setTimedCallback (xref2osjob_t job, ostime_t time, osjobcb_t cb); | 
| mluis | 0:62d1edcc13d1 | 145 | #endif | 
| mluis | 0:62d1edcc13d1 | 146 | #ifndef os_clearCallback | 
| mluis | 0:62d1edcc13d1 | 147 | void os_clearCallback (xref2osjob_t job); | 
| mluis | 0:62d1edcc13d1 | 148 | #endif | 
| mluis | 0:62d1edcc13d1 | 149 | #ifndef os_getTime | 
| mluis | 0:62d1edcc13d1 | 150 | ostime_t os_getTime (void); | 
| mluis | 0:62d1edcc13d1 | 151 | #endif | 
| mluis | 0:62d1edcc13d1 | 152 | #ifndef os_getTimeSecs | 
| mluis | 0:62d1edcc13d1 | 153 | uint os_getTimeSecs (void); | 
| mluis | 0:62d1edcc13d1 | 154 | #endif | 
| mluis | 0:62d1edcc13d1 | 155 | #ifndef os_radio | 
| mluis | 0:62d1edcc13d1 | 156 | void os_radio (u1_t mode); | 
| mluis | 0:62d1edcc13d1 | 157 | #endif | 
| mluis | 0:62d1edcc13d1 | 158 | #ifndef os_getBattLevel | 
| mluis | 0:62d1edcc13d1 | 159 | u1_t os_getBattLevel (void); | 
| mluis | 0:62d1edcc13d1 | 160 | #endif | 
| mluis | 0:62d1edcc13d1 | 161 | |
| mluis | 0:62d1edcc13d1 | 162 | #ifndef os_rlsbf4 | 
| mluis | 0:62d1edcc13d1 | 163 | //! Read 32-bit quantity from given pointer in little endian byte order. | 
| mluis | 0:62d1edcc13d1 | 164 | u4_t os_rlsbf4 (xref2cu1_t buf); | 
| mluis | 0:62d1edcc13d1 | 165 | #endif | 
| mluis | 0:62d1edcc13d1 | 166 | #ifndef os_wlsbf4 | 
| mluis | 0:62d1edcc13d1 | 167 | //! Write 32-bit quntity into buffer in little endian byte order. | 
| mluis | 0:62d1edcc13d1 | 168 | void os_wlsbf4 (xref2u1_t buf, u4_t value); | 
| mluis | 0:62d1edcc13d1 | 169 | #endif | 
| mluis | 0:62d1edcc13d1 | 170 | #ifndef os_rmsbf4 | 
| mluis | 0:62d1edcc13d1 | 171 | //! Read 32-bit quantity from given pointer in big endian byte order. | 
| mluis | 0:62d1edcc13d1 | 172 | u4_t os_rmsbf4 (xref2cu1_t buf); | 
| mluis | 0:62d1edcc13d1 | 173 | #endif | 
| mluis | 0:62d1edcc13d1 | 174 | #ifndef os_wmsbf4 | 
| mluis | 0:62d1edcc13d1 | 175 | //! Write 32-bit quntity into buffer in big endian byte order. | 
| mluis | 0:62d1edcc13d1 | 176 | void os_wmsbf4 (xref2u1_t buf, u4_t value); | 
| mluis | 0:62d1edcc13d1 | 177 | #endif | 
| mluis | 0:62d1edcc13d1 | 178 | #ifndef os_rlsbf2 | 
| mluis | 0:62d1edcc13d1 | 179 | //! Read 16-bit quantity from given pointer in little endian byte order. | 
| mluis | 0:62d1edcc13d1 | 180 | u2_t os_rlsbf2 (xref2cu1_t buf); | 
| mluis | 0:62d1edcc13d1 | 181 | #endif | 
| mluis | 0:62d1edcc13d1 | 182 | #ifndef os_wlsbf2 | 
| mluis | 0:62d1edcc13d1 | 183 | //! Write 16-bit quntity into buffer in little endian byte order. | 
| mluis | 0:62d1edcc13d1 | 184 | void os_wlsbf2 (xref2u1_t buf, u2_t value); | 
| mluis | 0:62d1edcc13d1 | 185 | #endif | 
| mluis | 0:62d1edcc13d1 | 186 | |
| mluis | 0:62d1edcc13d1 | 187 | //! Get random number (default impl for u2_t). | 
| mluis | 0:62d1edcc13d1 | 188 | #ifndef os_getRndU2 | 
| mluis | 0:62d1edcc13d1 | 189 | #define os_getRndU2() ((u2_t)((os_getRndU1()<<8)|os_getRndU1())) | 
| mluis | 0:62d1edcc13d1 | 190 | #endif | 
| mluis | 0:62d1edcc13d1 | 191 | #ifndef os_crc16 | 
| mluis | 0:62d1edcc13d1 | 192 | u2_t os_crc16 (xref2u1_t d, uint len); | 
| mluis | 0:62d1edcc13d1 | 193 | #endif | 
| mluis | 0:62d1edcc13d1 | 194 | |
| mluis | 0:62d1edcc13d1 | 195 | #endif // !HAS_os_calls | 
| mluis | 0:62d1edcc13d1 | 196 | |
| mluis | 0:62d1edcc13d1 | 197 | // ====================================================================== | 
| mluis | 0:62d1edcc13d1 | 198 | // AES support | 
| mluis | 0:62d1edcc13d1 | 199 | // !!Keep in sync with lorabase.hpp!! | 
| mluis | 0:62d1edcc13d1 | 200 | |
| mluis | 0:62d1edcc13d1 | 201 | #ifndef AES_ENC // if AES_ENC is defined as macro all other values must be too | 
| mluis | 0:62d1edcc13d1 | 202 | #define AES_ENC 0x00 | 
| mluis | 0:62d1edcc13d1 | 203 | #define AES_DEC 0x01 | 
| mluis | 0:62d1edcc13d1 | 204 | #define AES_MIC 0x02 | 
| mluis | 0:62d1edcc13d1 | 205 | #define AES_CTR 0x04 | 
| mluis | 0:62d1edcc13d1 | 206 | #define AES_MICNOAUX 0x08 | 
| mluis | 0:62d1edcc13d1 | 207 | #endif | 
| mluis | 0:62d1edcc13d1 | 208 | #ifndef AESkey // if AESkey is defined as macro all other values must be too | 
| mluis | 0:62d1edcc13d1 | 209 | extern xref2u1_t AESkey; | 
| mluis | 0:62d1edcc13d1 | 210 | extern xref2u1_t AESaux; | 
| mluis | 0:62d1edcc13d1 | 211 | #endif | 
| mluis | 0:62d1edcc13d1 | 212 | #ifndef os_aes | 
| mluis | 0:62d1edcc13d1 | 213 | u4_t os_aes (u1_t mode, xref2u1_t buf, u2_t len); | 
| mluis | 0:62d1edcc13d1 | 214 | #endif | 
| mluis | 0:62d1edcc13d1 | 215 | |
| mluis | 0:62d1edcc13d1 | 216 | |
| mluis | 0:62d1edcc13d1 | 217 | |
| mluis | 0:62d1edcc13d1 | 218 | #endif // _oslmic_h_ | 
