1e2be04c7SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-1.0+ WITH Linux-syscall-note */ 2607ca46eSDavid Howells /* 3607ca46eSDavid Howells * include/linux/loop.h 4607ca46eSDavid Howells * 5607ca46eSDavid Howells * Written by Theodore Ts'o, 3/29/93. 6607ca46eSDavid Howells * 7607ca46eSDavid Howells * Copyright 1993 by Theodore Ts'o. Redistribution of this file is 8607ca46eSDavid Howells * permitted under the GNU General Public License. 9607ca46eSDavid Howells */ 10607ca46eSDavid Howells #ifndef _UAPI_LINUX_LOOP_H 11607ca46eSDavid Howells #define _UAPI_LINUX_LOOP_H 12607ca46eSDavid Howells 13607ca46eSDavid Howells 14607ca46eSDavid Howells #define LO_NAME_SIZE 64 15607ca46eSDavid Howells #define LO_KEY_SIZE 32 16607ca46eSDavid Howells 17607ca46eSDavid Howells 18607ca46eSDavid Howells /* 19607ca46eSDavid Howells * Loop flags 20607ca46eSDavid Howells */ 21607ca46eSDavid Howells enum { 22607ca46eSDavid Howells LO_FLAGS_READ_ONLY = 1, 23607ca46eSDavid Howells LO_FLAGS_AUTOCLEAR = 4, 24607ca46eSDavid Howells LO_FLAGS_PARTSCAN = 8, 252e5ab5f3SMing Lei LO_FLAGS_DIRECT_IO = 16, 26607ca46eSDavid Howells }; 27607ca46eSDavid Howells 28faf1d254SMartijn Coenen /* LO_FLAGS that can be set using LOOP_SET_STATUS(64) */ 29faf1d254SMartijn Coenen #define LOOP_SET_STATUS_SETTABLE_FLAGS (LO_FLAGS_AUTOCLEAR | LO_FLAGS_PARTSCAN) 30faf1d254SMartijn Coenen 31faf1d254SMartijn Coenen /* LO_FLAGS that can be cleared using LOOP_SET_STATUS(64) */ 32faf1d254SMartijn Coenen #define LOOP_SET_STATUS_CLEARABLE_FLAGS (LO_FLAGS_AUTOCLEAR) 33faf1d254SMartijn Coenen 343448914eSMartijn Coenen /* LO_FLAGS that can be set using LOOP_CONFIGURE */ 353448914eSMartijn Coenen #define LOOP_CONFIGURE_SETTABLE_FLAGS (LO_FLAGS_READ_ONLY | LO_FLAGS_AUTOCLEAR \ 363448914eSMartijn Coenen | LO_FLAGS_PARTSCAN | LO_FLAGS_DIRECT_IO) 373448914eSMartijn Coenen 38607ca46eSDavid Howells #include <asm/posix_types.h> /* for __kernel_old_dev_t */ 39607ca46eSDavid Howells #include <linux/types.h> /* for __u64 */ 40607ca46eSDavid Howells 41607ca46eSDavid Howells /* Backwards compatibility version */ 42607ca46eSDavid Howells struct loop_info { 43607ca46eSDavid Howells int lo_number; /* ioctl r/o */ 44607ca46eSDavid Howells __kernel_old_dev_t lo_device; /* ioctl r/o */ 45607ca46eSDavid Howells unsigned long lo_inode; /* ioctl r/o */ 46607ca46eSDavid Howells __kernel_old_dev_t lo_rdevice; /* ioctl r/o */ 47607ca46eSDavid Howells int lo_offset; 48607ca46eSDavid Howells int lo_encrypt_type; 49607ca46eSDavid Howells int lo_encrypt_key_size; /* ioctl w/o */ 50faf1d254SMartijn Coenen int lo_flags; 51607ca46eSDavid Howells char lo_name[LO_NAME_SIZE]; 52607ca46eSDavid Howells unsigned char lo_encrypt_key[LO_KEY_SIZE]; /* ioctl w/o */ 53607ca46eSDavid Howells unsigned long lo_init[2]; 54607ca46eSDavid Howells char reserved[4]; 55607ca46eSDavid Howells }; 56607ca46eSDavid Howells 57607ca46eSDavid Howells struct loop_info64 { 58607ca46eSDavid Howells __u64 lo_device; /* ioctl r/o */ 59607ca46eSDavid Howells __u64 lo_inode; /* ioctl r/o */ 60607ca46eSDavid Howells __u64 lo_rdevice; /* ioctl r/o */ 61607ca46eSDavid Howells __u64 lo_offset; 62607ca46eSDavid Howells __u64 lo_sizelimit;/* bytes, 0 == max available */ 63607ca46eSDavid Howells __u32 lo_number; /* ioctl r/o */ 64607ca46eSDavid Howells __u32 lo_encrypt_type; 65607ca46eSDavid Howells __u32 lo_encrypt_key_size; /* ioctl w/o */ 66faf1d254SMartijn Coenen __u32 lo_flags; 67607ca46eSDavid Howells __u8 lo_file_name[LO_NAME_SIZE]; 68607ca46eSDavid Howells __u8 lo_crypt_name[LO_NAME_SIZE]; 69607ca46eSDavid Howells __u8 lo_encrypt_key[LO_KEY_SIZE]; /* ioctl w/o */ 70607ca46eSDavid Howells __u64 lo_init[2]; 71607ca46eSDavid Howells }; 72607ca46eSDavid Howells 733448914eSMartijn Coenen /** 743448914eSMartijn Coenen * struct loop_config - Complete configuration for a loop device. 753448914eSMartijn Coenen * @fd: fd of the file to be used as a backing file for the loop device. 763448914eSMartijn Coenen * @block_size: block size to use; ignored if 0. 773448914eSMartijn Coenen * @info: struct loop_info64 to configure the loop device with. 783448914eSMartijn Coenen * 793448914eSMartijn Coenen * This structure is used with the LOOP_CONFIGURE ioctl, and can be used to 803448914eSMartijn Coenen * atomically setup and configure all loop device parameters at once. 813448914eSMartijn Coenen */ 823448914eSMartijn Coenen struct loop_config { 833448914eSMartijn Coenen __u32 fd; 843448914eSMartijn Coenen __u32 block_size; 853448914eSMartijn Coenen struct loop_info64 info; 863448914eSMartijn Coenen __u64 __reserved[8]; 873448914eSMartijn Coenen }; 883448914eSMartijn Coenen 89607ca46eSDavid Howells /* 90607ca46eSDavid Howells * Loop filter types 91607ca46eSDavid Howells */ 92607ca46eSDavid Howells 93607ca46eSDavid Howells #define LO_CRYPT_NONE 0 94607ca46eSDavid Howells #define LO_CRYPT_XOR 1 95607ca46eSDavid Howells #define LO_CRYPT_DES 2 96607ca46eSDavid Howells #define LO_CRYPT_FISH2 3 /* Twofish encryption */ 97607ca46eSDavid Howells #define LO_CRYPT_BLOW 4 98607ca46eSDavid Howells #define LO_CRYPT_CAST128 5 99607ca46eSDavid Howells #define LO_CRYPT_IDEA 6 100607ca46eSDavid Howells #define LO_CRYPT_DUMMY 9 101607ca46eSDavid Howells #define LO_CRYPT_SKIPJACK 10 102607ca46eSDavid Howells #define LO_CRYPT_CRYPTOAPI 18 103607ca46eSDavid Howells #define MAX_LO_CRYPT 20 104607ca46eSDavid Howells 105607ca46eSDavid Howells /* 106607ca46eSDavid Howells * IOCTL commands --- we will commandeer 0x4C ('L') 107607ca46eSDavid Howells */ 108607ca46eSDavid Howells 109607ca46eSDavid Howells #define LOOP_SET_FD 0x4C00 110607ca46eSDavid Howells #define LOOP_CLR_FD 0x4C01 111607ca46eSDavid Howells #define LOOP_SET_STATUS 0x4C02 112607ca46eSDavid Howells #define LOOP_GET_STATUS 0x4C03 113607ca46eSDavid Howells #define LOOP_SET_STATUS64 0x4C04 114607ca46eSDavid Howells #define LOOP_GET_STATUS64 0x4C05 115607ca46eSDavid Howells #define LOOP_CHANGE_FD 0x4C06 116607ca46eSDavid Howells #define LOOP_SET_CAPACITY 0x4C07 117ab1cb278SMing Lei #define LOOP_SET_DIRECT_IO 0x4C08 11889e4fdecSOmar Sandoval #define LOOP_SET_BLOCK_SIZE 0x4C09 1193448914eSMartijn Coenen #define LOOP_CONFIGURE 0x4C0A 120607ca46eSDavid Howells 121607ca46eSDavid Howells /* /dev/loop-control interface */ 122607ca46eSDavid Howells #define LOOP_CTL_ADD 0x4C80 123607ca46eSDavid Howells #define LOOP_CTL_REMOVE 0x4C81 124607ca46eSDavid Howells #define LOOP_CTL_GET_FREE 0x4C82 125607ca46eSDavid Howells #endif /* _UAPI_LINUX_LOOP_H */ 126