Coverage Report

Created: 2026-06-15 07:03

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/CMake/Utilities/cmliblzma/liblzma/simple/ia64.c
Line
Count
Source
1
// SPDX-License-Identifier: 0BSD
2
3
///////////////////////////////////////////////////////////////////////////////
4
//
5
/// \file       ia64.c
6
/// \brief      Filter for IA64 (Itanium) binaries
7
///
8
//  Authors:    Igor Pavlov
9
//              Lasse Collin
10
//
11
///////////////////////////////////////////////////////////////////////////////
12
13
#include "simple_private.h"
14
15
16
static size_t
17
ia64_code(void *simple lzma_attribute((__unused__)),
18
    uint32_t now_pos, bool is_encoder,
19
    uint8_t *buffer, size_t size)
20
1.67k
{
21
1.67k
  static const uint32_t BRANCH_TABLE[32] = {
22
1.67k
    0, 0, 0, 0, 0, 0, 0, 0,
23
1.67k
    0, 0, 0, 0, 0, 0, 0, 0,
24
1.67k
    4, 4, 6, 6, 0, 0, 7, 7,
25
1.67k
    4, 4, 0, 0, 4, 4, 0, 0
26
1.67k
  };
27
28
1.67k
  size_t i;
29
211k
  for (i = 0; i + 16 <= size; i += 16) {
30
209k
    const uint32_t instr_template = buffer[i] & 0x1F;
31
209k
    const uint32_t mask = BRANCH_TABLE[instr_template];
32
209k
    uint32_t bit_pos = 5;
33
34
838k
    for (size_t slot = 0; slot < 3; ++slot, bit_pos += 41) {
35
629k
      if (((mask >> slot) & 1) == 0)
36
609k
        continue;
37
38
19.9k
      const size_t byte_pos = (bit_pos >> 3);
39
19.9k
      const uint32_t bit_res = bit_pos & 0x7;
40
19.9k
      uint64_t instruction = 0;
41
42
139k
      for (size_t j = 0; j < 6; ++j)
43
119k
        instruction += (uint64_t)(
44
119k
            buffer[i + j + byte_pos])
45
119k
            << (8 * j);
46
47
19.9k
      uint64_t inst_norm = instruction >> bit_res;
48
49
19.9k
      if (((inst_norm >> 37) & 0xF) == 0x5
50
3.49k
          && ((inst_norm >> 9) & 0x7) == 0
51
          /* &&  (inst_norm & 0x3F)== 0 */
52
19.9k
          ) {
53
554
        uint32_t src = (uint32_t)(
54
554
            (inst_norm >> 13) & 0xFFFFF);
55
554
        src |= ((inst_norm >> 36) & 1) << 20;
56
57
554
        src <<= 4;
58
59
554
        uint32_t dest;
60
554
        if (is_encoder)
61
0
          dest = now_pos + (uint32_t)(i) + src;
62
554
        else
63
554
          dest = src - (now_pos + (uint32_t)(i));
64
65
554
        dest >>= 4;
66
67
554
        inst_norm &= ~((uint64_t)(0x8FFFFF) << 13);
68
554
        inst_norm |= (uint64_t)(dest & 0xFFFFF) << 13;
69
554
        inst_norm |= (uint64_t)(dest & 0x100000)
70
554
            << (36 - 20);
71
72
554
        instruction &= (1U << bit_res) - 1;
73
554
        instruction |= (inst_norm << bit_res);
74
75
3.87k
        for (size_t j = 0; j < 6; j++)
76
3.32k
          buffer[i + j + byte_pos] = (uint8_t)(
77
3.32k
              instruction
78
3.32k
              >> (8 * j));
79
554
      }
80
19.9k
    }
81
209k
  }
82
83
1.67k
  return i;
84
1.67k
}
85
86
87
static lzma_ret
88
ia64_coder_init(lzma_next_coder *next, const lzma_allocator *allocator,
89
    const lzma_filter_info *filters, bool is_encoder)
90
1.01k
{
91
1.01k
  return lzma_simple_coder_init(next, allocator, filters,
92
1.01k
      &ia64_code, 0, 16, 16, is_encoder);
93
1.01k
}
94
95
96
#ifdef HAVE_ENCODER_IA64
97
extern lzma_ret
98
lzma_simple_ia64_encoder_init(lzma_next_coder *next,
99
    const lzma_allocator *allocator,
100
    const lzma_filter_info *filters)
101
0
{
102
0
  return ia64_coder_init(next, allocator, filters, true);
103
0
}
104
#endif
105
106
107
#ifdef HAVE_DECODER_IA64
108
extern lzma_ret
109
lzma_simple_ia64_decoder_init(lzma_next_coder *next,
110
    const lzma_allocator *allocator,
111
    const lzma_filter_info *filters)
112
1.01k
{
113
  return ia64_coder_init(next, allocator, filters, false);
114
1.01k
}
115
#endif