Coverage Report

Created: 2025-07-11 06:57

/src/sudo/lib/util/hexchar.c
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * SPDX-License-Identifier: ISC
3
 *
4
 * Copyright (c) 2013-2015, 2023 Todd C. Miller <Todd.Miller@sudo.ws>
5
 *
6
 * Permission to use, copy, modify, and distribute this software for any
7
 * purpose with or without fee is hereby granted, provided that the above
8
 * copyright notice and this permission notice appear in all copies.
9
 *
10
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17
 */
18
19
/*
20
 * This is an open source non-commercial project. Dear PVS-Studio, please check it.
21
 * PVS-Studio Static Code Analyzer for C, C++ and C#: http://www.viva64.com
22
 */
23
24
#include <config.h>
25
26
#include <sudo_compat.h>
27
#include <sudo_debug.h>
28
#include <sudo_util.h>
29
30
/*
31
 * Converts a two-byte hex string to decimal.
32
 * Returns a value 0-255 on success or -1 for invalid input.
33
 */
34
int
35
sudo_hexchar_v1(const char s[restrict static 2])
36
138k
{
37
138k
    unsigned char result[2];
38
138k
    unsigned int i;
39
138k
    debug_decl(sudo_hexchar, SUDO_DEBUG_UTIL);
40
41
391k
    for (i = 0; i < 2; i++) {
42
267k
  switch (s[i]) {
43
226k
  case '0':
44
226k
      result[i] = 0;
45
226k
      break;
46
9.46k
  case '1':
47
9.46k
      result[i] = 1;
48
9.46k
      break;
49
2.16k
  case '2':
50
2.16k
      result[i] = 2;
51
2.16k
      break;
52
2
  case '3':
53
2
      result[i] = 3;
54
2
      break;
55
125
  case '4':
56
125
      result[i] = 4;
57
125
      break;
58
1
  case '5':
59
1
      result[i] = 5;
60
1
      break;
61
10.1k
  case '6':
62
10.1k
      result[i] = 6;
63
10.1k
      break;
64
1
  case '7':
65
1
      result[i] = 7;
66
1
      break;
67
7
  case '8':
68
7
      result[i] = 8;
69
7
      break;
70
2
  case '9':
71
2
      result[i] = 9;
72
2
      break;
73
1
  case 'A':
74
161
  case 'a':
75
161
      result[i] = 10;
76
161
      break;
77
2
  case 'B':
78
27
  case 'b':
79
27
      result[i] = 11;
80
27
      break;
81
29
  case 'C':
82
37
  case 'c':
83
37
      result[i] = 12;
84
37
      break;
85
11
  case 'D':
86
18
  case 'd':
87
18
      result[i] = 13;
88
18
      break;
89
0
  case 'E':
90
1.44k
  case 'e':
91
1.44k
      result[i] = 14;
92
1.44k
      break;
93
9
  case 'F':
94
3.56k
  case 'f':
95
3.56k
      result[i] = 15;
96
3.56k
      break;
97
14.3k
  default:
98
      /* Invalid input. */
99
14.3k
      debug_return_int(-1);
100
267k
  }
101
267k
    }
102
124k
    debug_return_int((result[0] << 4) | result[1]);
103
124k
}