raw_bsd.c 5.7 KB
Newer Older
1 2
/* BlockDriver implementation for "raw"
 *
L
Laszlo Ersek 已提交
3 4
 * Copyright (C) 2010, 2013, Red Hat, Inc.
 * Copyright (C) 2010, Blue Swirl <blauwirbel@gmail.com>
L
Laszlo Ersek 已提交
5
 * Copyright (C) 2009, Anthony Liguori <aliguori@us.ibm.com>
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
 *
 * Author:
 *   Laszlo Ersek <lersek@redhat.com>
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to
 * deal in the Software without restriction, including without limitation the
 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
 * sell copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 * IN THE SOFTWARE.
 */

#include "block/block_int.h"
L
Laszlo Ersek 已提交
30 31
#include "qemu/option.h"

32
static QEMUOptionParameter raw_create_options[] = {
L
Laszlo Ersek 已提交
33 34 35 36 37 38 39
    {
        .name = BLOCK_OPT_SIZE,
        .type = OPT_SIZE,
        .help = "Virtual disk size"
    },
    { 0 }
};
40

41 42
static int raw_reopen_prepare(BDRVReopenState *reopen_state,
                              BlockReopenQueue *queue, Error **errp)
43
{
44
    return 0;
45 46
}

47 48
static int coroutine_fn raw_co_readv(BlockDriverState *bs, int64_t sector_num,
                                     int nb_sectors, QEMUIOVector *qiov)
49
{
50
    BLKDBG_EVENT(bs->file, BLKDBG_READ_AIO);
51
    return bdrv_co_readv(bs->file, sector_num, nb_sectors, qiov);
52 53
}

54 55
static int coroutine_fn raw_co_writev(BlockDriverState *bs, int64_t sector_num,
                                      int nb_sectors, QEMUIOVector *qiov)
56
{
57
    BLKDBG_EVENT(bs->file, BLKDBG_WRITE_AIO);
58
    return bdrv_co_writev(bs->file, sector_num, nb_sectors, qiov);
59 60
}

61 62 63
static int coroutine_fn raw_co_is_allocated(BlockDriverState *bs,
                                            int64_t sector_num, int nb_sectors,
                                            int *pnum)
64
{
65
    return bdrv_is_allocated(bs->file, sector_num, nb_sectors, pnum);
66 67
}

68 69
static int coroutine_fn raw_co_write_zeroes(BlockDriverState *bs,
                                            int64_t sector_num, int nb_sectors)
70
{
71
    return bdrv_co_write_zeroes(bs->file, sector_num, nb_sectors);
72 73
}

74 75
static int coroutine_fn raw_co_discard(BlockDriverState *bs,
                                       int64_t sector_num, int nb_sectors)
76
{
77
    return bdrv_co_discard(bs->file, sector_num, nb_sectors);
78 79
}

80
static int64_t raw_getlength(BlockDriverState *bs)
81 82 83 84
{
    return bdrv_getlength(bs->file);
}

85
static int raw_get_info(BlockDriverState *bs, BlockDriverInfo *bdi)
86
{
87
    return bdrv_get_info(bs->file, bdi);
88 89
}

90
static int raw_truncate(BlockDriverState *bs, int64_t offset)
91
{
92
    return bdrv_truncate(bs->file, offset);
93 94
}

95
static int raw_is_inserted(BlockDriverState *bs)
96 97 98 99
{
    return bdrv_is_inserted(bs->file);
}

100
static int raw_media_changed(BlockDriverState *bs)
101 102 103 104
{
    return bdrv_media_changed(bs->file);
}

105
static void raw_eject(BlockDriverState *bs, bool eject_flag)
106
{
107
    bdrv_eject(bs->file, eject_flag);
108 109
}

110
static void raw_lock_medium(BlockDriverState *bs, bool locked)
111
{
112
    bdrv_lock_medium(bs->file, locked);
113 114
}

115
static int raw_ioctl(BlockDriverState *bs, unsigned long int req, void *buf)
116
{
117
    return bdrv_ioctl(bs->file, req, buf);
118 119
}

120 121 122 123
static BlockDriverAIOCB *raw_aio_ioctl(BlockDriverState *bs,
                                       unsigned long int req, void *buf,
                                       BlockDriverCompletionFunc *cb,
                                       void *opaque)
124
{
125
    return bdrv_aio_ioctl(bs->file, req, buf, cb, opaque);
126 127
}

128
static int raw_has_zero_init(BlockDriverState *bs)
129 130 131 132
{
    return bdrv_has_zero_init(bs->file);
}

133
static int raw_create(const char *filename, QEMUOptionParameter *options)
L
Laszlo Ersek 已提交
134
{
135
    return bdrv_create_file(filename, options);
L
Laszlo Ersek 已提交
136
}
137

138
static int raw_open(BlockDriverState *bs, QDict *options, int flags)
139 140 141 142 143
{
    bs->sg = bs->file->sg;
    return 0;
}

144
static void raw_close(BlockDriverState *bs)
145 146 147
{
}

148
static int raw_probe(const uint8_t *buf, int buf_size, const char *filename)
149 150 151 152 153 154
{
    /* smallest possible positive score so that raw is used if and only if no
     * other block driver works
     */
    return 1;
}
L
Laszlo Ersek 已提交
155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186

static BlockDriver bdrv_raw = {
    .format_name          = "raw",
    .bdrv_probe           = &raw_probe,
    .bdrv_reopen_prepare  = &raw_reopen_prepare,
    .bdrv_open            = &raw_open,
    .bdrv_close           = &raw_close,
    .bdrv_create          = &raw_create,
    .bdrv_co_readv        = &raw_co_readv,
    .bdrv_co_writev       = &raw_co_writev,
    .bdrv_co_write_zeroes = &raw_co_write_zeroes,
    .bdrv_co_discard      = &raw_co_discard,
    .bdrv_co_is_allocated = &raw_co_is_allocated,
    .bdrv_truncate        = &raw_truncate,
    .bdrv_getlength       = &raw_getlength,
    .bdrv_get_info        = &raw_get_info,
    .bdrv_is_inserted     = &raw_is_inserted,
    .bdrv_media_changed   = &raw_media_changed,
    .bdrv_eject           = &raw_eject,
    .bdrv_lock_medium     = &raw_lock_medium,
    .bdrv_ioctl           = &raw_ioctl,
    .bdrv_aio_ioctl       = &raw_aio_ioctl,
    .create_options       = &raw_create_options[0],
    .bdrv_has_zero_init   = &raw_has_zero_init
};

static void bdrv_raw_init(void)
{
    bdrv_register(&bdrv_raw);
}

block_init(bdrv_raw_init);