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