Rizin
unix-like reverse engineering framework and cli tools
sparc.c
Go to the documentation of this file.
1 //
6 // Authors: Igor Pavlov
7 // Lasse Collin
8 //
9 // This file has been put into the public domain.
10 // You can do whatever you want with this file.
11 //
13 
14 #include "simple_private.h"
15 
16 
17 static size_t
18 sparc_code(void *simple lzma_attribute((__unused__)),
19  uint32_t now_pos, bool is_encoder,
20  uint8_t *buffer, size_t size)
21 {
22  size_t i;
23  for (i = 0; i + 4 <= size; i += 4) {
24 
25  if ((buffer[i] == 0x40 && (buffer[i + 1] & 0xC0) == 0x00)
26  || (buffer[i] == 0x7F
27  && (buffer[i + 1] & 0xC0) == 0xC0)) {
28 
29  uint32_t src = ((uint32_t)buffer[i + 0] << 24)
30  | ((uint32_t)buffer[i + 1] << 16)
31  | ((uint32_t)buffer[i + 2] << 8)
32  | ((uint32_t)buffer[i + 3]);
33 
34  src <<= 2;
35 
36  uint32_t dest;
37  if (is_encoder)
38  dest = now_pos + (uint32_t)(i) + src;
39  else
40  dest = src - (now_pos + (uint32_t)(i));
41 
42  dest >>= 2;
43 
44  dest = (((0 - ((dest >> 22) & 1)) << 22) & 0x3FFFFFFF)
45  | (dest & 0x3FFFFF)
46  | 0x40000000;
47 
48  buffer[i + 0] = (uint8_t)(dest >> 24);
49  buffer[i + 1] = (uint8_t)(dest >> 16);
50  buffer[i + 2] = (uint8_t)(dest >> 8);
51  buffer[i + 3] = (uint8_t)(dest);
52  }
53  }
54 
55  return i;
56 }
57 
58 
59 static lzma_ret
61  const lzma_filter_info *filters, bool is_encoder)
62 {
64  &sparc_code, 0, 4, 4, is_encoder);
65 }
66 
67 
68 extern lzma_ret
72 {
73  return sparc_coder_init(next, allocator, filters, true);
74 }
75 
76 
77 extern lzma_ret
81 {
82  return sparc_coder_init(next, allocator, filters, false);
83 }
lzma_index ** i
Definition: index.h:629
lzma_index * src
Definition: index.h:567
const lzma_allocator * allocator
Definition: block.h:377
const lzma_filter * filters
Definition: container.h:315
voidpf void uLong size
Definition: ioapi.h:138
char * dest
Definition: lz4.h:697
#define lzma_attribute(attr)
Definition: lzma.h:259
unsigned int uint32_t
Definition: sftypes.h:29
unsigned char uint8_t
Definition: sftypes.h:31
lzma_ret lzma_simple_coder_init(lzma_next_coder *next, const lzma_allocator *allocator, const lzma_filter_info *filters, size_t(*filter)(void *simple, uint32_t now_pos, bool is_encoder, uint8_t *buffer, size_t size), size_t simple_size, size_t unfiltered_max, uint32_t alignment, bool is_encoder)
Definition: simple_coder.c:235
Private definitions for so called simple filters.
lzma_ret lzma_simple_sparc_encoder_init(lzma_next_coder *next, const lzma_allocator *allocator, const lzma_filter_info *filters)
Definition: sparc.c:69
static lzma_ret sparc_coder_init(lzma_next_coder *next, const lzma_allocator *allocator, const lzma_filter_info *filters, bool is_encoder)
Definition: sparc.c:60
lzma_ret lzma_simple_sparc_decoder_init(lzma_next_coder *next, const lzma_allocator *allocator, const lzma_filter_info *filters)
Definition: sparc.c:78
static size_t sparc_code(void *simple lzma_attribute((__unused__)), uint32_t now_pos, bool is_encoder, uint8_t *buffer, size_t size)
Definition: sparc.c:18
Definition: buffer.h:15
Custom functions for memory handling.
Definition: base.h:372
Hold data and function pointers of the next filter in the chain.
Definition: common.h:135
lzma_ret
Return values used by several functions in liblzma.
Definition: base.h:57