2 * QEMU ATAPI CD-ROM Emulator
4 * Copyright (c) 2006 Fabrice Bellard
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25 /* ??? Most of the ATAPI emulation is still in ide.c. It should be moved
28 #include "qemu-common.h"
29 #include "hw/scsi/scsi.h"
31 static void lba_to_msf(uint8_t *buf
, int lba
)
34 buf
[0] = (lba
/ 75) / 60;
35 buf
[1] = (lba
/ 75) % 60;
39 /* same toc as bochs. Return -1 if error or the toc length */
41 int cdrom_read_toc(int nb_sectors
, uint8_t *buf
, int msf
, int start_track
)
46 if (start_track
> 1 && start_track
!= 0xaa)
49 *q
++ = 1; /* first session */
50 *q
++ = 1; /* last session */
51 if (start_track
<= 1) {
52 *q
++ = 0; /* reserved */
53 *q
++ = 0x14; /* ADR, control */
54 *q
++ = 1; /* track number */
55 *q
++ = 0; /* reserved */
57 *q
++ = 0; /* reserved */
62 cpu_to_be32wu((uint32_t *)q
, 0);
67 *q
++ = 0; /* reserved */
68 *q
++ = 0x16; /* ADR, control */
69 *q
++ = 0xaa; /* track number */
70 *q
++ = 0; /* reserved */
72 *q
++ = 0; /* reserved */
73 lba_to_msf(q
, nb_sectors
);
76 cpu_to_be32wu((uint32_t *)q
, nb_sectors
);
80 cpu_to_be16wu((uint16_t *)buf
, len
- 2);
84 /* mostly same info as PearPc */
85 int cdrom_read_toc_raw(int nb_sectors
, uint8_t *buf
, int msf
, int session_num
)
91 *q
++ = 1; /* first session */
92 *q
++ = 1; /* last session */
94 *q
++ = 1; /* session number */
95 *q
++ = 0x14; /* data track */
96 *q
++ = 0; /* track number */
97 *q
++ = 0xa0; /* lead-in */
100 *q
++ = 0; /* frame */
102 *q
++ = 1; /* first track */
103 *q
++ = 0x00; /* disk type */
106 *q
++ = 1; /* session number */
107 *q
++ = 0x14; /* data track */
108 *q
++ = 0; /* track number */
112 *q
++ = 0; /* frame */
114 *q
++ = 1; /* last track */
118 *q
++ = 1; /* session number */
119 *q
++ = 0x14; /* data track */
120 *q
++ = 0; /* track number */
121 *q
++ = 0xa2; /* lead-out */
124 *q
++ = 0; /* frame */
126 *q
++ = 0; /* reserved */
127 lba_to_msf(q
, nb_sectors
);
130 cpu_to_be32wu((uint32_t *)q
, nb_sectors
);
134 *q
++ = 1; /* session number */
135 *q
++ = 0x14; /* ADR, control */
136 *q
++ = 0; /* track number */
137 *q
++ = 1; /* point */
140 *q
++ = 0; /* frame */
153 cpu_to_be16wu((uint16_t *)buf
, len
- 2);