golden hour
/usr/include/linux
⬆️ Go Up
Upload
File/Folder
Size
Actions
a.out.h
7.15 KB
Del
OK
acct.h
3.58 KB
Del
OK
adb.h
1.05 KB
Del
OK
adfs_fs.h
873 B
Del
OK
affs_hardblocks.h
1.45 KB
Del
OK
agpgart.h
3.83 KB
Del
OK
aio_abi.h
3.18 KB
Del
OK
apm_bios.h
3.46 KB
Del
OK
arcfb.h
150 B
Del
OK
atalk.h
960 B
Del
OK
atm.h
7.64 KB
Del
OK
atm_eni.h
585 B
Del
OK
atm_he.h
343 B
Del
OK
atm_idt77105.h
892 B
Del
OK
atm_nicstar.h
1.19 KB
Del
OK
atm_tcp.h
1.52 KB
Del
OK
atm_zatm.h
1.57 KB
Del
OK
atmapi.h
889 B
Del
OK
atmarp.h
1.2 KB
Del
OK
atmbr2684.h
3.13 KB
Del
OK
atmclip.h
513 B
Del
OK
atmdev.h
7.44 KB
Del
OK
atmioc.h
1.55 KB
Del
OK
atmlec.h
2.26 KB
Del
OK
atmmpc.h
4.07 KB
Del
OK
atmppp.h
576 B
Del
OK
atmsap.h
4.79 KB
Del
OK
atmsvc.h
1.75 KB
Del
OK
audit.h
17.83 KB
Del
OK
auto_fs.h
2.53 KB
Del
OK
auto_fs4.h
4.23 KB
Del
OK
auxvec.h
1.4 KB
Del
OK
ax25.h
2.7 KB
Del
OK
b1lli.h
1.62 KB
Del
OK
baycom.h
820 B
Del
OK
beancounter.h
2.38 KB
Del
OK
bfs_fs.h
1.79 KB
Del
OK
binfmts.h
565 B
Del
OK
blkpg.h
1.56 KB
Del
OK
blktrace_api.h
4.38 KB
Del
OK
bpqether.h
952 B
Del
OK
bsg.h
2.37 KB
Del
OK
bt-bmc.h
508 B
Del
OK
btrfs.h
25.07 KB
Del
OK
byteorder
-
Del
OK
caif
-
Del
OK
can
-
Del
OK
can.h
5.46 KB
Del
OK
capability.h
10.92 KB
Del
OK
capi.h
2.99 KB
Del
OK
cciss_defs.h
3.14 KB
Del
OK
cciss_ioctl.h
2.63 KB
Del
OK
cdrom.h
28.12 KB
Del
OK
cgroupstats.h
2.1 KB
Del
OK
chio.h
5.16 KB
Del
OK
cm4000_cs.h
1.68 KB
Del
OK
cn_proc.h
3.19 KB
Del
OK
coda.h
17.09 KB
Del
OK
coda_psdev.h
720 B
Del
OK
coff.h
12.12 KB
Del
OK
compat.h
9.63 KB
Del
OK
connector.h
2.14 KB
Del
OK
const.h
673 B
Del
OK
cramfs_fs.h
2.68 KB
Del
OK
cuda.h
842 B
Del
OK
cyclades.h
16.65 KB
Del
OK
cycx_cfm.h
2.86 KB
Del
OK
dcbnl.h
24.19 KB
Del
OK
dccp.h
6.22 KB
Del
OK
devlink.h
7.09 KB
Del
OK
dlm.h
2.43 KB
Del
OK
dlm_device.h
2.42 KB
Del
OK
dlm_netlink.h
1.04 KB
Del
OK
dlm_plock.h
831 B
Del
OK
dlmconstants.h
4.9 KB
Del
OK
dm-ioctl.h
10.55 KB
Del
OK
dm-log-userspace.h
14.82 KB
Del
OK
dn.h
4.42 KB
Del
OK
dqblk_xfs.h
8.72 KB
Del
OK
dvb
-
Del
OK
edd.h
5.41 KB
Del
OK
efs_fs_sb.h
2.11 KB
Del
OK
elf-em.h
1.83 KB
Del
OK
elf-fdpic.h
1.04 KB
Del
OK
elf.h
12.63 KB
Del
OK
elfcore.h
2.86 KB
Del
OK
errno.h
23 B
Del
OK
errqueue.h
1.1 KB
Del
OK
ethtool.h
68.76 KB
Del
OK
eventpoll.h
1.76 KB
Del
OK
fadvise.h
855 B
Del
OK
falloc.h
1.98 KB
Del
OK
fanotify.h
3.52 KB
Del
OK
fb.h
16 KB
Del
OK
fcntl.h
2.16 KB
Del
OK
fd.h
11.31 KB
Del
OK
fdreg.h
5.23 KB
Del
OK
fib_rules.h
1.57 KB
Del
OK
fiemap.h
2.65 KB
Del
OK
filter.h
3.53 KB
Del
OK
firewire-cdev.h
42.86 KB
Del
OK
firewire-constants.h
3.16 KB
Del
OK
flat.h
2.04 KB
Del
OK
fou.h
617 B
Del
OK
fs.h
9.84 KB
Del
OK
fsl_hypervisor.h
7.05 KB
Del
OK
fuse.h
16.22 KB
Del
OK
futex.h
4.81 KB
Del
OK
gameport.h
834 B
Del
OK
gen_stats.h
1.48 KB
Del
OK
genetlink.h
1.85 KB
Del
OK
gfs2_ondisk.h
12 KB
Del
OK
gigaset_dev.h
1.35 KB
Del
OK
hdlc
-
Del
OK
hdlc.h
574 B
Del
OK
hdlcdrv.h
2.78 KB
Del
OK
hdreg.h
22.11 KB
Del
OK
hid.h
1.79 KB
Del
OK
hiddev.h
6.13 KB
Del
OK
hidraw.h
1.41 KB
Del
OK
hpet.h
680 B
Del
OK
hsi
-
Del
OK
hw_breakpoint.h
679 B
Del
OK
hyperv.h
10.22 KB
Del
OK
hysdn_if.h
1.29 KB
Del
OK
i2c-dev.h
2.37 KB
Del
OK
i2c.h
6.61 KB
Del
OK
i2o-dev.h
11.22 KB
Del
OK
i8k.h
1.4 KB
Del
OK
icmp.h
2.82 KB
Del
OK
icmpv6.h
3.82 KB
Del
OK
if.h
9.36 KB
Del
OK
if_addr.h
1.7 KB
Del
OK
if_addrlabel.h
658 B
Del
OK
if_alg.h
816 B
Del
OK
if_arcnet.h
3.63 KB
Del
OK
if_arp.h
6.3 KB
Del
OK
if_bonding.h
4.11 KB
Del
OK
if_bridge.h
6.46 KB
Del
OK
if_cablemodem.h
922 B
Del
OK
if_eql.h
1.26 KB
Del
OK
if_ether.h
7.13 KB
Del
OK
if_fc.h
1.63 KB
Del
OK
if_fddi.h
3.6 KB
Del
OK
if_frad.h
2.89 KB
Del
OK
if_hippi.h
4.07 KB
Del
OK
if_infiniband.h
1.13 KB
Del
OK
if_link.h
19.1 KB
Del
OK
if_ltalk.h
147 B
Del
OK
if_macsec.h
5.42 KB
Del
OK
if_packet.h
7.15 KB
Del
OK
if_phonet.h
361 B
Del
OK
if_plip.h
596 B
Del
OK
if_ppp.h
29 B
Del
OK
if_pppol2tp.h
3.18 KB
Del
OK
if_pppox.h
4.64 KB
Del
OK
if_slip.h
809 B
Del
OK
if_team.h
2.48 KB
Del
OK
if_tun.h
3.77 KB
Del
OK
if_tunnel.h
3 KB
Del
OK
if_vlan.h
1.69 KB
Del
OK
if_x25.h
817 B
Del
OK
ife.h
288 B
Del
OK
igmp.h
2.88 KB
Del
OK
in.h
9.15 KB
Del
OK
in6.h
6.99 KB
Del
OK
in_route.h
873 B
Del
OK
inet_diag.h
3.23 KB
Del
OK
inotify.h
3.09 KB
Del
OK
input.h
32.47 KB
Del
OK
ioctl.h
100 B
Del
OK
ip.h
3.47 KB
Del
OK
ip6_tunnel.h
1.67 KB
Del
OK
ip_vs.h
12.71 KB
Del
OK
ipc.h
1.99 KB
Del
OK
ipmi.h
15.8 KB
Del
OK
ipmi_msgdefs.h
4.37 KB
Del
OK
ipsec.h
884 B
Del
OK
ipv6.h
3.25 KB
Del
OK
ipv6_route.h
1.69 KB
Del
OK
ipx.h
1.79 KB
Del
OK
irda.h
7.31 KB
Del
OK
irqnr.h
104 B
Del
OK
isdn
-
Del
OK
isdn.h
5.58 KB
Del
OK
isdn_divertif.h
1.11 KB
Del
OK
isdn_ppp.h
1.82 KB
Del
OK
isdnif.h
2.25 KB
Del
OK
iso_fs.h
6.29 KB
Del
OK
ivtv.h
2.89 KB
Del
OK
ivtvfb.h
1.12 KB
Del
OK
ixjuser.h
24.53 KB
Del
OK
jffs2.h
6.85 KB
Del
OK
joystick.h
3.5 KB
Del
OK
kd.h
6.04 KB
Del
OK
kdev_t.h
320 B
Del
OK
kernel-page-flags.h
767 B
Del
OK
kernel.h
375 B
Del
OK
kernelcapi.h
956 B
Del
OK
kexec.h
1.92 KB
Del
OK
keyboard.h
12.42 KB
Del
OK
keyctl.h
2.98 KB
Del
OK
kvm.h
33.97 KB
Del
OK
kvm_para.h
819 B
Del
OK
l2tp.h
4.98 KB
Del
OK
libc-compat.h
3.44 KB
Del
OK
limits.h
874 B
Del
OK
llc.h
2.98 KB
Del
OK
loop.h
2.31 KB
Del
OK
lp.h
3.72 KB
Del
OK
lwtunnel.h
839 B
Del
OK
magic.h
2.91 KB
Del
OK
major.h
4.48 KB
Del
OK
map_to_7segment.h
7.02 KB
Del
OK
matroxfb.h
1.37 KB
Del
OK
mdio.h
13.74 KB
Del
OK
media.h
3.5 KB
Del
OK
mei.h
4.62 KB
Del
OK
memfd.h
186 B
Del
OK
mempolicy.h
2.35 KB
Del
OK
meye.h
2.41 KB
Del
OK
mii.h
7.76 KB
Del
OK
minix_fs.h
2.01 KB
Del
OK
mman.h
230 B
Del
OK
mmc
-
Del
OK
mmtimer.h
2.01 KB
Del
OK
mpls.h
1.33 KB
Del
OK
mqueue.h
2.01 KB
Del
OK
mroute.h
4.12 KB
Del
OK
mroute6.h
4.08 KB
Del
OK
msdos_fs.h
6.28 KB
Del
OK
msg.h
2.55 KB
Del
OK
mtio.h
7.92 KB
Del
OK
n_r3964.h
2.29 KB
Del
OK
nbd.h
2.34 KB
Del
OK
ncp.h
4.94 KB
Del
OK
ncp_fs.h
3.27 KB
Del
OK
ncp_mount.h
2.06 KB
Del
OK
ncp_no.h
651 B
Del
OK
ndctl.h
8.79 KB
Del
OK
neighbour.h
4.17 KB
Del
OK
net.h
1.97 KB
Del
OK
net_dropmon.h
1.07 KB
Del
OK
net_namespace.h
609 B
Del
OK
net_tstamp.h
4.06 KB
Del
OK
netconf.h
423 B
Del
OK
netdevice.h
1.46 KB
Del
OK
netfilter
-
Del
OK
netfilter.h
1.56 KB
Del
OK
netfilter_arp
-
Del
OK
netfilter_arp.h
380 B
Del
OK
netfilter_bridge
-
Del
OK
netfilter_bridge.h
768 B
Del
OK
netfilter_decnet.h
1.83 KB
Del
OK
netfilter_ipv4
-
Del
OK
netfilter_ipv4.h
2.02 KB
Del
OK
netfilter_ipv6
-
Del
OK
netfilter_ipv6.h
2.04 KB
Del
OK
netlink.h
6.22 KB
Del
OK
netlink_diag.h
1.33 KB
Del
OK
netrom.h
744 B
Del
OK
nfc.h
7.72 KB
Del
OK
nfs.h
4.31 KB
Del
OK
nfs2.h
1.37 KB
Del
OK
nfs3.h
2.24 KB
Del
OK
nfs4.h
5.95 KB
Del
OK
nfs4_mount.h
1.83 KB
Del
OK
nfs_fs.h
1.51 KB
Del
OK
nfs_idmap.h
2.19 KB
Del
OK
nfs_mount.h
2.32 KB
Del
OK
nfsacl.h
605 B
Del
OK
nfsd
-
Del
OK
nl80211.h
226.29 KB
Del
OK
nubus.h
8.17 KB
Del
OK
nvme_ioctl.h
1.55 KB
Del
OK
nvram.h
469 B
Del
OK
omap3isp.h
20.19 KB
Del
OK
omapfb.h
5.72 KB
Del
OK
oom.h
448 B
Del
OK
openvswitch.h
31.79 KB
Del
OK
packet_diag.h
1.5 KB
Del
OK
param.h
78 B
Del
OK
parport.h
3.56 KB
Del
OK
patchkey.h
829 B
Del
OK
pci.h
1.29 KB
Del
OK
pci_regs.h
49.96 KB
Del
OK
perf_event.h
29.53 KB
Del
OK
personality.h
1.99 KB
Del
OK
pfkeyv2.h
9.91 KB
Del
OK
pg.h
2.23 KB
Del
OK
phantom.h
1.55 KB
Del
OK
phonet.h
4.51 KB
Del
OK
pkt_cls.h
11.51 KB
Del
OK
pkt_sched.h
19.75 KB
Del
OK
pktcdvd.h
2.56 KB
Del
OK
pmu.h
5.13 KB
Del
OK
poll.h
22 B
Del
OK
posix_types.h
1.01 KB
Del
OK
ppdev.h
3.07 KB
Del
OK
ppp-comp.h
2.41 KB
Del
OK
ppp-ioctl.h
5.29 KB
Del
OK
ppp_defs.h
4.93 KB
Del
OK
pps.h
4.06 KB
Del
OK
prctl.h
6.71 KB
Del
OK
psample.h
735 B
Del
OK
ptp_clock.h
4.69 KB
Del
OK
ptrace.h
3.2 KB
Del
OK
qnx4_fs.h
2.21 KB
Del
OK
qnxtypes.h
561 B
Del
OK
quota.h
5.78 KB
Del
OK
radeonfb.h
297 B
Del
OK
raid
-
Del
OK
random.h
1.2 KB
Del
OK
raw.h
302 B
Del
OK
rds.h
7.9 KB
Del
OK
reboot.h
1.25 KB
Del
OK
reiserfs_fs.h
712 B
Del
OK
reiserfs_xattr.h
464 B
Del
OK
resource.h
2.09 KB
Del
OK
rfkill.h
3.5 KB
Del
OK
romfs_fs.h
1.15 KB
Del
OK
rose.h
2.12 KB
Del
OK
route.h
2.21 KB
Del
OK
rtc.h
3.85 KB
Del
OK
rtnetlink.h
16.63 KB
Del
OK
scc.h
4.43 KB
Del
OK
sched.h
2.23 KB
Del
OK
screen_info.h
2.36 KB
Del
OK
sctp.h
29.29 KB
Del
OK
sdla.h
2.71 KB
Del
OK
seccomp.h
1.79 KB
Del
OK
securebits.h
2.58 KB
Del
OK
selinux_netlink.h
1.11 KB
Del
OK
sem.h
2.52 KB
Del
OK
serial.h
3.04 KB
Del
OK
serial_core.h
5.11 KB
Del
OK
serial_reg.h
15.66 KB
Del
OK
serio.h
1.77 KB
Del
OK
shm.h
2.17 KB
Del
OK
signal.h
171 B
Del
OK
signalfd.h
1.07 KB
Del
OK
snmp.h
12.38 KB
Del
OK
sock_diag.h
431 B
Del
OK
socket.h
738 B
Del
OK
sockios.h
5.89 KB
Del
OK
som.h
5.35 KB
Del
OK
sonet.h
2.17 KB
Del
OK
sonypi.h
5.12 KB
Del
OK
sound.h
1.15 KB
Del
OK
soundcard.h
44.96 KB
Del
OK
spi
-
Del
OK
stat.h
1 KB
Del
OK
stddef.h
1 B
Del
OK
string.h
175 B
Del
OK
sunrpc
-
Del
OK
suspend_ioctls.h
1.34 KB
Del
OK
swab.h
6.36 KB
Del
OK
synclink.h
8.71 KB
Del
OK
sysctl.h
25.46 KB
Del
OK
sysinfo.h
986 B
Del
OK
target_core_user.h
3.65 KB
Del
OK
taskstats.h
6.83 KB
Del
OK
tc_act
-
Del
OK
tc_ematch
-
Del
OK
tcp.h
5.93 KB
Del
OK
tcp_metrics.h
1.45 KB
Del
OK
telephony.h
8.84 KB
Del
OK
termios.h
443 B
Del
OK
time.h
1.54 KB
Del
OK
times.h
215 B
Del
OK
timex.h
6.17 KB
Del
OK
tiocl.h
1.63 KB
Del
OK
tipc.h
5.44 KB
Del
OK
tipc_config.h
14.1 KB
Del
OK
toshiba.h
1.24 KB
Del
OK
tty.h
1.33 KB
Del
OK
tty_flags.h
3.66 KB
Del
OK
types.h
1.4 KB
Del
OK
udf_fs_i.h
634 B
Del
OK
udp.h
1.28 KB
Del
OK
uhid.h
2.15 KB
Del
OK
uinput.h
5 KB
Del
OK
uio.h
668 B
Del
OK
ultrasound.h
4.39 KB
Del
OK
un.h
239 B
Del
OK
unistd.h
157 B
Del
OK
unix_diag.h
1.1 KB
Del
OK
usb
-
Del
OK
usbdevice_fs.h
6.56 KB
Del
OK
userfaultfd.h
6.59 KB
Del
OK
utime.h
152 B
Del
OK
utsname.h
606 B
Del
OK
uuid.h
1.5 KB
Del
OK
uvcvideo.h
1.6 KB
Del
OK
v4l2-common.h
2.38 KB
Del
OK
v4l2-controls.h
37.34 KB
Del
OK
v4l2-dv-timings.h
25.75 KB
Del
OK
v4l2-mediabus.h
4.55 KB
Del
OK
v4l2-subdev.h
5.27 KB
Del
OK
version.h
255 B
Del
OK
veth.h
402 B
Del
OK
vfio.h
24.12 KB
Del
OK
vhost.h
7.13 KB
Del
OK
videodev2.h
67.41 KB
Del
OK
virtio_9p.h
1.99 KB
Del
OK
virtio_balloon.h
3.71 KB
Del
OK
virtio_blk.h
5.2 KB
Del
OK
virtio_config.h
3.24 KB
Del
OK
virtio_console.h
2.94 KB
Del
OK
virtio_gpu.h
7.84 KB
Del
OK
virtio_ids.h
2.32 KB
Del
OK
virtio_input.h
2.45 KB
Del
OK
virtio_net.h
9.4 KB
Del
OK
virtio_pci.h
6.63 KB
Del
OK
virtio_ring.h
6.18 KB
Del
OK
virtio_rng.h
265 B
Del
OK
virtio_scsi.h
5.13 KB
Del
OK
virtio_types.h
2.11 KB
Del
OK
virtio_vsock.h
3.01 KB
Del
OK
vm_sockets.h
5.13 KB
Del
OK
vsockmon.h
1.78 KB
Del
OK
vt.h
3.05 KB
Del
OK
vtpm_proxy.h
1.62 KB
Del
OK
vzcalluser.h
4.11 KB
Del
OK
vzctl_netstat.h
2.56 KB
Del
OK
vzctl_venet.h
641 B
Del
OK
vzctl_veth.h
758 B
Del
OK
vziptable_defs.h
3.03 KB
Del
OK
vzlist.h
845 B
Del
OK
wait.h
600 B
Del
OK
wanrouter.h
390 B
Del
OK
watchdog.h
2.22 KB
Del
OK
wimax
-
Del
OK
wimax.h
8.17 KB
Del
OK
wireless.h
41.65 KB
Del
OK
x25.h
3.42 KB
Del
OK
xattr.h
2.53 KB
Del
OK
xfrm.h
11 KB
Del
OK
Edit: dm-log-userspace.h
/* * Copyright (C) 2006-2009 Red Hat, Inc. * * This file is released under the LGPL. */ #ifndef __DM_LOG_USERSPACE_H__ #define __DM_LOG_USERSPACE_H__ #include <linux/dm-ioctl.h> /* For DM_UUID_LEN */ /* * The device-mapper userspace log module consists of a kernel component and * a user-space component. The kernel component implements the API defined * in dm-dirty-log.h. Its purpose is simply to pass the parameters and * return values of those API functions between kernel and user-space. * * Below are defined the 'request_types' - DM_ULOG_CTR, DM_ULOG_DTR, etc. * These request types represent the different functions in the device-mapper * dirty log API. Each of these is described in more detail below. * * The user-space program must listen for requests from the kernel (representing * the various API functions) and process them. * * User-space begins by setting up the communication link (error checking * removed for clarity): * fd = socket(PF_NETLINK, SOCK_DGRAM, NETLINK_CONNECTOR); * addr.nl_family = AF_NETLINK; * addr.nl_groups = CN_IDX_DM; * addr.nl_pid = 0; * r = bind(fd, (struct sockaddr *) &addr, sizeof(addr)); * opt = addr.nl_groups; * setsockopt(fd, SOL_NETLINK, NETLINK_ADD_MEMBERSHIP, &opt, sizeof(opt)); * * User-space will then wait to receive requests form the kernel, which it * will process as described below. The requests are received in the form, * ((struct dm_ulog_request) + (additional data)). Depending on the request * type, there may or may not be 'additional data'. In the descriptions below, * you will see 'Payload-to-userspace' and 'Payload-to-kernel'. The * 'Payload-to-userspace' is what the kernel sends in 'additional data' as * necessary parameters to complete the request. The 'Payload-to-kernel' is * the 'additional data' returned to the kernel that contains the necessary * results of the request. The 'data_size' field in the dm_ulog_request * structure denotes the availability and amount of payload data. */ /* * DM_ULOG_CTR corresponds to (found in dm-dirty-log.h): * int (*ctr)(struct dm_dirty_log *log, struct dm_target *ti, * unsigned argc, char **argv); * * Payload-to-userspace: * A single string containing all the argv arguments separated by ' 's * Payload-to-kernel: * A NUL-terminated string that is the name of the device that is used * as the backing store for the log data. 'dm_get_device' will be called * on this device. ('dm_put_device' will be called on this device * automatically after calling DM_ULOG_DTR.) If there is no device needed * for log data, 'data_size' in the dm_ulog_request struct should be 0. * * The UUID contained in the dm_ulog_request structure is the reference that * will be used by all request types to a specific log. The constructor must * record this association with the instance created. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field, filling the * data field with the log device if necessary, and setting 'data_size' * appropriately. */ #define DM_ULOG_CTR 1 /* * DM_ULOG_DTR corresponds to (found in dm-dirty-log.h): * void (*dtr)(struct dm_dirty_log *log); * * Payload-to-userspace: * A single string containing all the argv arguments separated by ' 's * Payload-to-kernel: * None. ('data_size' in the dm_ulog_request struct should be 0.) * * The UUID contained in the dm_ulog_request structure is all that is * necessary to identify the log instance being destroyed. There is no * payload data. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and clearing * 'data_size' appropriately. */ #define DM_ULOG_DTR 2 /* * DM_ULOG_PRESUSPEND corresponds to (found in dm-dirty-log.h): * int (*presuspend)(struct dm_dirty_log *log); * * Payload-to-userspace: * None. * Payload-to-kernel: * None. * * The UUID contained in the dm_ulog_request structure is all that is * necessary to identify the log instance being presuspended. There is no * payload data. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_PRESUSPEND 3 /* * DM_ULOG_POSTSUSPEND corresponds to (found in dm-dirty-log.h): * int (*postsuspend)(struct dm_dirty_log *log); * * Payload-to-userspace: * None. * Payload-to-kernel: * None. * * The UUID contained in the dm_ulog_request structure is all that is * necessary to identify the log instance being postsuspended. There is no * payload data. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_POSTSUSPEND 4 /* * DM_ULOG_RESUME corresponds to (found in dm-dirty-log.h): * int (*resume)(struct dm_dirty_log *log); * * Payload-to-userspace: * None. * Payload-to-kernel: * None. * * The UUID contained in the dm_ulog_request structure is all that is * necessary to identify the log instance being resumed. There is no * payload data. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_RESUME 5 /* * DM_ULOG_GET_REGION_SIZE corresponds to (found in dm-dirty-log.h): * uint32_t (*get_region_size)(struct dm_dirty_log *log); * * Payload-to-userspace: * None. * Payload-to-kernel: * uint64_t - contains the region size * * The region size is something that was determined at constructor time. * It is returned in the payload area and 'data_size' is set to * reflect this. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field appropriately. */ #define DM_ULOG_GET_REGION_SIZE 6 /* * DM_ULOG_IS_CLEAN corresponds to (found in dm-dirty-log.h): * int (*is_clean)(struct dm_dirty_log *log, region_t region); * * Payload-to-userspace: * uint64_t - the region to get clean status on * Payload-to-kernel: * int64_t - 1 if clean, 0 otherwise * * Payload is sizeof(uint64_t) and contains the region for which the clean * status is being made. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - filling the payload with 0 (not clean) or * 1 (clean), setting 'data_size' and 'error' appropriately. */ #define DM_ULOG_IS_CLEAN 7 /* * DM_ULOG_IN_SYNC corresponds to (found in dm-dirty-log.h): * int (*in_sync)(struct dm_dirty_log *log, region_t region, * int can_block); * * Payload-to-userspace: * uint64_t - the region to get sync status on * Payload-to-kernel: * int64_t - 1 if in-sync, 0 otherwise * * Exactly the same as 'is_clean' above, except this time asking "has the * region been recovered?" vs. "is the region not being modified?" */ #define DM_ULOG_IN_SYNC 8 /* * DM_ULOG_FLUSH corresponds to (found in dm-dirty-log.h): * int (*flush)(struct dm_dirty_log *log); * * Payload-to-userspace: * If the 'integrated_flush' directive is present in the constructor * table, the payload is as same as DM_ULOG_MARK_REGION: * uint64_t [] - region(s) to mark * else * None * Payload-to-kernel: * None. * * If the 'integrated_flush' option was used during the creation of the * log, mark region requests are carried as payload in the flush request. * Piggybacking the mark requests in this way allows for fewer communications * between kernel and userspace. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and clearing * 'data_size' appropriately. */ #define DM_ULOG_FLUSH 9 /* * DM_ULOG_MARK_REGION corresponds to (found in dm-dirty-log.h): * void (*mark_region)(struct dm_dirty_log *log, region_t region); * * Payload-to-userspace: * uint64_t [] - region(s) to mark * Payload-to-kernel: * None. * * Incoming payload contains the one or more regions to mark dirty. * The number of regions contained in the payload can be determined from * 'data_size/sizeof(uint64_t)'. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and clearing * 'data_size' appropriately. */ #define DM_ULOG_MARK_REGION 10 /* * DM_ULOG_CLEAR_REGION corresponds to (found in dm-dirty-log.h): * void (*clear_region)(struct dm_dirty_log *log, region_t region); * * Payload-to-userspace: * uint64_t [] - region(s) to clear * Payload-to-kernel: * None. * * Incoming payload contains the one or more regions to mark clean. * The number of regions contained in the payload can be determined from * 'data_size/sizeof(uint64_t)'. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and clearing * 'data_size' appropriately. */ #define DM_ULOG_CLEAR_REGION 11 /* * DM_ULOG_GET_RESYNC_WORK corresponds to (found in dm-dirty-log.h): * int (*get_resync_work)(struct dm_dirty_log *log, region_t *region); * * Payload-to-userspace: * None. * Payload-to-kernel: * { * int64_t i; -- 1 if recovery necessary, 0 otherwise * uint64_t r; -- The region to recover if i=1 * } * 'data_size' should be set appropriately. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field appropriately. */ #define DM_ULOG_GET_RESYNC_WORK 12 /* * DM_ULOG_SET_REGION_SYNC corresponds to (found in dm-dirty-log.h): * void (*set_region_sync)(struct dm_dirty_log *log, * region_t region, int in_sync); * * Payload-to-userspace: * { * uint64_t - region to set sync state on * int64_t - 0 if not-in-sync, 1 if in-sync * } * Payload-to-kernel: * None. * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and clearing * 'data_size' appropriately. */ #define DM_ULOG_SET_REGION_SYNC 13 /* * DM_ULOG_GET_SYNC_COUNT corresponds to (found in dm-dirty-log.h): * region_t (*get_sync_count)(struct dm_dirty_log *log); * * Payload-to-userspace: * None. * Payload-to-kernel: * uint64_t - the number of in-sync regions * * No incoming payload. Kernel-bound payload contains the number of * regions that are in-sync (in a size_t). * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_GET_SYNC_COUNT 14 /* * DM_ULOG_STATUS_INFO corresponds to (found in dm-dirty-log.h): * int (*status)(struct dm_dirty_log *log, STATUSTYPE_INFO, * char *result, unsigned maxlen); * * Payload-to-userspace: * None. * Payload-to-kernel: * Character string containing STATUSTYPE_INFO * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_STATUS_INFO 15 /* * DM_ULOG_STATUS_TABLE corresponds to (found in dm-dirty-log.h): * int (*status)(struct dm_dirty_log *log, STATUSTYPE_TABLE, * char *result, unsigned maxlen); * * Payload-to-userspace: * None. * Payload-to-kernel: * Character string containing STATUSTYPE_TABLE * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_STATUS_TABLE 16 /* * DM_ULOG_IS_REMOTE_RECOVERING corresponds to (found in dm-dirty-log.h): * int (*is_remote_recovering)(struct dm_dirty_log *log, region_t region); * * Payload-to-userspace: * uint64_t - region to determine recovery status on * Payload-to-kernel: * { * int64_t is_recovering; -- 0 if no, 1 if yes * uint64_t in_sync_hint; -- lowest region still needing resync * } * * When the request has been processed, user-space must return the * dm_ulog_request to the kernel - setting the 'error' field and * 'data_size' appropriately. */ #define DM_ULOG_IS_REMOTE_RECOVERING 17 /* * (DM_ULOG_REQUEST_MASK & request_type) to get the request type * * Payload-to-userspace: * A single string containing all the argv arguments separated by ' 's * Payload-to-kernel: * None. ('data_size' in the dm_ulog_request struct should be 0.) * * We are reserving 8 bits of the 32-bit 'request_type' field for the * various request types above. The remaining 24-bits are currently * set to zero and are reserved for future use and compatibility concerns. * * User-space should always use DM_ULOG_REQUEST_TYPE to acquire the * request type from the 'request_type' field to maintain forward compatibility. */ #define DM_ULOG_REQUEST_MASK 0xFF #define DM_ULOG_REQUEST_TYPE(request_type) \ (DM_ULOG_REQUEST_MASK & (request_type)) /* * DM_ULOG_REQUEST_VERSION is incremented when there is a * change to the way information is passed between kernel * and userspace. This could be a structure change of * dm_ulog_request or a change in the way requests are * issued/handled. Changes are outlined here: * version 1: Initial implementation * version 2: DM_ULOG_CTR allowed to return a string containing a * device name that is to be registered with DM via * 'dm_get_device'. * version 3: DM_ULOG_FLUSH is capable of carrying payload for marking * regions. This "integrated flush" reduces the number of * requests between the kernel and userspace by effectively * merging 'mark' and 'flush' requests. A constructor table * argument ('integrated_flush') is required to turn this * feature on, so it is backwards compatible with older * userspace versions. */ #define DM_ULOG_REQUEST_VERSION 3 struct dm_ulog_request { /* * The local unique identifier (luid) and the universally unique * identifier (uuid) are used to tie a request to a specific * mirror log. A single machine log could probably make due with * just the 'luid', but a cluster-aware log must use the 'uuid' and * the 'luid'. The uuid is what is required for node to node * communication concerning a particular log, but the 'luid' helps * differentiate between logs that are being swapped and have the * same 'uuid'. (Think "live" and "inactive" device-mapper tables.) */ uint64_t luid; char uuid[DM_UUID_LEN]; char padding[3]; /* Padding because DM_UUID_LEN = 129 */ uint32_t version; /* See DM_ULOG_REQUEST_VERSION */ int32_t error; /* Used to report back processing errors */ uint32_t seq; /* Sequence number for request */ uint32_t request_type; /* DM_ULOG_* defined above */ uint32_t data_size; /* How much data (not including this struct) */ char data[0]; }; #endif /* __DM_LOG_USERSPACE_H__ */
Save