1 #ifndef ISO9660_SUSP_H
2 #define ISO9660_SUSP_H 1
3 
4 /* Public functions of susp_rr.c, a reader for SUSP and Rock Ridge information.
5 */
6 
7 /*  Inspect the ISO 9660 filesystem whether it bears the signatures of
8     SUSP and Rock Ridge.
9     Set the parameters fs->fs_info->do_rr and fs->fs_info->susp_skip.
10     To be called at the end of iso_fs_init().
11 
12     SUSP demands an SP entry as first entry in the System Use area of
13     the first directory record in the root directory.
14     Rock Ridge prescribes at the same directory record an ER entry with
15     id field content "RRIP_1991A", or "IEEE_P1282", or "IEEE_1282".
16 
17     @param fs       The filesystem to inspect
18     @param flag     Bitfield for control purposes:
19                     bit0= Demand a Rock Ridge ER entry
20     @return         0 No valid SUSP signature found.
21                     1 Yes, signature of SUSP found. No ER was demanded.
22                     2 ER of RRIP 1.10 found.
23                     3 ER of RRIP 1.12 found.
24 */
25 int susp_rr_check_signatures(struct fs_info *fs, int flag);
26 
27 
28 /*  Obtain the payload bytes of all SUSP entries with the given signature.
29 
30     @param fs       The filesystem from which to read CE blocks.
31                     fs->fs_info->do_rr must be non-zero or else this function
32                     will always return 0 (i.e. no payload found).
33     @param dir_rec  Memory containing the whole ISO 9660 directory record.
34     @param sig      Two characters of SUSP signature. E.g. "NM", "ER", ...
35     @param data     Returns allocated memory with the payload.
36                     A trailing 0-byte is added for convenience with strings.
37                     If data is returned != NULL, then it has to be disposed
38                     by free() when it is no longer needed.
39     @param len_data Returns the number of valid bytes in *data.
40                     Not included in this count is the convenience 0-byte.
41     @param flag     Bitfield for control purposes:
42                     bit0= NM/SL mode:
43                           Skip 5 header bytes rather than 4.
44                           End after first matching entry without CONTINUE bit.
45                           Return 0x100 | byte[4] (FLAGS) of first entry.
46     @return         >0 Success.
47                        *data and *len_data are valid.
48                        Only in this case, *data is returned != NULL.
49                     0  Desired signature not found.
50                    -1  Error.
51                        Something is wrong with the ISO 9660 or SUSP data in
52                        the image.
53 */
54 int susp_rr_get_entries(struct fs_info *fs, char *dir_rec, char *sig,
55                         char **data, int *len_data, int flag);
56 
57 
58 /*  Obtain the Rock Ridge name of a directory record.
59     If the found content of NM entries is longer than 255 characters,
60     then this function will not return it, but rather indicate an error.
61 
62     @param fs       The filesystem from which to read CE blocks.
63                     fs->fs_info->do_rr must be non-zero or else this function
64                     will always return 0 (i.e. no Rock Ridge name found).
65     @param dir_rec  Memory containing the whole ISO 9660 directory record.
66     @param name     Returns allocated memory with the name and a trailing
67                     0-byte. name might contain any byte values.
68                     If name is returned != NULL, then it has to be disposed
69                     by free() when it is no longer needed.
70     @param len_name Returns the number of valid bytes in *name.
71                     Not included in this count is the 0-byte after the name.
72     @return         >0 Success.
73                        *name and *len_name are valid.
74                        Only in this case, *data is returned != NULL.
75                     0  No NM entry found. No Rock Ridge name defined.
76                    -1  Error.
77                        Something is wrong with the ISO 9660 or SUSP data in
78                        the image.
79 */
80 int susp_rr_get_nm(struct fs_info *fs, char *dir_rec,
81                    char **name, int *len_name);
82 
83 
84 #endif /* ! ISO9660_SUSP_H */
85