X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=src%2Fguestfs_protocol.x;h=38bb8ea916b59283efa2020eb396ceb619908bf9;hp=e03aef66e3683b10981d3cbe98bae274c2c2c7f6;hb=85ed8cef99c19b4143844991d14e0b848fecc5da;hpb=6bcbe54b5785cb8c911ccf4b724ae6abfdf53ce4 diff --git a/src/guestfs_protocol.x b/src/guestfs_protocol.x index e03aef6..38bb8ea 100644 --- a/src/guestfs_protocol.x +++ b/src/guestfs_protocol.x @@ -406,6 +406,298 @@ struct guestfs_statvfs_ret { guestfs_int_statvfs statbuf; }; +struct guestfs_tune2fs_l_args { + string device<>; +}; + +struct guestfs_tune2fs_l_ret { + str superblock<>; +}; + +struct guestfs_blockdev_setro_args { + string device<>; +}; + +struct guestfs_blockdev_setrw_args { + string device<>; +}; + +struct guestfs_blockdev_getro_args { + string device<>; +}; + +struct guestfs_blockdev_getro_ret { + bool ro; +}; + +struct guestfs_blockdev_getss_args { + string device<>; +}; + +struct guestfs_blockdev_getss_ret { + int sectorsize; +}; + +struct guestfs_blockdev_getbsz_args { + string device<>; +}; + +struct guestfs_blockdev_getbsz_ret { + int blocksize; +}; + +struct guestfs_blockdev_setbsz_args { + string device<>; + int blocksize; +}; + +struct guestfs_blockdev_getsz_args { + string device<>; +}; + +struct guestfs_blockdev_getsz_ret { + hyper sizeinsectors; +}; + +struct guestfs_blockdev_getsize64_args { + string device<>; +}; + +struct guestfs_blockdev_getsize64_ret { + hyper sizeinbytes; +}; + +struct guestfs_blockdev_flushbufs_args { + string device<>; +}; + +struct guestfs_blockdev_rereadpt_args { + string device<>; +}; + +struct guestfs_upload_args { + string remotefilename<>; +}; + +struct guestfs_download_args { + string remotefilename<>; +}; + +struct guestfs_checksum_args { + string csumtype<>; + string path<>; +}; + +struct guestfs_checksum_ret { + string checksum<>; +}; + +struct guestfs_tar_in_args { + string directory<>; +}; + +struct guestfs_tar_out_args { + string directory<>; +}; + +struct guestfs_tgz_in_args { + string directory<>; +}; + +struct guestfs_tgz_out_args { + string directory<>; +}; + +struct guestfs_mount_ro_args { + string device<>; + string mountpoint<>; +}; + +struct guestfs_mount_options_args { + string options<>; + string device<>; + string mountpoint<>; +}; + +struct guestfs_mount_vfs_args { + string options<>; + string vfstype<>; + string device<>; + string mountpoint<>; +}; + +struct guestfs_debug_args { + string subcmd<>; + str extraargs<>; +}; + +struct guestfs_debug_ret { + string result<>; +}; + +struct guestfs_lvremove_args { + string device<>; +}; + +struct guestfs_vgremove_args { + string vgname<>; +}; + +struct guestfs_pvremove_args { + string device<>; +}; + +struct guestfs_set_e2label_args { + string device<>; + string label<>; +}; + +struct guestfs_get_e2label_args { + string device<>; +}; + +struct guestfs_get_e2label_ret { + string label<>; +}; + +struct guestfs_set_e2uuid_args { + string device<>; + string uuid<>; +}; + +struct guestfs_get_e2uuid_args { + string device<>; +}; + +struct guestfs_get_e2uuid_ret { + string uuid<>; +}; + +struct guestfs_fsck_args { + string fstype<>; + string device<>; +}; + +struct guestfs_fsck_ret { + int status; +}; + +struct guestfs_zero_args { + string device<>; +}; + +struct guestfs_grub_install_args { + string root<>; + string device<>; +}; + +struct guestfs_cp_args { + string src<>; + string dest<>; +}; + +struct guestfs_cp_a_args { + string src<>; + string dest<>; +}; + +struct guestfs_mv_args { + string src<>; + string dest<>; +}; + +struct guestfs_drop_caches_args { + int whattodrop; +}; + +struct guestfs_dmesg_ret { + string kmsgs<>; +}; + +struct guestfs_equal_args { + string file1<>; + string file2<>; +}; + +struct guestfs_equal_ret { + bool equality; +}; + +struct guestfs_strings_args { + string path<>; +}; + +struct guestfs_strings_ret { + str stringsout<>; +}; + +struct guestfs_strings_e_args { + string encoding<>; + string path<>; +}; + +struct guestfs_strings_e_ret { + str stringsout<>; +}; + +struct guestfs_hexdump_args { + string path<>; +}; + +struct guestfs_hexdump_ret { + string dump<>; +}; + +struct guestfs_zerofree_args { + string device<>; +}; + +struct guestfs_pvresize_args { + string device<>; +}; + +struct guestfs_sfdisk_N_args { + string device<>; + int n; + int cyls; + int heads; + int sectors; + string line<>; +}; + +struct guestfs_sfdisk_l_args { + string device<>; +}; + +struct guestfs_sfdisk_l_ret { + string partitions<>; +}; + +struct guestfs_sfdisk_kernel_geometry_args { + string device<>; +}; + +struct guestfs_sfdisk_kernel_geometry_ret { + string partitions<>; +}; + +struct guestfs_sfdisk_disk_geometry_args { + string device<>; +}; + +struct guestfs_sfdisk_disk_geometry_ret { + string partitions<>; +}; + +struct guestfs_vg_activate_all_args { + bool activate; +}; + +struct guestfs_vg_activate_args { + bool activate; + str volgroups<>; +}; + enum guestfs_procedure { GUESTFS_PROC_MOUNT = 1, GUESTFS_PROC_SYNC = 2, @@ -461,14 +753,72 @@ enum guestfs_procedure { GUESTFS_PROC_STAT = 52, GUESTFS_PROC_LSTAT = 53, GUESTFS_PROC_STATVFS = 54, - GUESTFS_PROC_dummy + GUESTFS_PROC_TUNE2FS_L = 55, + GUESTFS_PROC_BLOCKDEV_SETRO = 56, + GUESTFS_PROC_BLOCKDEV_SETRW = 57, + GUESTFS_PROC_BLOCKDEV_GETRO = 58, + GUESTFS_PROC_BLOCKDEV_GETSS = 59, + GUESTFS_PROC_BLOCKDEV_GETBSZ = 60, + GUESTFS_PROC_BLOCKDEV_SETBSZ = 61, + GUESTFS_PROC_BLOCKDEV_GETSZ = 62, + GUESTFS_PROC_BLOCKDEV_GETSIZE64 = 63, + GUESTFS_PROC_BLOCKDEV_FLUSHBUFS = 64, + GUESTFS_PROC_BLOCKDEV_REREADPT = 65, + GUESTFS_PROC_UPLOAD = 66, + GUESTFS_PROC_DOWNLOAD = 67, + GUESTFS_PROC_CHECKSUM = 68, + GUESTFS_PROC_TAR_IN = 69, + GUESTFS_PROC_TAR_OUT = 70, + GUESTFS_PROC_TGZ_IN = 71, + GUESTFS_PROC_TGZ_OUT = 72, + GUESTFS_PROC_MOUNT_RO = 73, + GUESTFS_PROC_MOUNT_OPTIONS = 74, + GUESTFS_PROC_MOUNT_VFS = 75, + GUESTFS_PROC_DEBUG = 76, + GUESTFS_PROC_LVREMOVE = 77, + GUESTFS_PROC_VGREMOVE = 78, + GUESTFS_PROC_PVREMOVE = 79, + GUESTFS_PROC_SET_E2LABEL = 80, + GUESTFS_PROC_GET_E2LABEL = 81, + GUESTFS_PROC_SET_E2UUID = 82, + GUESTFS_PROC_GET_E2UUID = 83, + GUESTFS_PROC_FSCK = 84, + GUESTFS_PROC_ZERO = 85, + GUESTFS_PROC_GRUB_INSTALL = 86, + GUESTFS_PROC_CP = 87, + GUESTFS_PROC_CP_A = 88, + GUESTFS_PROC_MV = 89, + GUESTFS_PROC_DROP_CACHES = 90, + GUESTFS_PROC_DMESG = 91, + GUESTFS_PROC_PING_DAEMON = 92, + GUESTFS_PROC_EQUAL = 93, + GUESTFS_PROC_STRINGS = 94, + GUESTFS_PROC_STRINGS_E = 95, + GUESTFS_PROC_HEXDUMP = 96, + GUESTFS_PROC_ZEROFREE = 97, + GUESTFS_PROC_PVRESIZE = 98, + GUESTFS_PROC_SFDISK_N = 99, + GUESTFS_PROC_SFDISK_L = 100, + GUESTFS_PROC_SFDISK_KERNEL_GEOMETRY = 101, + GUESTFS_PROC_SFDISK_DISK_GEOMETRY = 102, + GUESTFS_PROC_VG_ACTIVATE_ALL = 103, + GUESTFS_PROC_VG_ACTIVATE = 104, + GUESTFS_PROC_NR_PROCS }; const GUESTFS_MESSAGE_MAX = 4194304; +/* The communication protocol is now documented in the guestfs(3) + * manpage. + */ + const GUESTFS_PROGRAM = 0x2000F5F5; const GUESTFS_PROTOCOL_VERSION = 1; +/* These constants must be larger than any possible message length. */ +const GUESTFS_LAUNCH_FLAG = 0xf5f55ff5; +const GUESTFS_CANCEL_FLAG = 0xffffeeee; + enum guestfs_message_direction { GUESTFS_DIRECTION_CALL = 0, /* client -> daemon */ GUESTFS_DIRECTION_REPLY = 1 /* daemon -> client */ @@ -482,7 +832,7 @@ enum guestfs_message_status { const GUESTFS_ERROR_LEN = 256; struct guestfs_message_error { - string error; /* error message */ + string error_message; }; struct guestfs_message_header { @@ -493,3 +843,11 @@ struct guestfs_message_header { unsigned serial; /* message serial number */ guestfs_message_status status; }; + +const GUESTFS_MAX_CHUNK_SIZE = 8192; + +struct guestfs_chunk { + int cancel; /* if non-zero, transfer is cancelled */ + /* data size is 0 bytes if the transfer has finished successfully */ + opaque data; +};