block_int.h revision 5d8f37ad78fc66901af50c762029a501561f3b23
18b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project/*
28b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * QEMU System Emulator block driver
38b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project *
48b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * Copyright (c) 2003 Fabrice Bellard
58b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project *
68b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * Permission is hereby granted, free of charge, to any person obtaining a copy
78b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * of this software and associated documentation files (the "Software"), to deal
88b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * in the Software without restriction, including without limitation the rights
98b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
108b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * copies of the Software, and to permit persons to whom the Software is
118b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * furnished to do so, subject to the following conditions:
128b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project *
138b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * The above copyright notice and this permission notice shall be included in
148b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * all copies or substantial portions of the Software.
158b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project *
168b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
178b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
188b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
198b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
208b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
218b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
228b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project * THE SOFTWARE.
238b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project */
248b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#ifndef BLOCK_INT_H
258b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#define BLOCK_INT_H
268b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
278b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#include "block.h"
285d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#include "qemu-option.h"
298b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
308b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#define BLOCK_FLAG_ENCRYPT	1
318b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#define BLOCK_FLAG_COMPRESS	2
328b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#define BLOCK_FLAG_COMPAT6	4
338b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
345d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#define BLOCK_OPT_SIZE          "size"
355d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#define BLOCK_OPT_ENCRYPT       "encryption"
365d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#define BLOCK_OPT_COMPAT6       "compat6"
375d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#define BLOCK_OPT_BACKING_FILE  "backing_file"
385d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#define BLOCK_OPT_BACKING_FMT   "backing_fmt"
395d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#define BLOCK_OPT_CLUSTER_SIZE  "cluster_size"
405d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
415d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turnertypedef struct AIOPool {
425d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    void (*cancel)(BlockDriverAIOCB *acb);
435d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int aiocb_size;
445d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    BlockDriverAIOCB *free_aiocb;
455d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner} AIOPool;
465d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
478b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Projectstruct BlockDriver {
488b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    const char *format_name;
498b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int instance_size;
508b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_probe)(const uint8_t *buf, int buf_size, const char *filename);
515d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int (*bdrv_probe_device)(const char *filename);
528b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_open)(BlockDriverState *bs, const char *filename, int flags);
538b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_read)(BlockDriverState *bs, int64_t sector_num,
548b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                     uint8_t *buf, int nb_sectors);
558b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_write)(BlockDriverState *bs, int64_t sector_num,
568b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                      const uint8_t *buf, int nb_sectors);
578b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void (*bdrv_close)(BlockDriverState *bs);
585d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int (*bdrv_create)(const char *filename, QEMUOptionParameter *options);
598b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void (*bdrv_flush)(BlockDriverState *bs);
608b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_is_allocated)(BlockDriverState *bs, int64_t sector_num,
618b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                             int nb_sectors, int *pnum);
628b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_set_key)(BlockDriverState *bs, const char *key);
638b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_make_empty)(BlockDriverState *bs);
648b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* aio */
655d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    BlockDriverAIOCB *(*bdrv_aio_readv)(BlockDriverState *bs,
665d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner        int64_t sector_num, QEMUIOVector *qiov, int nb_sectors,
678b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project        BlockDriverCompletionFunc *cb, void *opaque);
685d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    BlockDriverAIOCB *(*bdrv_aio_writev)(BlockDriverState *bs,
695d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner        int64_t sector_num, QEMUIOVector *qiov, int nb_sectors,
708b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project        BlockDriverCompletionFunc *cb, void *opaque);
718b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
728b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    const char *protocol_name;
738b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_truncate)(BlockDriverState *bs, int64_t offset);
748b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int64_t (*bdrv_getlength)(BlockDriverState *bs);
758b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_write_compressed)(BlockDriverState *bs, int64_t sector_num,
768b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                                 const uint8_t *buf, int nb_sectors);
778b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
788b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_snapshot_create)(BlockDriverState *bs,
798b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                                QEMUSnapshotInfo *sn_info);
808b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_snapshot_goto)(BlockDriverState *bs,
818b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                              const char *snapshot_id);
828b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_snapshot_delete)(BlockDriverState *bs, const char *snapshot_id);
838b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_snapshot_list)(BlockDriverState *bs,
848b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                              QEMUSnapshotInfo **psn_info);
858b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_get_info)(BlockDriverState *bs, BlockDriverInfo *bdi);
868b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
875d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int (*bdrv_put_buffer)(BlockDriverState *bs, const uint8_t *buf,
885d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner                           int64_t pos, int size);
895d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int (*bdrv_get_buffer)(BlockDriverState *bs, uint8_t *buf,
905d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner                           int64_t pos, int size);
915d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
928b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* removable device specific */
938b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_is_inserted)(BlockDriverState *bs);
948b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_media_changed)(BlockDriverState *bs);
958b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_eject)(BlockDriverState *bs, int eject_flag);
968b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_set_locked)(BlockDriverState *bs, int locked);
978b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
988b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* to control generic scsi devices */
998b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int (*bdrv_ioctl)(BlockDriverState *bs, unsigned long int req, void *buf);
1005d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    BlockDriverAIOCB *(*bdrv_aio_ioctl)(BlockDriverState *bs,
1015d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner        unsigned long int req, void *buf,
1025d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner        BlockDriverCompletionFunc *cb, void *opaque);
1035d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1045d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    /* List of options for creating images, terminated by name == NULL */
1055d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    QEMUOptionParameter *create_options;
1065d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1075d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1085d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    /* Returns number of errors in image, -errno for internal errors */
1095d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int (*bdrv_check)(BlockDriverState* bs);
1108b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1118b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    struct BlockDriver *next;
1128b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project};
1138b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1148b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Projectstruct BlockDriverState {
1158b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int64_t total_sectors; /* if we are reading a disk image, give its
1168b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                              size in sectors */
1178b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int read_only; /* if true, the media is read only */
1188b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int removable; /* if true, the media can be removed */
1198b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int locked;    /* if true, the media cannot temporarily be ejected */
1208b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int encrypted; /* if true, the media is encrypted */
1215d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int valid_key; /* if true, a valid encryption key has been set */
1228b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int sg;        /* if true, the device is a /dev/sg* */
1238b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* event callback when inserting/removing */
1248b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void (*change_cb)(void *opaque);
1258b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void *change_opaque;
1268b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1278b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    BlockDriver *drv; /* NULL means no media */
1288b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void *opaque;
1298b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1308b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    char filename[1024];
1318b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    char backing_file[1024]; /* if non zero, the image is a diff of
1328b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project                                this file image */
1335d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    char backing_format[16]; /* if non-zero and backing_file exists */
1348b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int is_temporary;
1358b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int media_changed;
1368b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1378b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    BlockDriverState *backing_hd;
1388b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* async read/write emulation */
1398b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1408b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void *sync_aiocb;
1418b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1428b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* I/O stats (display with "info blockstats"). */
1438b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    uint64_t rd_bytes;
1448b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    uint64_t wr_bytes;
1458b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    uint64_t rd_ops;
1468b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    uint64_t wr_ops;
1478b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1485d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    /* Whether the disk can expand beyond total_sectors */
1495d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int growable;
1505d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1515d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    /* the memory alignment required for the buffers handled by this driver */
1525d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    int buffer_alignment;
1535d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1548b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    /* NOTE: the following infos are only hints for real hardware
1558b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project       drivers. They are not used by the block driver */
1568b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int cyls, heads, secs, translation;
1578b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    int type;
1588b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    char device_name[32];
1598b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    BlockDriverState *next;
1605d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    void *private;
1618b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project};
1628b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1638b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Projectstruct BlockDriverAIOCB {
1645d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner    AIOPool *pool;
1658b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    BlockDriverState *bs;
1668b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    BlockDriverCompletionFunc *cb;
1678b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    void *opaque;
1688b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project    BlockDriverAIOCB *next;
1698b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project};
1708b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1718b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Projectvoid get_tmp_filename(char *filename, int size);
1728b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1735d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turnervoid *qemu_aio_get(AIOPool *pool, BlockDriverState *bs,
1745d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner                   BlockDriverCompletionFunc *cb, void *opaque);
1758b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Projectvoid qemu_aio_release(void *p);
1768b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1775d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turnervoid *qemu_blockalign(BlockDriverState *bs, size_t size);
1785d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1795d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turnerextern BlockDriverState *bdrv_first;
1805d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner
1815d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#ifdef _WIN32
1825d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turnerint is_windows_drive(const char *filename);
1835d8f37ad78fc66901af50c762029a501561f3b23David 'Digit' Turner#endif
1848b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project
1858b23a6c7e1aee255004dd19098d4c2462b61b849The Android Open Source Project#endif /* BLOCK_INT_H */
186