1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
$NetBSD: patch-ag,v 1.1.1.1 2004/07/26 18:23:25 dillo Exp $
--- src/gens/util/chd.h.orig 2004-06-25 19:55:16.000000000 +0200
+++ src/gens/util/chd.h
@@ -0,0 +1,94 @@
+#ifndef HAD_CHD_H
+
+/*
+ NiH: chd.h,v 1.3 2004/06/25 23:31:08 dillo Exp
+
+ chd.h -- accessing chd files
+ Copyright (C) 2004 Dieter Baron and Thomas Klausner
+
+ This file is part of ckmame, a program to check rom sets for MAME.
+ The authors can be contacted at <nih@giga.or.at>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License, version 2, as
+ published by the Free Software Foundation.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include <stdio.h>
+#include <zlib.h>
+
+#define CHD_ERR_NONE 0 /* N no error */
+#define CHD_ERR_OPEN 1 /* S cannot open file */
+#define CHD_ERR_READ 2 /* S read error */
+#define CHD_ERR_NO_CHD 3 /* N not a CHD file */
+#define CHD_ERR_VERSION 4 /* N unsupported version */
+#define CHD_ERR_INVAL 5 /* N invalid argument */
+#define CHD_ERR_SEEK 6 /* S seek error */
+#define CHD_ERR_NOTSUP 7 /* N unsupported chd feature */
+#define CHD_ERR_ZLIB 8 /* Z zlib error */
+#define CHD_ERR_CRC 9 /* N CRC mismatch */
+#define CHD_ERR_NOMEM 10 /* N out of memory */
+
+#define CHD_MAP_TYPE_COMPRESSED 0x01
+#define CHD_MAP_TYPE_UNCOMPRESSED 0x02
+#define CHD_MAP_TYPE_MINI 0x03
+#define CHD_MAP_TYPE_SELF_HUNK 0x04
+#define CHD_MAP_TYPE_PARENT_HUNK 0x05
+#define CHD_MAP_TYPE_MASK 0x0f
+#define CHD_MAP_FL_NOCRC 0x10
+
+#define CHD_COMP_NONE 0x0
+#define CHD_COMP_ZLIB 0x1
+#define CHD_COMP_ZLIB_PLUS 0x2
+
+
+
+struct chd_map_entry {
+ uint64_t offset; /* offse t within the file of the data */
+ uint32_t crc; /* 32-bit CRC of the data */
+ uint16_t length; /* length of the data */
+ uint16_t flags; /* misc flags */
+};
+
+struct chd {
+ FILE *f;
+ char *name;
+ int error;
+
+ uint32_t hdr_length; /* length of header data */
+ uint32_t version; /* drive format version */
+ uint32_t flags; /* flags field */
+ uint32_t compression; /* compression type */
+ uint32_t hunk_len; /* number of bytes per hunk */
+ uint32_t total_hunks; /* total # of hunks represented */
+ uint64_t total_len; /* logical size of the data */
+ uint64_t meta_offset; /* offset in file of first metadata */
+ uint8_t md5[16]; /* MD5 checksum of raw data */
+ uint8_t parent_md5[16]; /* MD5 checksum of parent file */
+ uint8_t sha1[20]; /* SHA1 checksum of raw data */
+ uint8_t parent_sha1[20]; /* SHA1 checksum of parent file */
+
+ struct chd_map_entry *map; /* hunk map */
+ char *buf; /* decompression buffer */
+ z_stream z; /* decompressor */
+ int hno; /* hunk currently in hbuf */
+ char *hbuf; /* hunk data buffer */
+};
+
+
+
+void chd_close(struct chd *);
+struct chd *chd_open(const char *, int *);
+int chd_read_hunk(struct chd *, int, char *);
+int chd_read_range(struct chd *, char *, int, int);
+
+#endif /* chd.h */
|