blob: 20dbf1a20887a5f4269a73e6a7566248e9ad518c [file] [log] [blame]
Cyril Bur314929b2016-10-14 15:55:16 +11001/* Copyright 2016 IBM
2 *
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +11007 * http://www.apache.org/licenses/LICENSE-2.0
Cyril Bur314929b2016-10-14 15:55:16 +11008 *
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +11009 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
Cyril Bur314929b2016-10-14 15:55:16 +110014 *
15 */
16
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +110017#ifndef COMMON_H
18#define COMMON_H
19
Andrew Jeffery36a39f62017-04-10 16:25:04 +093020#include <stdarg.h>
21#include <stdbool.h>
22#include <stdint.h>
23
Cyril Bur314929b2016-10-14 15:55:16 +110024#ifndef PREFIX
25#define PREFIX ""
26#endif
27
Ratan Gupta90b92fe2017-05-05 17:34:00 +053028enum verbose {
Andrew Jeffery44ac0782018-02-26 13:03:40 +103029 MBOX_LOG_NONE = 0,
30 MBOX_LOG_INFO = 1,
31 MBOX_LOG_DEBUG = 2
Ratan Gupta90b92fe2017-05-05 17:34:00 +053032};
33
34extern enum verbose verbosity;
Cyril Bur314929b2016-10-14 15:55:16 +110035
Suraj Jitindar Singh28519592017-04-27 14:48:58 +100036/* Error Messages */
Andrew Jeffery44ac0782018-02-26 13:03:40 +103037#define MSG_ERR(f_, ...) \
38do { \
39 mbox_log(LOG_ERR, f_, ##__VA_ARGS__); \
40} while (0)
41
Suraj Jitindar Singh28519592017-04-27 14:48:58 +100042/* Informational Messages */
Andrew Jeffery44ac0782018-02-26 13:03:40 +103043#define MSG_INFO(f_, ...) \
44do { \
45 if (verbosity >= MBOX_LOG_INFO) { \
46 mbox_log(LOG_INFO, f_, ##__VA_ARGS__); \
47 } \
48} while (0)
49
Suraj Jitindar Singh28519592017-04-27 14:48:58 +100050/* Debug Messages */
Andrew Jeffery44ac0782018-02-26 13:03:40 +103051#define MSG_DBG(f_, ...) \
52do { \
53 if (verbosity >= MBOX_LOG_DEBUG) { \
54 mbox_log(LOG_DEBUG, f_, ##__VA_ARGS__); \
55 } \
56} while(0)
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +110057
Ratan Gupta90b92fe2017-05-05 17:34:00 +053058extern void (*mbox_vlog)(int p, const char *fmt, va_list args);
Cyril Bur314929b2016-10-14 15:55:16 +110059
Deepak Kodihalli393821d2017-04-28 04:44:38 -050060#ifdef __cplusplus
61extern "C" {
62#endif
63
Cyril Bur314929b2016-10-14 15:55:16 +110064void mbox_log_console(int p, const char *fmt, va_list args);
65
66__attribute__((format(printf, 2, 3)))
67void mbox_log(int p, const char *fmt, ...);
68
69uint16_t get_u16(uint8_t *ptr);
70
71void put_u16(uint8_t *ptr, uint16_t val);
72
73uint32_t get_u32(uint8_t *ptr);
74
75void put_u32(uint8_t *ptr, uint32_t val);
76
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +110077static inline uint32_t align_up(uint32_t val, uint32_t size)
78{
79 return (((val) + (size) - 1) & ~((size) - 1));
80}
81
82static inline uint32_t align_down(uint32_t val, uint32_t size)
83{
84 return ((val) & ~(((size) - 1)));
85}
86
87static inline uint32_t min_u32(uint32_t a, uint32_t b)
88{
89 if (a <= b) {
90 return a;
91 }
92
93 return b;
94}
95
96static inline int log_2(int val)
97{
98 int ret = 0;
99
100 if (val <= 0) {
101 return -1;
102 }
103
104 while (val >>= 1) {
105 ret++;
106 }
107
108 return ret;
109}
110
Suraj Jitindar Singh0aff80c2017-04-12 14:37:24 +1000111static inline bool is_power_of_2(unsigned val)
112{
113 return __builtin_popcount(val) == 1;
114}
115
Cyril Bur314929b2016-10-14 15:55:16 +1100116char *get_dev_mtd(void);
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +1100117
Deepak Kodihalli393821d2017-04-28 04:44:38 -0500118#ifdef __cplusplus
119}
120#endif
121
Suraj Jitindar Singhe39c9162017-03-28 10:47:43 +1100122#endif /* COMMON_H */