xref: /dflybsd-src/contrib/xz/src/liblzma/simple/arm.c (revision b5feb3da7c498482b19d14ac6f2b1901005f7d94)
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