12940b44dSPeter Avalos ///////////////////////////////////////////////////////////////////////////////
22940b44dSPeter Avalos //
32940b44dSPeter Avalos /// \file arm.c
42940b44dSPeter Avalos /// \brief Filter for ARM binaries
52940b44dSPeter Avalos ///
62940b44dSPeter Avalos // Authors: Igor Pavlov
72940b44dSPeter Avalos // Lasse Collin
82940b44dSPeter Avalos //
92940b44dSPeter Avalos // This file has been put into the public domain.
102940b44dSPeter Avalos // You can do whatever you want with this file.
112940b44dSPeter Avalos //
122940b44dSPeter Avalos ///////////////////////////////////////////////////////////////////////////////
132940b44dSPeter Avalos
142940b44dSPeter Avalos #include "simple_private.h"
152940b44dSPeter Avalos
162940b44dSPeter Avalos
172940b44dSPeter Avalos static size_t
arm_code(void * simple lzma_attribute ((__unused__)),uint32_t now_pos,bool is_encoder,uint8_t * buffer,size_t size)1846a2189dSzrj arm_code(void *simple lzma_attribute((__unused__)),
192940b44dSPeter Avalos uint32_t now_pos, bool is_encoder,
202940b44dSPeter Avalos uint8_t *buffer, size_t size)
212940b44dSPeter Avalos {
222940b44dSPeter Avalos size_t i;
232940b44dSPeter Avalos for (i = 0; i + 4 <= size; i += 4) {
242940b44dSPeter Avalos if (buffer[i + 3] == 0xEB) {
25*e151908bSDaniel Fojt uint32_t src = ((uint32_t)(buffer[i + 2]) << 16)
26*e151908bSDaniel Fojt | ((uint32_t)(buffer[i + 1]) << 8)
27*e151908bSDaniel Fojt | (uint32_t)(buffer[i + 0]);
282940b44dSPeter Avalos src <<= 2;
292940b44dSPeter Avalos
302940b44dSPeter Avalos uint32_t dest;
312940b44dSPeter Avalos if (is_encoder)
322940b44dSPeter Avalos dest = now_pos + (uint32_t)(i) + 8 + src;
332940b44dSPeter Avalos else
342940b44dSPeter Avalos dest = src - (now_pos + (uint32_t)(i) + 8);
352940b44dSPeter Avalos
362940b44dSPeter Avalos dest >>= 2;
372940b44dSPeter Avalos buffer[i + 2] = (dest >> 16);
382940b44dSPeter Avalos buffer[i + 1] = (dest >> 8);
392940b44dSPeter Avalos buffer[i + 0] = dest;
402940b44dSPeter Avalos }
412940b44dSPeter Avalos }
422940b44dSPeter Avalos
432940b44dSPeter Avalos return i;
442940b44dSPeter Avalos }
452940b44dSPeter Avalos
462940b44dSPeter Avalos
472940b44dSPeter Avalos static lzma_ret
arm_coder_init(lzma_next_coder * next,const lzma_allocator * allocator,const lzma_filter_info * filters,bool is_encoder)4815ab8c86SJohn Marino arm_coder_init(lzma_next_coder *next, const lzma_allocator *allocator,
492940b44dSPeter Avalos const lzma_filter_info *filters, bool is_encoder)
502940b44dSPeter Avalos {
512940b44dSPeter Avalos return lzma_simple_coder_init(next, allocator, filters,
522940b44dSPeter Avalos &arm_code, 0, 4, 4, is_encoder);
532940b44dSPeter Avalos }
542940b44dSPeter Avalos
552940b44dSPeter Avalos
562940b44dSPeter Avalos extern lzma_ret
lzma_simple_arm_encoder_init(lzma_next_coder * next,const lzma_allocator * allocator,const lzma_filter_info * filters)5715ab8c86SJohn Marino lzma_simple_arm_encoder_init(lzma_next_coder *next,
5815ab8c86SJohn Marino const lzma_allocator *allocator,
592940b44dSPeter Avalos const lzma_filter_info *filters)
602940b44dSPeter Avalos {
612940b44dSPeter Avalos return arm_coder_init(next, allocator, filters, true);
622940b44dSPeter Avalos }
632940b44dSPeter Avalos
642940b44dSPeter Avalos
652940b44dSPeter Avalos extern lzma_ret
lzma_simple_arm_decoder_init(lzma_next_coder * next,const lzma_allocator * allocator,const lzma_filter_info * filters)6615ab8c86SJohn Marino lzma_simple_arm_decoder_init(lzma_next_coder *next,
6715ab8c86SJohn Marino const lzma_allocator *allocator,
682940b44dSPeter Avalos const lzma_filter_info *filters)
692940b44dSPeter Avalos {
702940b44dSPeter Avalos return arm_coder_init(next, allocator, filters, false);
712940b44dSPeter Avalos }
72