A metronome using the FRDM K64F board

Committer:
ram54288
Date:
Sun May 14 18:40:18 2017 +0000
Revision:
0:a7a43371b306
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ram54288 0:a7a43371b306 1 /*
ram54288 0:a7a43371b306 2 * Copyright (c) 2016 ARM Limited. All rights reserved.
ram54288 0:a7a43371b306 3 * SPDX-License-Identifier: Apache-2.0
ram54288 0:a7a43371b306 4 * Licensed under the Apache License, Version 2.0 (the License); you may
ram54288 0:a7a43371b306 5 * not use this file except in compliance with the License.
ram54288 0:a7a43371b306 6 * You may obtain a copy of the License at
ram54288 0:a7a43371b306 7 *
ram54288 0:a7a43371b306 8 * http://www.apache.org/licenses/LICENSE-2.0
ram54288 0:a7a43371b306 9 *
ram54288 0:a7a43371b306 10 * Unless required by applicable law or agreed to in writing, software
ram54288 0:a7a43371b306 11 * distributed under the License is distributed on an AS IS BASIS, WITHOUT
ram54288 0:a7a43371b306 12 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
ram54288 0:a7a43371b306 13 * See the License for the specific language governing permissions and
ram54288 0:a7a43371b306 14 * limitations under the License.
ram54288 0:a7a43371b306 15 */
ram54288 0:a7a43371b306 16
ram54288 0:a7a43371b306 17
ram54288 0:a7a43371b306 18 #ifndef _PAL_MACROS_H
ram54288 0:a7a43371b306 19 #define _PAL_MACROS_H
ram54288 0:a7a43371b306 20
ram54288 0:a7a43371b306 21 #ifdef __cplusplus
ram54288 0:a7a43371b306 22 extern "C" {
ram54288 0:a7a43371b306 23 #endif
ram54288 0:a7a43371b306 24
ram54288 0:a7a43371b306 25 #include "pal_errors.h"
ram54288 0:a7a43371b306 26 // PAL success value
ram54288 0:a7a43371b306 27 #define PAL_SUCCESS 0
ram54288 0:a7a43371b306 28
ram54288 0:a7a43371b306 29 // maximum integer types
ram54288 0:a7a43371b306 30 #define PAL_MAX_UINT8 0xFFU
ram54288 0:a7a43371b306 31 #define PAL_MAX_UINT16 0xFFFFU
ram54288 0:a7a43371b306 32 #define PAL_MAX_UINT32 0xFFFFFFFFUL
ram54288 0:a7a43371b306 33 #define PAL_MAX_INT32 0x7FFFFFFFL
ram54288 0:a7a43371b306 34 #define PAL_MIN_INT32 0x80000000L
ram54288 0:a7a43371b306 35 #define PAL_MAX_UINT64 0xFFFFFFFFFFFFFFFFULL
ram54288 0:a7a43371b306 36 #define PAL_MAX_INT64 0x7FFFFFFFFFFFFFFFLL
ram54288 0:a7a43371b306 37
ram54288 0:a7a43371b306 38 // useful macros
ram54288 0:a7a43371b306 39
ram54288 0:a7a43371b306 40 #define PAL_MAX(a,b) ((a) > (b) ? (a) : (b))
ram54288 0:a7a43371b306 41
ram54288 0:a7a43371b306 42 #define PAL_MIN(a,b) ((a) < (b) ? (a) : (b))
ram54288 0:a7a43371b306 43
ram54288 0:a7a43371b306 44 #define PAL_DIVIDE_ROUND_UP(num, divider) (((num) + (divider) - 1) / (divider))
ram54288 0:a7a43371b306 45
ram54288 0:a7a43371b306 46 #if PAL_COMPILATION_ENDIANITY == 1
ram54288 0:a7a43371b306 47 #define BIG__ENDIAN 1
ram54288 0:a7a43371b306 48 #elif PAL_COMPILATION_ENDIANITY == 0
ram54288 0:a7a43371b306 49 #define LITTLE__ENDIAN 1
ram54288 0:a7a43371b306 50 #else
ram54288 0:a7a43371b306 51 #error neither BIG__ENDIAN nor LITTLE__ENDIAN defined, cannot compile
ram54288 0:a7a43371b306 52 #endif
ram54288 0:a7a43371b306 53
ram54288 0:a7a43371b306 54 // endianity macros
ram54288 0:a7a43371b306 55 #ifdef LITTLE__ENDIAN
ram54288 0:a7a43371b306 56
ram54288 0:a7a43371b306 57 #define PAL_HTONS(x) (((((unsigned short)(x)) >> 8) & 0xff) | \
ram54288 0:a7a43371b306 58 ((((unsigned short)(x)) & 0xff) << 8))
ram54288 0:a7a43371b306 59 #define PAL_NTOHS(x) (((((unsigned short)(x)) >> 8) & 0xff) | \
ram54288 0:a7a43371b306 60 ((((unsigned short)(x)) & 0xff) << 8) )
ram54288 0:a7a43371b306 61 #define PAL_HTONL(x) ((((x)>>24) & 0xffL) | (((x)>>8) & 0xff00L) | \
ram54288 0:a7a43371b306 62 (((x)<<8) & 0xff0000L) | (((x)<<24) & 0xff000000L))
ram54288 0:a7a43371b306 63 #define PAL_NTOHL(x) ((((x)>>24) & 0xffL) | (((x)>>8) & 0xff00L) | \
ram54288 0:a7a43371b306 64 (((x)<<8) & 0xff0000L) | (((x)<<24) & 0xff000000L))
ram54288 0:a7a43371b306 65
ram54288 0:a7a43371b306 66 #elif defined(BIG__ENDIAN)
ram54288 0:a7a43371b306 67
ram54288 0:a7a43371b306 68 #define PAL_HTONS(x) (x)
ram54288 0:a7a43371b306 69 #define PAL_NTOHS(x) (x)
ram54288 0:a7a43371b306 70 #define PAL_HTONL(x) (x)
ram54288 0:a7a43371b306 71 #define PAL_NTOHL(x) (x)
ram54288 0:a7a43371b306 72 #else
ram54288 0:a7a43371b306 73 #error neither BIG__ENDIAN nor LITTLE__ENDIAN defined, cannot compile
ram54288 0:a7a43371b306 74 #endif
ram54288 0:a7a43371b306 75
ram54288 0:a7a43371b306 76
ram54288 0:a7a43371b306 77
ram54288 0:a7a43371b306 78 #define PAL_INVERSE_UINT16_BYTES( val ) \
ram54288 0:a7a43371b306 79 ( ((val) << 8) | (((val) & 0x0000FF00) >> 8))
ram54288 0:a7a43371b306 80
ram54288 0:a7a43371b306 81 #define PAL_INVERSE_UINT32_BYTES( val ) \
ram54288 0:a7a43371b306 82 ( ((val) >> 24) | (((val) & 0x00FF0000) >> 8) | (((val) & 0x0000FF00) << 8) | (((val) & 0x000000FF) << 24) )
ram54288 0:a7a43371b306 83
ram54288 0:a7a43371b306 84 #define PAL_INVERSE_UINT64_BYTES( val ) \
ram54288 0:a7a43371b306 85 ((PAL_INVERSE_UINT32_BYTES( ((val >> 16) >> 16)) &0xffffffff) | ((((uint64_t)PAL_INVERSE_UINT32_BYTES(val & 0xffffffff))<<16)<<16))
ram54288 0:a7a43371b306 86
ram54288 0:a7a43371b306 87 /* Set of Macros similar to the HTONS/L, NTOHS/L ones but converting to/from little endian instead of big endian*/
ram54288 0:a7a43371b306 88 #ifdef LITTLE__ENDIAN
ram54288 0:a7a43371b306 89 #define PAL_LITTLE_ENDIAN_TO_HOST_16BIT(x) (x)
ram54288 0:a7a43371b306 90 #define PAL_LITTLE_ENDIAN_TO_HOST_32BIT(x) (x)
ram54288 0:a7a43371b306 91 #define PAL_LITTLE_ENDIAN_TO_HOST_64BIT(x) (x)
ram54288 0:a7a43371b306 92 #define PAL_HOST_TO_LITTLE_ENDIAN_16BIT(x) (x)
ram54288 0:a7a43371b306 93 #define PAL_HOST_TO_LITTLE_ENDIAN_32BIT(x) (x)
ram54288 0:a7a43371b306 94 #define PAL_HOST_TO_LITTLE_ENDIAN_64BIT(x) (x)
ram54288 0:a7a43371b306 95
ram54288 0:a7a43371b306 96
ram54288 0:a7a43371b306 97 #elif defined(BIG__ENDIAN)
ram54288 0:a7a43371b306 98 #define PAL_LITTLE_ENDIAN_TO_HOST_16BIT(x) (PAL_INVERSE_UINT16_BYTES(((uint16_t)x)))
ram54288 0:a7a43371b306 99 #define PAL_LITTLE_ENDIAN_TO_HOST_32BIT(x) (PAL_INVERSE_UINT32_BYTES(((uint32_t)x)))
ram54288 0:a7a43371b306 100 #define PAL_LITTLE_ENDIAN_TO_HOST_64BIT(x) (PAL_INVERSE_UINT64_BYTES(((uint64_t)x)))
ram54288 0:a7a43371b306 101 #define PAL_HOST_TO_LITTLE_ENDIAN_16BIT(x) (PAL_INVERSE_UINT16_BYTES(((uint16_t)x)))
ram54288 0:a7a43371b306 102 #define PAL_HOST_TO_LITTLE_ENDIAN_32BIT(x) (PAL_INVERSE_UINT32_BYTES(((uint32_t)x)))
ram54288 0:a7a43371b306 103 #define PAL_HOST_TO_LITTLE_ENDIAN_64BIT(x) (PAL_INVERSE_UINT64_BYTES(((uint64_t)x)))
ram54288 0:a7a43371b306 104
ram54288 0:a7a43371b306 105 #else
ram54288 0:a7a43371b306 106 #error neither BIG__ENDIAN nor LITTLE__ENDIAN defined, cannot compile
ram54288 0:a7a43371b306 107 #endif
ram54288 0:a7a43371b306 108
ram54288 0:a7a43371b306 109
ram54288 0:a7a43371b306 110 #define PAL_MODULE_INIT(INIT) INIT= 1
ram54288 0:a7a43371b306 111 #define PAL_MODULE_DEINIT(INIT) INIT= 0
ram54288 0:a7a43371b306 112
ram54288 0:a7a43371b306 113 #ifdef DEBUG
ram54288 0:a7a43371b306 114 #include "pal.h"
ram54288 0:a7a43371b306 115 #define DEBUG_PRINT(ARGS...) PAL_PRINTF(ARGS)
ram54288 0:a7a43371b306 116
ram54288 0:a7a43371b306 117 #define DEBUG_PRINT(ARGS...) PAL_PRINTF(ARGS)
ram54288 0:a7a43371b306 118 #define PAL_MODULE_IS_INIT(INIT) if(!INIT) return PAL_ERR_NOT_INITIALIZED;
ram54288 0:a7a43371b306 119
ram54288 0:a7a43371b306 120
ram54288 0:a7a43371b306 121 #else
ram54288 0:a7a43371b306 122 #define PAL_MODULE_IS_INIT(INIT)
ram54288 0:a7a43371b306 123
ram54288 0:a7a43371b306 124 #define DEBUG_PRINT(ARGS...)
ram54288 0:a7a43371b306 125
ram54288 0:a7a43371b306 126 #endif //DEBUG
ram54288 0:a7a43371b306 127
ram54288 0:a7a43371b306 128 #ifdef __cplusplus
ram54288 0:a7a43371b306 129 }
ram54288 0:a7a43371b306 130 #endif
ram54288 0:a7a43371b306 131 #endif //_PAL_MACROS_H