From: cuz Date: Tue, 23 Sep 2003 20:11:39 +0000 (+0000) Subject: Make the stuff compile X-Git-Tag: V2.12.0~1326 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=03560318ef580dceac280582f9afecf94bc4f396;p=cc65 Make the stuff compile git-svn-id: svn://svn.cc65.org/cc65/trunk@2445 b7a2c559-68d2-44c3-8de9-860c34a00d81 --- diff --git a/libsrc/zlib/.cvsignore b/libsrc/zlib/.cvsignore new file mode 100644 index 000000000..9c9d53cbd --- /dev/null +++ b/libsrc/zlib/.cvsignore @@ -0,0 +1 @@ +uncompress.s diff --git a/libsrc/zlib/Makefile b/libsrc/zlib/Makefile new file mode 100644 index 000000000..85c5bc642 --- /dev/null +++ b/libsrc/zlib/Makefile @@ -0,0 +1,42 @@ +# +# Makefile for the zlib subdirectory of the cc65 runtime library +# + +.SUFFIXES: .o .s .c + +#-------------------------------------------------------------------------- +# Rules + +%.o: %.c + @$(CC) $(CFLAGS) $< + @$(AS) -g -o $@ $(AFLAGS) $(*).s + +%.o: %.s + @$(AS) -g -o $@ $(AFLAGS) $< + +#-------------------------------------------------------------------------- +# Object files + +C_OBJS = uncompress.o + + +S_OBJS = adler32.o \ + crc32.o \ + inflatemem.o + + +#-------------------------------------------------------------------------- +# Targets + +.PHONY: all clean zap + +all: $(C_OBJS) $(S_OBJS) + +clean: + @rm -f *~ + @rm -f $(C_OBJS:.o=.s) + @rm -f $(C_OBJS) + @rm -f $(S_OBJS) + +zap: clean + diff --git a/libsrc/zlib/adler32.s b/libsrc/zlib/adler32.s index bebfdc90c..bebe34dcf 100644 --- a/libsrc/zlib/adler32.s +++ b/libsrc/zlib/adler32.s @@ -1,85 +1,85 @@ -; -; Piotr Fusik, 18.11.2001 -; -; unsigned long __fastcall__ adler32 (unsigned long adler, unsigned char* buf, -; unsigned len); -; - - .export _adler32 - - .import incsp2, incsp4, popax, popeax - .importzp sreg, ptr1, ptr2, tmp1 - -BASE = 65521 ; largest prime smaller than 65536 - -_adler32: -; ptr2 = (len & 0xff) == 0 ? len : len + 0x100; - tay - beq @L1 - inx -@L1: sta ptr2 - stx ptr2+1 -; ptr1 = buf - jsr popax - sta ptr1 - stx ptr1+1 -; if (buf == NULL) return 1L; - ora ptr1+1 - beq @L0 -; s1 = adler & 0xFFFF; s2 = adler >> 16; - jsr popeax -; if (len == 0) return adler; - ldy ptr2 - bne @L2 - ldy ptr2+1 - beq @RET -@L2: ldy #0 -; s1 += *ptr++; if (s1 >= BASE) s1 -= BASE; -@L3: clc - adc (ptr1),y - bcc @L4 - inx - beq @L5 ; C flag is set -@L4: cpx #>BASE - bcc @L6 - cmp #= BASE) s2 -= BASE; - adc sreg ; C flag is clear - sta sreg - txa - adc sreg+1 - sta sreg+1 - bcs @L7 - cmp #>BASE - bcc @L8 - lda sreg - cmp #BASE - sta sreg+1 -@L8: lda tmp1 - iny - bne @L9 - inc ptr1+1 -@L9: dec ptr2 - bne @L3 - dec ptr2+1 - bne @L3 -; return (s2 << 16) | s1; -@RET: rts - -; return 1L -@L0: sta sreg - sta sreg+1 - lda #1 -; ignore adler - jmp incsp4 +; +; Piotr Fusik, 18.11.2001 +; +; unsigned long __fastcall__ adler32 (unsigned long adler, unsigned char* buf, +; unsigned len); +; + + .export _adler32 + + .import incsp2, incsp4, popax, popeax + .importzp sreg, ptr1, ptr2, tmp1 + +BASE = 65521 ; largest prime smaller than 65536 + +_adler32: +; ptr2 = (len & 0xff) == 0 ? len : len + 0x100; + tay + beq @L1 + inx +@L1: sta ptr2 + stx ptr2+1 +; ptr1 = buf + jsr popax + sta ptr1 + stx ptr1+1 +; if (buf == NULL) return 1L; + ora ptr1+1 + beq @L0 +; s1 = adler & 0xFFFF; s2 = adler >> 16; + jsr popeax +; if (len == 0) return adler; + ldy ptr2 + bne @L2 + ldy ptr2+1 + beq @RET +@L2: ldy #0 +; s1 += *ptr++; if (s1 >= BASE) s1 -= BASE; +@L3: clc + adc (ptr1),y + bcc @L4 + inx + beq @L5 ; C flag is set +@L4: cpx #>BASE + bcc @L6 + cmp #= BASE) s2 -= BASE; + adc sreg ; C flag is clear + sta sreg + txa + adc sreg+1 + sta sreg+1 + bcs @L7 + cmp #>BASE + bcc @L8 + lda sreg + cmp #BASE + sta sreg+1 +@L8: lda tmp1 + iny + bne @L9 + inc ptr1+1 +@L9: dec ptr2 + bne @L3 + dec ptr2+1 + bne @L3 +; return (s2 << 16) | s1; +@RET: rts + +; return 1L +@L0: sta sreg + sta sreg+1 + lda #1 +; ignore adler + jmp incsp4 diff --git a/libsrc/zlib/crc32.s b/libsrc/zlib/crc32.s index d47e92f10..61f64c3cf 100644 --- a/libsrc/zlib/crc32.s +++ b/libsrc/zlib/crc32.s @@ -1,134 +1,134 @@ -; -; Piotr Fusik, 14.11.2001 -; -; unsigned long __fastcall__ crc32 (unsigned long crc, unsigned char* buf, -; unsigned len); -; - - .export _crc32 - - .import compleax, incsp2, incsp4, popax, popeax - .importzp sreg, ptr1, ptr2, tmp1, tmp2 - -POLYNOMIAL = $EDB88320 - -make_table: - ldx #0 -@L1: lda #0 - sta tmp2 - sta sreg - sta sreg+1 - ldy #8 - txa -@L2: sta tmp1 - lsr a - bcc @L3 - lda sreg+1 - lsr a - eor #(POLYNOMIAL>>24)&$FF - sta sreg+1 - lda sreg - ror a - eor #(POLYNOMIAL>>16)&$FF - sta sreg - lda tmp2 - ror a - eor #(POLYNOMIAL>>8)&$FF - sta tmp2 - lda tmp1 - ror a - eor #POLYNOMIAL&$FF - bcs @L4 ; branch always -@L3: rol a - lsr sreg+1 - ror sreg - ror tmp2 - ror a -@L4: dey - bne @L2 - sta table_0,x - lda tmp2 - sta table_1,x - lda sreg - sta table_2,x - lda sreg+1 - sta table_3,x - inx - bne @L1 - inc table_initialised -RET: - rts - -_crc32: -; ptr2 = (len & 0xff) == 0 ? len : len + 0x100; - tay - beq @L1 - inx -@L1: sta ptr2 - stx ptr2+1 -; ptr1 = buf - jsr popax - sta ptr1 - stx ptr1+1 -; if (buf == NULL) return 0; - ora ptr1+1 - beq @L0 -; if (!tables_initialised) make_tables(); - lda table_initialised - bne @dont_make - jsr make_table -@dont_make: -; eax = crc - jsr popeax -; if (len == 0) return crc; - ldy ptr2 - bne @L2 - ldy ptr2+1 - beq RET -@L2: -; eax = ~crc - jsr compleax - stx tmp2 - ldy #0 -; crc = (crc >> 8) ^ table[(crc & 0xff) ^ *p++]; -@L3: eor (ptr1),y - tax - lda table_0,x - eor tmp2 - sta tmp1 - lda table_1,x - eor sreg - sta tmp2 - lda table_2,x - eor sreg+1 - sta sreg - lda table_3,x - sta sreg+1 - lda tmp1 - iny - bne @L4 - inc ptr1+1 -@L4: dec ptr2 - bne @L3 - dec ptr2+1 - bne @L3 - ldx tmp2 - jmp compleax - -; return 0L -@L0: sta sreg - sta sreg+1 -; ignore crc - jmp incsp4 - - .data -table_initialised: - .byte 0 - - .bss -table_0: .res 256 -table_1: .res 256 -table_2: .res 256 -table_3: .res 256 - - +; +; Piotr Fusik, 14.11.2001 +; +; unsigned long __fastcall__ crc32 (unsigned long crc, unsigned char* buf, +; unsigned len); +; + + .export _crc32 + + .import compleax, incsp2, incsp4, popax, popeax + .importzp sreg, ptr1, ptr2, tmp1, tmp2 + +POLYNOMIAL = $EDB88320 + +make_table: + ldx #0 +@L1: lda #0 + sta tmp2 + sta sreg + sta sreg+1 + ldy #8 + txa +@L2: sta tmp1 + lsr a + bcc @L3 + lda sreg+1 + lsr a + eor #(POLYNOMIAL>>24)&$FF + sta sreg+1 + lda sreg + ror a + eor #(POLYNOMIAL>>16)&$FF + sta sreg + lda tmp2 + ror a + eor #(POLYNOMIAL>>8)&$FF + sta tmp2 + lda tmp1 + ror a + eor #POLYNOMIAL&$FF + bcs @L4 ; branch always +@L3: rol a + lsr sreg+1 + ror sreg + ror tmp2 + ror a +@L4: dey + bne @L2 + sta table_0,x + lda tmp2 + sta table_1,x + lda sreg + sta table_2,x + lda sreg+1 + sta table_3,x + inx + bne @L1 + inc table_initialised +RET: + rts + +_crc32: +; ptr2 = (len & 0xff) == 0 ? len : len + 0x100; + tay + beq @L1 + inx +@L1: sta ptr2 + stx ptr2+1 +; ptr1 = buf + jsr popax + sta ptr1 + stx ptr1+1 +; if (buf == NULL) return 0; + ora ptr1+1 + beq @L0 +; if (!tables_initialised) make_tables(); + lda table_initialised + bne @dont_make + jsr make_table +@dont_make: +; eax = crc + jsr popeax +; if (len == 0) return crc; + ldy ptr2 + bne @L2 + ldy ptr2+1 + beq RET +@L2: +; eax = ~crc + jsr compleax + stx tmp2 + ldy #0 +; crc = (crc >> 8) ^ table[(crc & 0xff) ^ *p++]; +@L3: eor (ptr1),y + tax + lda table_0,x + eor tmp2 + sta tmp1 + lda table_1,x + eor sreg + sta tmp2 + lda table_2,x + eor sreg+1 + sta sreg + lda table_3,x + sta sreg+1 + lda tmp1 + iny + bne @L4 + inc ptr1+1 +@L4: dec ptr2 + bne @L3 + dec ptr2+1 + bne @L3 + ldx tmp2 + jmp compleax + +; return 0L +@L0: sta sreg + sta sreg+1 +; ignore crc + jmp incsp4 + + .data +table_initialised: + .byte 0 + + .bss +table_0: .res 256 +table_1: .res 256 +table_2: .res 256 +table_3: .res 256 + + diff --git a/libsrc/zlib/uncompress.c b/libsrc/zlib/uncompress.c index fb07ba43a..162158657 100644 --- a/libsrc/zlib/uncompress.c +++ b/libsrc/zlib/uncompress.c @@ -1,36 +1,36 @@ -/* - * uncompress.c - * - * Piotr Fusik, 18.11.2001 - */ - -#include - -int uncompress (char* dest, unsigned* destLen, - const char* source, unsigned sourceLen) -{ - unsigned len; - unsigned char* ptr; - unsigned long csum; - /* source[0]: Compression method and flags - bits 0 to 3: Compression method (must be Z_DEFLATED) - bits 4 to 7: Compression info (must be <= 7) - source[1]: Flags - bits 0 to 4: Check bits - bit 5: Preset dictionary (not supported, sorry) - bits 6 to 7: Compression level - */ - if ((source[0] & 0x8f) != Z_DEFLATED || source[1] & 0x20) - return Z_DATA_ERROR; - if ((((unsigned) source[0] << 8) | (unsigned char) source[1]) % 31) - return Z_DATA_ERROR; - *destLen = len = inflatemem(dest, source + 2); - ptr = (unsigned char*) source + sourceLen - 4; - csum = adler32(adler32(0L, Z_NULL, 0), dest, len); - if ((unsigned char) csum != ptr[3] - || (unsigned char) (csum >> 8) != ptr[2] - || (unsigned char) (csum >> 16) != ptr[1] - || (unsigned char) (csum >> 24) != ptr[0]) - return Z_DATA_ERROR; - return Z_OK; -} +/* + * uncompress.c + * + * Piotr Fusik, 18.11.2001 + */ + +#include + +int uncompress (char* dest, unsigned* destLen, + const char* source, unsigned sourceLen) +{ + unsigned len; + unsigned char* ptr; + unsigned long csum; + /* source[0]: Compression method and flags + bits 0 to 3: Compression method (must be Z_DEFLATED) + bits 4 to 7: Compression info (must be <= 7) + source[1]: Flags + bits 0 to 4: Check bits + bit 5: Preset dictionary (not supported, sorry) + bits 6 to 7: Compression level + */ + if ((source[0] & 0x8f) != Z_DEFLATED || source[1] & 0x20) + return Z_DATA_ERROR; + if ((((unsigned) source[0] << 8) | (unsigned char) source[1]) % 31) + return Z_DATA_ERROR; + *destLen = len = inflatemem(dest, source + 2); + ptr = (unsigned char*) source + sourceLen - 4; + csum = adler32(adler32(0L, Z_NULL, 0), dest, len); + if ((unsigned char) csum != ptr[3] + || (unsigned char) (csum >> 8) != ptr[2] + || (unsigned char) (csum >> 16) != ptr[1] + || (unsigned char) (csum >> 24) != ptr[0]) + return Z_DATA_ERROR; + return Z_OK; +}