Skip to content

Commit 86dbb30

Browse files
committed
adding zlib test
1 parent fbc6dff commit 86dbb30

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

58 files changed

+23030
-0
lines changed

zlib/Makefile

+158
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,158 @@
1+
2+
ARMGNU ?= arm-none-eabi
3+
4+
COPS = -Wall -O2 -nostdlib -nostartfiles -ffreestanding
5+
6+
gcc : zlibtest.hex zlibtest.bin
7+
8+
all : gcc clang
9+
10+
clean :
11+
rm -f *.o
12+
rm -f *.bin
13+
rm -f *.hex
14+
rm -f *.elf
15+
rm -f *.list
16+
rm -f *.img
17+
rm -f *.bc
18+
rm -f *.opt.s
19+
20+
21+
GOBJLIST = vectors.o zlibtest.o uart.o compress.o deflate.o zutil.o adler32.o crc32.o trees.o inflate.o uncompr.o inftrees.o inffast.o
22+
23+
vectors.o : vectors.s
24+
$(ARMGNU)-as vectors.s -o vectors.o
25+
26+
zlibtest.o : zlibtest.c
27+
$(ARMGNU)-gcc $(COPS) -c zlibtest.c -o zlibtest.o
28+
29+
zlibtest.elf : memmap $(GOBJLIST)
30+
$(ARMGNU)-ld $(GOBJLIST) -T memmap -o zlibtest.elf
31+
$(ARMGNU)-objdump -D zlibtest.elf > zlibtest.list
32+
33+
zlibtest.bin : zlibtest.elf
34+
$(ARMGNU)-objcopy zlibtest.elf -O binary zlibtest.bin
35+
36+
zlibtest.hex : zlibtest.elf
37+
$(ARMGNU)-objcopy zlibtest.elf -O ihex zlibtest.hex
38+
39+
40+
uart.o : uart.c
41+
$(ARMGNU)-gcc $(COPS) -c uart.c -o uart.o
42+
43+
compress.o : compress.c
44+
$(ARMGNU)-gcc $(COPS) -c compress.c -o compress.o
45+
46+
deflate.o : deflate.c
47+
$(ARMGNU)-gcc $(COPS) -c deflate.c -o deflate.o
48+
49+
zutil.o : zutil.c
50+
$(ARMGNU)-gcc $(COPS) -c zutil.c -o zutil.o
51+
52+
adler32.o : adler32.c
53+
$(ARMGNU)-gcc $(COPS) -c adler32.c -o adler32.o
54+
55+
crc32.o : crc32.c
56+
$(ARMGNU)-gcc $(COPS) -c crc32.c -o crc32.o
57+
58+
trees.o : trees.c
59+
$(ARMGNU)-gcc $(COPS) -c trees.c -o trees.o
60+
61+
inflate.o : inflate.c
62+
$(ARMGNU)-gcc $(COPS) -c inflate.c -o inflate.o
63+
64+
uncompr.o : uncompr.c
65+
$(ARMGNU)-gcc $(COPS) -c uncompr.c -o uncompr.o
66+
67+
inftrees.o : inftrees.c
68+
$(ARMGNU)-gcc $(COPS) -c inftrees.c -o inftrees.o
69+
70+
inffast.o : inffast.c
71+
$(ARMGNU)-gcc $(COPS) -c inffast.c -o inffast.o
72+
73+
74+
75+
76+
77+
LOPS = -Wall -m32 -emit-llvm
78+
LLCOPS = -mtriple=arm-none-eabi -march=arm -mcpu=arm1176jzf-s
79+
LLCOPS0 = -march=arm
80+
LLCOPS1 = -march=arm -mcpu=arm1176jzf-s
81+
COPS = -Wall -O2 -nostdlib -nostartfiles -ffreestanding
82+
OOPS = -std-compile-opts
83+
84+
clang : zlibtest.clang.hex zlibtest.clang.bin
85+
86+
COBJLIST = zlibtest.bc uart.bc compress.bc deflate.bc zutil.bc adler32.bc crc32.bc trees.bc inflate.bc uncompr.bc inftrees.bc inffast.bc
87+
88+
zlibtest.bc : zlibtest.c
89+
clang $(LOPS) -c zlibtest.c -o zlibtest.bc
90+
91+
uart.bc : uart.c
92+
clang $(LOPS) -c uart.c -o uart.bc
93+
94+
compress.bc : compress.c
95+
clang $(LOPS) -c compress.c -o compress.bc
96+
97+
deflate.bc : deflate.c
98+
clang $(LOPS) -c deflate.c -o deflate.bc
99+
100+
zutil.bc : zutil.c
101+
clang $(LOPS) -c zutil.c -o zutil.bc
102+
103+
adler32.bc : adler32.c
104+
clang $(LOPS) -c adler32.c -o adler32.bc
105+
106+
crc32.bc : crc32.c
107+
clang $(LOPS) -c crc32.c -o crc32.bc
108+
109+
trees.bc : trees.c
110+
clang $(LOPS) -c trees.c -o trees.bc
111+
112+
inflate.bc : inflate.c
113+
clang $(LOPS) -c inflate.c -o inflate.bc
114+
115+
uncompr.bc : uncompr.c
116+
clang $(LOPS) -c uncompr.c -o uncompr.bc
117+
118+
inftrees.bc : inftrees.c
119+
clang $(LOPS) -c inftrees.c -o inftrees.bc
120+
121+
inffast.bc : inffast.c
122+
clang $(LOPS) -c inffast.c -o inffast.bc
123+
124+
zlibtest.clang.bc : $(COBJLIST)
125+
llvm-link -o zlibtest.clang.bc $(COBJLIST)
126+
127+
zlibtest.clang.opt.elf : memmap vectors.o zlibtest.clang.bc
128+
opt $(OOPS) zlibtest.clang.bc -o zlibtest.clang.opt.bc
129+
llc $(LLCOPS) zlibtest.clang.opt.bc -o zlibtest.clang.opt.s
130+
$(ARMGNU)-as zlibtest.clang.opt.s -o zlibtest.clang.opt.o
131+
$(ARMGNU)-ld -o zlibtest.clang.opt.elf -T memmap vectors.o zlibtest.clang.opt.o
132+
$(ARMGNU)-objdump -D zlibtest.clang.opt.elf > zlibtest.clang.opt.list
133+
134+
zlibtest.clang.hex : zlibtest.clang.opt.elf
135+
$(ARMGNU)-objcopy zlibtest.clang.opt.elf zlibtest.clang.hex -O ihex
136+
137+
zlibtest.clang.bin : zlibtest.clang.opt.elf
138+
$(ARMGNU)-objcopy zlibtest.clang.opt.elf zlibtest.clang.bin -O binary
139+
140+
141+
142+
143+
144+
145+
146+
147+
148+
149+
150+
151+
152+
153+
154+
155+
156+
157+
158+

