1 /* $NetBSD: cd9660_eltorito.h,v 1.5 2009/07/04 14:31:38 ahoka Exp $ */
4 * Copyright (c) 2005 Daniel Watt, Walter Deignan, Ryan Gabrys, Alan
5 * Perez-Rathke and Ram Vedam. All rights reserved.
7 * This code was written by Daniel Watt, Walter Deignan, Ryan Gabrys,
8 * Alan Perez-Rathke and Ram Vedam.
10 * Redistribution and use in source and binary forms, with or
11 * without modification, are permitted provided that the following
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above
16 * copyright notice, this list of conditions and the following
17 * disclaimer in the documentation and/or other materials provided
18 * with the distribution.
20 * THIS SOFTWARE IS PROVIDED BY DANIEL WATT, WALTER DEIGNAN, RYAN
21 * GABRYS, ALAN PEREZ-RATHKE AND RAM VEDAM ``AS IS'' AND ANY EXPRESS OR
22 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
24 * DISCLAIMED. IN NO EVENT SHALL DANIEL WATT, WALTER DEIGNAN, RYAN
25 * GABRYS, ALAN PEREZ-RATHKE AND RAM VEDAM BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
27 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
28 * USE,DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
29 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
35 #ifndef _CD9660_ELTORITO_H_
36 #define _CD9660_ELTORITO_H_
39 #define ET_ID "EL TORITO SPECIFICATION"
44 #define ET_BOOT_ENTRY_SIZE 0x20
46 #define ET_BOOTABLE 0x88
47 #define ET_NOT_BOOTABLE 0
49 #define ET_MEDIA_NOEM 0
50 #define ET_MEDIA_12FDD 1
51 #define ET_MEDIA_144FDD 2
52 #define ET_MEDIA_288FDD 3
53 #define ET_MEDIA_HDD 4
55 #define ET_INDICATOR_HEADERMORE 0x90
56 #define ET_INDICATOR_HEADERLAST 0x91
57 #define ET_INDICATOR_EXTENSION 0x44
59 /*** Boot Structures ***/
61 typedef struct _boot_volume_descriptor
{
62 u_char boot_record_indicator
[ISODCL(0x00,0x00)];
63 u_char identifier
[ISODCL(0x01,0x05)];
64 u_char version
[ISODCL(0x06,0x06)];
65 u_char boot_system_identifier
[ISODCL(0x07,0x26)];
66 u_char unused1
[ISODCL(0x27,0x46)];
67 u_char boot_catalog_pointer
[ISODCL(0x47,0x4A)];
68 u_char unused2
[ISODCL(0x4B,0x7FF)];
69 } boot_volume_descriptor
;
71 typedef struct _boot_catalog_validation_entry
{
72 u_char header_id
[ISODCL(0x00,0x00)];
73 u_char platform_id
[ISODCL(0x01,0x01)];
74 u_char reserved1
[ISODCL(0x02,0x03)];
75 u_char manufacturer
[ISODCL(0x04,0x1B)];
76 u_char checksum
[ISODCL(0x1C,0x1D)];
77 u_char key
[ISODCL(0x1E,0x1F)];
78 } boot_catalog_validation_entry
;
80 typedef struct _boot_catalog_initial_entry
{
81 u_char boot_indicator
[ISODCL(0x00,0x00)];
82 u_char media_type
[ISODCL(0x01,0x01)];
83 u_char load_segment
[ISODCL(0x02,0x03)];
84 u_char system_type
[ISODCL(0x04,0x04)];
85 u_char unused_1
[ISODCL(0x05,0x05)];
86 u_char sector_count
[ISODCL(0x06,0x07)];
87 u_char load_rba
[ISODCL(0x08,0x0B)];
88 u_char unused_2
[ISODCL(0x0C,0x1F)];
89 } boot_catalog_initial_entry
;
91 #define ET_SECTION_HEADER_MORE 0x90
92 #define ET_SECTION_HEADER_LAST 0x91
94 typedef struct _boot_catalog_section_header
{
95 u_char header_indicator
[ISODCL(0x00,0x00)];
96 u_char platform_id
[ISODCL(0x01,0x01)];
97 u_char num_section_entries
[ISODCL(0x02,0x03)];
98 u_char id_string
[ISODCL(0x04,0x1F)];
99 } boot_catalog_section_header
;
101 typedef struct _boot_catalog_section_entry
{
102 u_char boot_indicator
[ISODCL(0x00,0x00)];
103 u_char media_type
[ISODCL(0x01,0x01)];
104 u_char load_segment
[ISODCL(0x02,0x03)];
105 u_char system_type
[ISODCL(0x04,0x04)];
106 u_char unused_1
[ISODCL(0x05,0x05)];
107 u_char sector_count
[ISODCL(0x06,0x07)];
108 u_char load_rba
[ISODCL(0x08,0x0B)];
109 u_char selection_criteria
[ISODCL(0x0C,0x0C)];
110 u_char vendor_criteria
[ISODCL(0x0D,0x1F)];
111 } boot_catalog_section_entry
;
113 typedef struct _boot_catalog_section_entry_extension
{
114 u_char extension_indicator
[ISODCL(0x00,0x00)];
115 u_char flags
[ISODCL(0x01,0x01)];
116 u_char vendor_criteria
[ISODCL(0x02,0x1F)];
117 } boot_catalog_section_entry_extension
;
119 #define ET_ENTRY_VE 1
120 #define ET_ENTRY_IE 2
121 #define ET_ENTRY_SH 3
122 #define ET_ENTRY_SE 4
123 #define ET_ENTRY_EX 5
125 struct boot_catalog_entry
{
128 boot_catalog_validation_entry VE
;
129 boot_catalog_initial_entry IE
;
130 boot_catalog_section_header SH
;
131 boot_catalog_section_entry SE
;
132 boot_catalog_section_entry_extension EX
;
135 LIST_ENTRY(boot_catalog_entry
) ll_struct
;
138 /* Temporary structure */
139 struct cd9660_boot_image
{
142 int sector
; /* copied to LoadRBA */
144 unsigned int loadSegment
;
149 * If the boot image exists in the filesystem
150 * already, this is a pointer to that node. For the sake
151 * of simplicity in future versions, this pointer is only
152 * to the node in the primary volume. This SHOULD be done
153 * via a hashtable lookup.
155 struct _cd9660node
*boot_image_node
;
156 TAILQ_ENTRY(cd9660_boot_image
) image_list
;
161 #endif /* _CD9660_ELTORITO_H_ */