xref: /openbmc/linux/include/uapi/linux/pktcdvd.h (revision 1ac731c529cd4d6adbce134754b51ff7d822b145)
1*4b83e99eSJens Axboe /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2*4b83e99eSJens Axboe /*
3*4b83e99eSJens Axboe  * Copyright (C) 2000 Jens Axboe <axboe@suse.de>
4*4b83e99eSJens Axboe  * Copyright (C) 2001-2004 Peter Osterlund <petero2@telia.com>
5*4b83e99eSJens Axboe  *
6*4b83e99eSJens Axboe  * May be copied or modified under the terms of the GNU General Public
7*4b83e99eSJens Axboe  * License.  See linux/COPYING for more information.
8*4b83e99eSJens Axboe  *
9*4b83e99eSJens Axboe  * Packet writing layer for ATAPI and SCSI CD-R, CD-RW, DVD-R, and
10*4b83e99eSJens Axboe  * DVD-RW devices.
11*4b83e99eSJens Axboe  *
12*4b83e99eSJens Axboe  */
13*4b83e99eSJens Axboe #ifndef _UAPI__PKTCDVD_H
14*4b83e99eSJens Axboe #define _UAPI__PKTCDVD_H
15*4b83e99eSJens Axboe 
16*4b83e99eSJens Axboe #include <linux/types.h>
17*4b83e99eSJens Axboe 
18*4b83e99eSJens Axboe /*
19*4b83e99eSJens Axboe  * UNUSED:
20*4b83e99eSJens Axboe  * 1 for normal debug messages, 2 is very verbose. 0 to turn it off.
21*4b83e99eSJens Axboe  */
22*4b83e99eSJens Axboe #define PACKET_DEBUG		1
23*4b83e99eSJens Axboe 
24*4b83e99eSJens Axboe #define	MAX_WRITERS		8
25*4b83e99eSJens Axboe 
26*4b83e99eSJens Axboe #define PKT_RB_POOL_SIZE	512
27*4b83e99eSJens Axboe 
28*4b83e99eSJens Axboe /*
29*4b83e99eSJens Axboe  * How long we should hold a non-full packet before starting data gathering.
30*4b83e99eSJens Axboe  */
31*4b83e99eSJens Axboe #define PACKET_WAIT_TIME	(HZ * 5 / 1000)
32*4b83e99eSJens Axboe 
33*4b83e99eSJens Axboe /*
34*4b83e99eSJens Axboe  * No user-servicable parts beyond this point ->
35*4b83e99eSJens Axboe  */
36*4b83e99eSJens Axboe 
37*4b83e99eSJens Axboe /*
38*4b83e99eSJens Axboe  * device types
39*4b83e99eSJens Axboe  */
40*4b83e99eSJens Axboe #define PACKET_CDR		1
41*4b83e99eSJens Axboe #define	PACKET_CDRW		2
42*4b83e99eSJens Axboe #define PACKET_DVDR		3
43*4b83e99eSJens Axboe #define PACKET_DVDRW		4
44*4b83e99eSJens Axboe 
45*4b83e99eSJens Axboe /*
46*4b83e99eSJens Axboe  * flags
47*4b83e99eSJens Axboe  */
48*4b83e99eSJens Axboe #define PACKET_WRITABLE		1	/* pd is writable */
49*4b83e99eSJens Axboe #define PACKET_NWA_VALID	2	/* next writable address valid */
50*4b83e99eSJens Axboe #define PACKET_LRA_VALID	3	/* last recorded address valid */
51*4b83e99eSJens Axboe #define PACKET_MERGE_SEGS	4	/* perform segment merging to keep */
52*4b83e99eSJens Axboe 					/* underlying cdrom device happy */
53*4b83e99eSJens Axboe 
54*4b83e99eSJens Axboe /*
55*4b83e99eSJens Axboe  * Disc status -- from READ_DISC_INFO
56*4b83e99eSJens Axboe  */
57*4b83e99eSJens Axboe #define PACKET_DISC_EMPTY	0
58*4b83e99eSJens Axboe #define PACKET_DISC_INCOMPLETE	1
59*4b83e99eSJens Axboe #define PACKET_DISC_COMPLETE	2
60*4b83e99eSJens Axboe #define PACKET_DISC_OTHER	3
61*4b83e99eSJens Axboe 
62*4b83e99eSJens Axboe /*
63*4b83e99eSJens Axboe  * write type, and corresponding data block type
64*4b83e99eSJens Axboe  */
65*4b83e99eSJens Axboe #define PACKET_MODE1		1
66*4b83e99eSJens Axboe #define PACKET_MODE2		2
67*4b83e99eSJens Axboe #define PACKET_BLOCK_MODE1	8
68*4b83e99eSJens Axboe #define PACKET_BLOCK_MODE2	10
69*4b83e99eSJens Axboe 
70*4b83e99eSJens Axboe /*
71*4b83e99eSJens Axboe  * Last session/border status
72*4b83e99eSJens Axboe  */
73*4b83e99eSJens Axboe #define PACKET_SESSION_EMPTY		0
74*4b83e99eSJens Axboe #define PACKET_SESSION_INCOMPLETE	1
75*4b83e99eSJens Axboe #define PACKET_SESSION_RESERVED		2
76*4b83e99eSJens Axboe #define PACKET_SESSION_COMPLETE		3
77*4b83e99eSJens Axboe 
78*4b83e99eSJens Axboe #define PACKET_MCN			"4a656e734178626f65323030300000"
79*4b83e99eSJens Axboe 
80*4b83e99eSJens Axboe #undef PACKET_USE_LS
81*4b83e99eSJens Axboe 
82*4b83e99eSJens Axboe #define PKT_CTRL_CMD_SETUP	0
83*4b83e99eSJens Axboe #define PKT_CTRL_CMD_TEARDOWN	1
84*4b83e99eSJens Axboe #define PKT_CTRL_CMD_STATUS	2
85*4b83e99eSJens Axboe 
86*4b83e99eSJens Axboe struct pkt_ctrl_command {
87*4b83e99eSJens Axboe 	__u32 command;				/* in: Setup, teardown, status */
88*4b83e99eSJens Axboe 	__u32 dev_index;			/* in/out: Device index */
89*4b83e99eSJens Axboe 	__u32 dev;				/* in/out: Device nr for cdrw device */
90*4b83e99eSJens Axboe 	__u32 pkt_dev;				/* in/out: Device nr for packet device */
91*4b83e99eSJens Axboe 	__u32 num_devices;			/* out: Largest device index + 1 */
92*4b83e99eSJens Axboe 	__u32 padding;				/* Not used */
93*4b83e99eSJens Axboe };
94*4b83e99eSJens Axboe 
95*4b83e99eSJens Axboe /*
96*4b83e99eSJens Axboe  * packet ioctls
97*4b83e99eSJens Axboe  */
98*4b83e99eSJens Axboe #define PACKET_IOCTL_MAGIC	('X')
99*4b83e99eSJens Axboe #define PACKET_CTRL_CMD		_IOWR(PACKET_IOCTL_MAGIC, 1, struct pkt_ctrl_command)
100*4b83e99eSJens Axboe 
101*4b83e99eSJens Axboe 
102 #endif /* _UAPI__PKTCDVD_H */
103