blob: e1d4c893edcedfff76fd87c1c26d1d018600dba1 [file] [log] [blame]
Harald Welted284cd92010-03-01 21:58:31 +01001
2#include <string.h>
3#include <stdint.h>
4#include <errno.h>
Harald Welteb59f9352010-03-25 11:37:04 +08005#include <stdio.h>
Harald Welted284cd92010-03-01 21:58:31 +01006
Pablo Neira Ayuso83419342011-03-22 16:36:13 +01007#include <osmocom/core/utils.h>
Harald Welted284cd92010-03-01 21:58:31 +01008
Harald Welteb59f9352010-03-25 11:37:04 +08009static char namebuf[255];
Harald Welted284cd92010-03-01 21:58:31 +010010const char *get_value_string(const struct value_string *vs, uint32_t val)
11{
12 int i;
13
14 for (i = 0;; i++) {
15 if (vs[i].value == 0 && vs[i].str == NULL)
16 break;
17 if (vs[i].value == val)
18 return vs[i].str;
19 }
Harald Welteb59f9352010-03-25 11:37:04 +080020
21 snprintf(namebuf, sizeof(namebuf), "unknown 0x%x", val);
22 return namebuf;
Harald Welted284cd92010-03-01 21:58:31 +010023}
24
25int get_string_value(const struct value_string *vs, const char *str)
26{
27 int i;
28
29 for (i = 0;; i++) {
30 if (vs[i].value == 0 && vs[i].str == NULL)
31 break;
32 if (!strcasecmp(vs[i].str, str))
33 return vs[i].value;
34 }
35 return -EINVAL;
36}
Harald Weltea73e2f92010-03-04 10:50:32 +010037
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +020038char osmo_bcd2char(uint8_t bcd)
Harald Weltea73e2f92010-03-04 10:50:32 +010039{
40 if (bcd < 0xa)
41 return '0' + bcd;
42 else
43 return 'A' + (bcd - 0xa);
44}
45
Holger Hans Peter Freyther121f3582010-11-19 19:20:46 +010046/* only works for numbers in ascii */
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +020047uint8_t osmo_char2bcd(char c)
Harald Weltea73e2f92010-03-04 10:50:32 +010048{
49 return c - 0x30;
50}
Harald Welte3eba9912010-07-30 10:37:29 +020051
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +020052int osmo_hexparse(const char *str, uint8_t *b, int max_len)
Harald Welte3eba9912010-07-30 10:37:29 +020053
54{
55 int i, l, v;
56
57 l = strlen(str);
58 if ((l&1) || ((l>>1) > max_len))
59 return -1;
60
61 memset(b, 0x00, max_len);
62
63 for (i=0; i<l; i++) {
64 char c = str[i];
65 if (c >= '0' && c <= '9')
66 v = c - '0';
67 else if (c >= 'a' && c <= 'f')
68 v = 10 + (c - 'a');
69 else if (c >= 'A' && c <= 'F')
70 v = 10 + (c - 'A');
71 else
72 return -1;
73 b[i>>1] |= v << (i&1 ? 0 : 4);
74 }
75
76 return i>>1;
77}
Harald Welte40481e82010-07-30 11:40:32 +020078
79static char hexd_buff[4096];
80
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +020081static char *_osmo_hexdump(const unsigned char *buf, int len, char *delim)
Harald Welte40481e82010-07-30 11:40:32 +020082{
83 int i;
84 char *cur = hexd_buff;
85
86 hexd_buff[0] = 0;
87 for (i = 0; i < len; i++) {
88 int len_remain = sizeof(hexd_buff) - (cur - hexd_buff);
Holger Hans Peter Freyther128d9e22011-07-15 16:07:23 +020089 if (len_remain <= 0)
90 break;
Harald Weltedee47cd2010-07-30 11:43:30 +020091 int rc = snprintf(cur, len_remain, "%02x%s", buf[i], delim);
Harald Welte40481e82010-07-30 11:40:32 +020092 if (rc <= 0)
93 break;
94 cur += rc;
95 }
96 hexd_buff[sizeof(hexd_buff)-1] = 0;
97 return hexd_buff;
98}
Harald Weltedee47cd2010-07-30 11:43:30 +020099
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +0200100char *osmo_ubit_dump(const uint8_t *bits, unsigned int len)
Harald Welte3d0ac5e2011-02-08 16:55:03 +0100101{
102 int i;
103
104 if (len > sizeof(hexd_buff)-1)
105 len = sizeof(hexd_buff)-1;
106 memset(hexd_buff, 0, sizeof(hexd_buff));
107
108 for (i = 0; i < len; i++) {
109 char outch;
110 switch (bits[i]) {
111 case 0:
112 outch = '0';
113 break;
114 case 0xff:
115 outch = '?';
116 break;
117 case 1:
118 outch = '1';
119 break;
120 default:
121 outch = 'E';
122 break;
123 }
124 hexd_buff[i] = outch;
125 }
126 hexd_buff[sizeof(hexd_buff)-1] = 0;
127 return hexd_buff;
128}
129
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +0200130char *osmo_hexdump(const unsigned char *buf, int len)
Harald Weltedee47cd2010-07-30 11:43:30 +0200131{
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +0200132 return _osmo_hexdump(buf, len, " ");
Harald Weltedee47cd2010-07-30 11:43:30 +0200133}
134
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +0200135char *osmo_osmo_hexdump_nospc(const unsigned char *buf, int len)
Harald Weltedee47cd2010-07-30 11:43:30 +0200136{
Pablo Neira Ayuso87f7b252011-05-07 12:43:08 +0200137 return _osmo_hexdump(buf, len, "");
Harald Weltedee47cd2010-07-30 11:43:30 +0200138}
Harald Welte28222962011-02-18 20:37:04 +0100139
140#include "../config.h"
141#ifdef HAVE_CTYPE_H
142#include <ctype.h>
143void osmo_str2lower(char *out, const char *in)
144{
145 unsigned int i;
146
147 for (i = 0; i < strlen(in); i++)
148 out[i] = tolower(in[i]);
149 out[strlen(in)] = '\0';
150}
151
152void osmo_str2upper(char *out, const char *in)
153{
154 unsigned int i;
155
156 for (i = 0; i < strlen(in); i++)
157 out[i] = toupper(in[i]);
158 out[strlen(in)] = '\0';
159}
160#endif /* HAVE_CTYPE_H */