zlib/a.c

+38
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
2+
#include <stdio.h>
3+
#include <stdlib.h>
4+
#include <string.h>
5+
6+
FILE *fp;
7+
8+
unsigned char data[10000];
9+
10+
int main ( void )
11+
{
12+
unsigned int ra;
13+
14+
fp=fopen("twain.txt","rb");
15+
if(fp==NULL) return(1);
16+
fread(data,1,sizeof(data),fp);
17+
fclose(fp);
18+
19+
fp=fopen("testdata.h","wt");
20+
if(fp==NULL) return(1);
21+
fprintf(fp,"\n");
22+
fprintf(fp,"#define TESTDATALEN %u\n",(unsigned int)sizeof(data));
23+
fprintf(fp,"const unsigned char testdata[TESTDATALEN]=\n");
24+
fprintf(fp,"{");
25+
for(ra=0;ra<sizeof(data);ra++)
26+
{
27+
if((ra&15)==0) fprintf(fp,"\n");
28+
fprintf(fp,"0x%02X,",data[ra]);
29+
}
30+
fprintf(fp,"\n");
31+
fprintf(fp,"};");
32+
fprintf(fp,"\n");
33+
fclose(fp);
34+
35+
36+
return(0);
37+
}
38+

zlib/adler32.c

+179
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,179 @@
1+
/* adler32.c -- compute the Adler-32 checksum of a data stream
2+
* Copyright (C) 1995-2011 Mark Adler
3+
* For conditions of distribution and use, see copyright notice in zlib.h
4+
*/
5+
6+
/* @(#) $Id$ */
7+
8+
#include "zutil.h"
9+
10+
#define local static
11+
12+
local uInt adler32_combine_ OF((uInt adler1, uInt adler2, z_off64_t len2));
13+
14+
#define BASE 65521 /* largest prime smaller than 65536 */
15+
#define NMAX 5552
16+
/* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */
17+
18+
#define DO1(buf,i) {adler += (buf)[i]; sum2 += adler;}
19+
#define DO2(buf,i) DO1(buf,i); DO1(buf,i+1);
20+
#define DO4(buf,i) DO2(buf,i); DO2(buf,i+2);
21+
#define DO8(buf,i) DO4(buf,i); DO4(buf,i+4);
22+
#define DO16(buf) DO8(buf,0); DO8(buf,8);
23+
24+
/* use NO_DIVIDE if your processor does not do division in hardware --
25+
try it both ways to see which is faster */
26+
#ifdef NO_DIVIDE
27+
/* note that this assumes BASE is 65521, where 65536 % 65521 == 15
28+
(thank you to John Reiser for pointing this out) */
29+
# define CHOP(a) \
30+
do { \
31+
unsigned int tmp = a >> 16; \
32+
a &= 0xffffUL; \
33+
a += (tmp << 4) - tmp; \
34+
} while (0)
35+
# define MOD28(a) \
36+
do { \
37+
CHOP(a); \
38+
if (a >= BASE) a -= BASE; \
39+
} while (0)
40+
# define MOD(a) \
41+
do { \
42+
CHOP(a); \
43+
MOD28(a); \
44+
} while (0)
45+
# define MOD63(a) \
46+
do { /* this assumes a is not negative */ \
47+
z_off64_t tmp = a >> 32; \
48+
a &= 0xffffffffL; \
49+
a += (tmp << 8) - (tmp << 5) + tmp; \
50+
tmp = a >> 16; \
51+
a &= 0xffffL; \
52+
a += (tmp << 4) - tmp; \
53+
tmp = a >> 16; \
54+
a &= 0xffffL; \
55+
a += (tmp << 4) - tmp; \
56+
if (a >= BASE) a -= BASE; \
57+
} while (0)
58+
#else
59+
# define MOD(a) a %= BASE
60+
# define MOD28(a) a %= BASE
61+
# define MOD63(a) a %= BASE
62+
#endif
63+
64+
/* ========================================================================= */
65+
uInt ZEXPORT adler32(adler, buf, len)
66+
uInt adler;
67+
const Bytef *buf;
68+
uInt len;
69+
{
70+
unsigned int sum2;
71+
unsigned n;
72+
73+
/* split Adler-32 into component sums */
74+
sum2 = (adler >> 16) & 0xffff;
75+
adler &= 0xffff;
76+
77+
/* in case user likes doing a byte at a time, keep it fast */
78+
if (len == 1) {
79+
adler += buf[0];
80+
if (adler >= BASE)
81+
adler -= BASE;
82+
sum2 += adler;
83+
if (sum2 >= BASE)
84+
sum2 -= BASE;
85+
return adler | (sum2 << 16);
86+
}
87+
88+
/* initial Adler-32 value (deferred check for len == 1 speed) */
89+
if (buf == Z_NULL)
90+
return 1L;
91+
92+
/* in case short lengths are provided, keep it somewhat fast */
93+
if (len < 16) {
94+
while (len--) {
95+
adler += *buf++;
96+
sum2 += adler;
97+
}
98+
if (adler >= BASE)
99+
adler -= BASE;
100+
MOD28(sum2); /* only added so many BASE's */
101+
return adler | (sum2 << 16);
102+
}
103+
104+
/* do length NMAX blocks -- requires just one modulo operation */
105+
while (len >= NMAX) {
106+
len -= NMAX;
107+
n = NMAX / 16; /* NMAX is divisible by 16 */
108+
do {
109+
DO16(buf); /* 16 sums unrolled */
110+
buf += 16;
111+
} while (--n);
112+
MOD(adler);
113+
MOD(sum2);
114+
}
115+
116+
/* do remaining bytes (less than NMAX, still just one modulo) */
117+
if (len) { /* avoid modulos if none remaining */
118+
while (len >= 16) {
119+
len -= 16;
120+
DO16(buf);
121+
buf += 16;
122+
}
123+
while (len--) {
124+
adler += *buf++;
125+
sum2 += adler;
126+
}
127+
MOD(adler);
128+
MOD(sum2);
129+
}
130+
131+
/* return recombined sums */
132+
return adler | (sum2 << 16);
133+
}
134+
135+
/* ========================================================================= */
136+
local uInt adler32_combine_(adler1, adler2, len2)
137+
uInt adler1;
138+
uInt adler2;
139+
z_off64_t len2;
140+
{
141+
unsigned int sum1;
142+
unsigned int sum2;
143+
unsigned rem;
144+
145+
/* for negative len, return invalid adler32 as a clue for debugging */
146+
if (len2 < 0)
147+
return 0xffffffffUL;
148+
149+
/* the derivation of this formula is left as an exercise for the reader */
150+
MOD63(len2); /* assumes len2 >= 0 */
151+
rem = (unsigned)len2;
152+
sum1 = adler1 & 0xffff;
153+
sum2 = rem * sum1;
154+
MOD(sum2);
155+
sum1 += (adler2 & 0xffff) + BASE - 1;
156+
sum2 += ((adler1 >> 16) & 0xffff) + ((adler2 >> 16) & 0xffff) + BASE - rem;
157+
if (sum1 >= BASE) sum1 -= BASE;
158+
if (sum1 >= BASE) sum1 -= BASE;
159+
if (sum2 >= (BASE << 1)) sum2 -= (BASE << 1);
160+
if (sum2 >= BASE) sum2 -= BASE;
161+
return sum1 | (sum2 << 16);
162+
}
163+
164+
/* ========================================================================= */
165+
uInt ZEXPORT adler32_combine(adler1, adler2, len2)
166+
uInt adler1;
167+
uInt adler2;
168+
z_off_t len2;
169+
{
170+
return adler32_combine_(adler1, adler2, len2);
171+
}
172+
173+
uInt ZEXPORT adler32_combine64(adler1, adler2, len2)
174+
uInt adler1;
175+
uInt adler2;
176+
z_off64_t len2;
177+
{
178+
return adler32_combine_(adler1, adler2, len2);
179+
}

0 commit comments

Comments
 (0)