123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- /*************************************************************************
- *
- * enables user programs to display messages and control encryption
- * on s390 tape devices
- *
- * Copyright IBM Corp. 2001, 2006
- * Author(s): Michael Holzheu <holzheu@de.ibm.com>
- *
- *************************************************************************/
- #ifndef _TAPE390_H
- #define _TAPE390_H
- #define TAPE390_DISPLAY _IOW('d', 1, struct display_struct)
- /*
- * The TAPE390_DISPLAY ioctl calls the Load Display command
- * which transfers 17 bytes of data from the channel to the subsystem:
- * - 1 format control byte, and
- * - two 8-byte messages
- *
- * Format control byte:
- * 0-2: New Message Overlay
- * 3: Alternate Messages
- * 4: Blink Message
- * 5: Display Low/High Message
- * 6: Reserved
- * 7: Automatic Load Request
- *
- */
- typedef struct display_struct {
- char cntrl;
- char message1[8];
- char message2[8];
- } display_struct;
- /*
- * Tape encryption support
- */
- struct tape390_crypt_info {
- char capability;
- char status;
- char medium_status;
- } __attribute__ ((packed));
- /* Macros for "capable" field */
- #define TAPE390_CRYPT_SUPPORTED_MASK 0x01
- #define TAPE390_CRYPT_SUPPORTED(x) \
- ((x.capability & TAPE390_CRYPT_SUPPORTED_MASK))
- /* Macros for "status" field */
- #define TAPE390_CRYPT_ON_MASK 0x01
- #define TAPE390_CRYPT_ON(x) (((x.status) & TAPE390_CRYPT_ON_MASK))
- /* Macros for "medium status" field */
- #define TAPE390_MEDIUM_LOADED_MASK 0x01
- #define TAPE390_MEDIUM_ENCRYPTED_MASK 0x02
- #define TAPE390_MEDIUM_ENCRYPTED(x) \
- (((x.medium_status) & TAPE390_MEDIUM_ENCRYPTED_MASK))
- #define TAPE390_MEDIUM_LOADED(x) \
- (((x.medium_status) & TAPE390_MEDIUM_LOADED_MASK))
- /*
- * The TAPE390_CRYPT_SET ioctl is used to switch on/off encryption.
- * The "encryption_capable" and "tape_status" fields are ignored for this ioctl!
- */
- #define TAPE390_CRYPT_SET _IOW('d', 2, struct tape390_crypt_info)
- /*
- * The TAPE390_CRYPT_QUERY ioctl is used to query the encryption state.
- */
- #define TAPE390_CRYPT_QUERY _IOR('d', 3, struct tape390_crypt_info)
- /* Values for "kekl1/2_type" and "kekl1/2_type_on_tape" fields */
- #define TAPE390_KEKL_TYPE_NONE 0
- #define TAPE390_KEKL_TYPE_LABEL 1
- #define TAPE390_KEKL_TYPE_HASH 2
- struct tape390_kekl {
- unsigned char type;
- unsigned char type_on_tape;
- char label[65];
- } __attribute__ ((packed));
- struct tape390_kekl_pair {
- struct tape390_kekl kekl[2];
- } __attribute__ ((packed));
- /*
- * The TAPE390_KEKL_SET ioctl is used to set Key Encrypting Key labels.
- */
- #define TAPE390_KEKL_SET _IOW('d', 4, struct tape390_kekl_pair)
- /*
- * The TAPE390_KEKL_QUERY ioctl is used to query Key Encrypting Key labels.
- */
- #define TAPE390_KEKL_QUERY _IOR('d', 5, struct tape390_kekl_pair)
- #endif
|