1*f80ad8b4SAndroid Build Coastguard Worker /* SPDX-License-Identifier: GPL-1.0+ WITH Linux-syscall-note */ 2*f80ad8b4SAndroid Build Coastguard Worker /* 3*f80ad8b4SAndroid Build Coastguard Worker * Copyright 1993 by Theodore Ts'o. 4*f80ad8b4SAndroid Build Coastguard Worker */ 5*f80ad8b4SAndroid Build Coastguard Worker #ifndef _UAPI_LINUX_LOOP_H 6*f80ad8b4SAndroid Build Coastguard Worker #define _UAPI_LINUX_LOOP_H 7*f80ad8b4SAndroid Build Coastguard Worker 8*f80ad8b4SAndroid Build Coastguard Worker 9*f80ad8b4SAndroid Build Coastguard Worker #define LO_NAME_SIZE 64 10*f80ad8b4SAndroid Build Coastguard Worker #define LO_KEY_SIZE 32 11*f80ad8b4SAndroid Build Coastguard Worker 12*f80ad8b4SAndroid Build Coastguard Worker 13*f80ad8b4SAndroid Build Coastguard Worker /* 14*f80ad8b4SAndroid Build Coastguard Worker * Loop flags 15*f80ad8b4SAndroid Build Coastguard Worker */ 16*f80ad8b4SAndroid Build Coastguard Worker enum { 17*f80ad8b4SAndroid Build Coastguard Worker LO_FLAGS_READ_ONLY = 1, 18*f80ad8b4SAndroid Build Coastguard Worker LO_FLAGS_AUTOCLEAR = 4, 19*f80ad8b4SAndroid Build Coastguard Worker LO_FLAGS_PARTSCAN = 8, 20*f80ad8b4SAndroid Build Coastguard Worker LO_FLAGS_DIRECT_IO = 16, 21*f80ad8b4SAndroid Build Coastguard Worker }; 22*f80ad8b4SAndroid Build Coastguard Worker 23*f80ad8b4SAndroid Build Coastguard Worker /* LO_FLAGS that can be set using LOOP_SET_STATUS(64) */ 24*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_STATUS_SETTABLE_FLAGS (LO_FLAGS_AUTOCLEAR | LO_FLAGS_PARTSCAN) 25*f80ad8b4SAndroid Build Coastguard Worker 26*f80ad8b4SAndroid Build Coastguard Worker /* LO_FLAGS that can be cleared using LOOP_SET_STATUS(64) */ 27*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_STATUS_CLEARABLE_FLAGS (LO_FLAGS_AUTOCLEAR) 28*f80ad8b4SAndroid Build Coastguard Worker 29*f80ad8b4SAndroid Build Coastguard Worker /* LO_FLAGS that can be set using LOOP_CONFIGURE */ 30*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CONFIGURE_SETTABLE_FLAGS (LO_FLAGS_READ_ONLY | LO_FLAGS_AUTOCLEAR \ 31*f80ad8b4SAndroid Build Coastguard Worker | LO_FLAGS_PARTSCAN | LO_FLAGS_DIRECT_IO) 32*f80ad8b4SAndroid Build Coastguard Worker 33*f80ad8b4SAndroid Build Coastguard Worker #include <asm/posix_types.h> /* for __kernel_old_dev_t */ 34*f80ad8b4SAndroid Build Coastguard Worker #include <linux/types.h> /* for __u64 */ 35*f80ad8b4SAndroid Build Coastguard Worker 36*f80ad8b4SAndroid Build Coastguard Worker /* Backwards compatibility version */ 37*f80ad8b4SAndroid Build Coastguard Worker struct loop_info { 38*f80ad8b4SAndroid Build Coastguard Worker int lo_number; /* ioctl r/o */ 39*f80ad8b4SAndroid Build Coastguard Worker __kernel_old_dev_t lo_device; /* ioctl r/o */ 40*f80ad8b4SAndroid Build Coastguard Worker unsigned long lo_inode; /* ioctl r/o */ 41*f80ad8b4SAndroid Build Coastguard Worker __kernel_old_dev_t lo_rdevice; /* ioctl r/o */ 42*f80ad8b4SAndroid Build Coastguard Worker int lo_offset; 43*f80ad8b4SAndroid Build Coastguard Worker int lo_encrypt_type; /* obsolete, ignored */ 44*f80ad8b4SAndroid Build Coastguard Worker int lo_encrypt_key_size; /* ioctl w/o */ 45*f80ad8b4SAndroid Build Coastguard Worker int lo_flags; 46*f80ad8b4SAndroid Build Coastguard Worker char lo_name[LO_NAME_SIZE]; 47*f80ad8b4SAndroid Build Coastguard Worker unsigned char lo_encrypt_key[LO_KEY_SIZE]; /* ioctl w/o */ 48*f80ad8b4SAndroid Build Coastguard Worker unsigned long lo_init[2]; 49*f80ad8b4SAndroid Build Coastguard Worker char reserved[4]; 50*f80ad8b4SAndroid Build Coastguard Worker }; 51*f80ad8b4SAndroid Build Coastguard Worker 52*f80ad8b4SAndroid Build Coastguard Worker struct loop_info64 { 53*f80ad8b4SAndroid Build Coastguard Worker __u64 lo_device; /* ioctl r/o */ 54*f80ad8b4SAndroid Build Coastguard Worker __u64 lo_inode; /* ioctl r/o */ 55*f80ad8b4SAndroid Build Coastguard Worker __u64 lo_rdevice; /* ioctl r/o */ 56*f80ad8b4SAndroid Build Coastguard Worker __u64 lo_offset; 57*f80ad8b4SAndroid Build Coastguard Worker __u64 lo_sizelimit;/* bytes, 0 == max available */ 58*f80ad8b4SAndroid Build Coastguard Worker __u32 lo_number; /* ioctl r/o */ 59*f80ad8b4SAndroid Build Coastguard Worker __u32 lo_encrypt_type; /* obsolete, ignored */ 60*f80ad8b4SAndroid Build Coastguard Worker __u32 lo_encrypt_key_size; /* ioctl w/o */ 61*f80ad8b4SAndroid Build Coastguard Worker __u32 lo_flags; 62*f80ad8b4SAndroid Build Coastguard Worker __u8 lo_file_name[LO_NAME_SIZE]; 63*f80ad8b4SAndroid Build Coastguard Worker __u8 lo_crypt_name[LO_NAME_SIZE]; 64*f80ad8b4SAndroid Build Coastguard Worker __u8 lo_encrypt_key[LO_KEY_SIZE]; /* ioctl w/o */ 65*f80ad8b4SAndroid Build Coastguard Worker __u64 lo_init[2]; 66*f80ad8b4SAndroid Build Coastguard Worker }; 67*f80ad8b4SAndroid Build Coastguard Worker 68*f80ad8b4SAndroid Build Coastguard Worker /** 69*f80ad8b4SAndroid Build Coastguard Worker * struct loop_config - Complete configuration for a loop device. 70*f80ad8b4SAndroid Build Coastguard Worker * @fd: fd of the file to be used as a backing file for the loop device. 71*f80ad8b4SAndroid Build Coastguard Worker * @block_size: block size to use; ignored if 0. 72*f80ad8b4SAndroid Build Coastguard Worker * @info: struct loop_info64 to configure the loop device with. 73*f80ad8b4SAndroid Build Coastguard Worker * 74*f80ad8b4SAndroid Build Coastguard Worker * This structure is used with the LOOP_CONFIGURE ioctl, and can be used to 75*f80ad8b4SAndroid Build Coastguard Worker * atomically setup and configure all loop device parameters at once. 76*f80ad8b4SAndroid Build Coastguard Worker */ 77*f80ad8b4SAndroid Build Coastguard Worker struct loop_config { 78*f80ad8b4SAndroid Build Coastguard Worker __u32 fd; 79*f80ad8b4SAndroid Build Coastguard Worker __u32 block_size; 80*f80ad8b4SAndroid Build Coastguard Worker struct loop_info64 info; 81*f80ad8b4SAndroid Build Coastguard Worker __u64 __reserved[8]; 82*f80ad8b4SAndroid Build Coastguard Worker }; 83*f80ad8b4SAndroid Build Coastguard Worker 84*f80ad8b4SAndroid Build Coastguard Worker /* 85*f80ad8b4SAndroid Build Coastguard Worker * Loop filter types 86*f80ad8b4SAndroid Build Coastguard Worker */ 87*f80ad8b4SAndroid Build Coastguard Worker 88*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_NONE 0 89*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_XOR 1 90*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_DES 2 91*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_FISH2 3 /* Twofish encryption */ 92*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_BLOW 4 93*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_CAST128 5 94*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_IDEA 6 95*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_DUMMY 9 96*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_SKIPJACK 10 97*f80ad8b4SAndroid Build Coastguard Worker #define LO_CRYPT_CRYPTOAPI 18 98*f80ad8b4SAndroid Build Coastguard Worker #define MAX_LO_CRYPT 20 99*f80ad8b4SAndroid Build Coastguard Worker 100*f80ad8b4SAndroid Build Coastguard Worker /* 101*f80ad8b4SAndroid Build Coastguard Worker * IOCTL commands --- we will commandeer 0x4C ('L') 102*f80ad8b4SAndroid Build Coastguard Worker */ 103*f80ad8b4SAndroid Build Coastguard Worker 104*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_FD 0x4C00 105*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CLR_FD 0x4C01 106*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_STATUS 0x4C02 107*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_GET_STATUS 0x4C03 108*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_STATUS64 0x4C04 109*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_GET_STATUS64 0x4C05 110*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CHANGE_FD 0x4C06 111*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_CAPACITY 0x4C07 112*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_DIRECT_IO 0x4C08 113*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_SET_BLOCK_SIZE 0x4C09 114*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CONFIGURE 0x4C0A 115*f80ad8b4SAndroid Build Coastguard Worker 116*f80ad8b4SAndroid Build Coastguard Worker /* /dev/loop-control interface */ 117*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CTL_ADD 0x4C80 118*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CTL_REMOVE 0x4C81 119*f80ad8b4SAndroid Build Coastguard Worker #define LOOP_CTL_GET_FREE 0x4C82 120*f80ad8b4SAndroid Build Coastguard Worker #endif /* _UAPI_LINUX_LOOP_H */ 121