qcow2-refcount.c 38.4 KB
Newer Older
K
Kevin Wolf 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*
 * Block driver for the QCOW version 2 format
 *
 * Copyright (c) 2004-2006 Fabrice Bellard
 *
 * 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 "qemu-common.h"
#include "block_int.h"
#include "block/qcow2.h"

static int64_t alloc_clusters_noref(BlockDriverState *bs, int64_t size);
30
static int QEMU_WARN_UNUSED_RESULT update_refcount(BlockDriverState *bs,
K
Kevin Wolf 已提交
31 32 33
                            int64_t offset, int64_t length,
                            int addend);

34

K
Kevin Wolf 已提交
35 36 37
/*********************************************************/
/* refcount handling */

K
Kevin Wolf 已提交
38
int qcow2_refcount_init(BlockDriverState *bs)
K
Kevin Wolf 已提交
39 40 41 42 43 44 45
{
    BDRVQcowState *s = bs->opaque;
    int ret, refcount_table_size2, i;

    refcount_table_size2 = s->refcount_table_size * sizeof(uint64_t);
    s->refcount_table = qemu_malloc(refcount_table_size2);
    if (s->refcount_table_size > 0) {
46 47
        BLKDBG_EVENT(bs->file, BLKDBG_REFTABLE_LOAD);
        ret = bdrv_pread(bs->file, s->refcount_table_offset,
K
Kevin Wolf 已提交
48 49 50 51 52 53 54 55 56 57 58
                         s->refcount_table, refcount_table_size2);
        if (ret != refcount_table_size2)
            goto fail;
        for(i = 0; i < s->refcount_table_size; i++)
            be64_to_cpus(&s->refcount_table[i]);
    }
    return 0;
 fail:
    return -ENOMEM;
}

K
Kevin Wolf 已提交
59
void qcow2_refcount_close(BlockDriverState *bs)
K
Kevin Wolf 已提交
60 61 62 63 64 65 66
{
    BDRVQcowState *s = bs->opaque;
    qemu_free(s->refcount_table);
}


static int load_refcount_block(BlockDriverState *bs,
K
Kevin Wolf 已提交
67 68
                               int64_t refcount_block_offset,
                               void **refcount_block)
K
Kevin Wolf 已提交
69 70 71
{
    BDRVQcowState *s = bs->opaque;
    int ret;
72

73
    BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_LOAD);
K
Kevin Wolf 已提交
74 75
    ret = qcow2_cache_get(bs, s->refcount_block_cache, refcount_block_offset,
        refcount_block);
76

K
Kevin Wolf 已提交
77
    return ret;
K
Kevin Wolf 已提交
78 79
}

80 81 82 83 84
/*
 * Returns the refcount of the cluster given by its index. Any non-negative
 * return value is the refcount of the cluster, negative values are -errno
 * and indicate an error.
 */
K
Kevin Wolf 已提交
85 86 87 88 89
static int get_refcount(BlockDriverState *bs, int64_t cluster_index)
{
    BDRVQcowState *s = bs->opaque;
    int refcount_table_index, block_index;
    int64_t refcount_block_offset;
90
    int ret;
K
Kevin Wolf 已提交
91 92
    uint16_t *refcount_block;
    uint16_t refcount;
K
Kevin Wolf 已提交
93 94 95 96 97 98 99

    refcount_table_index = cluster_index >> (s->cluster_bits - REFCOUNT_SHIFT);
    if (refcount_table_index >= s->refcount_table_size)
        return 0;
    refcount_block_offset = s->refcount_table[refcount_table_index];
    if (!refcount_block_offset)
        return 0;
K
Kevin Wolf 已提交
100 101 102 103 104

    ret = qcow2_cache_get(bs, s->refcount_block_cache, refcount_block_offset,
        (void**) &refcount_block);
    if (ret < 0) {
        return ret;
K
Kevin Wolf 已提交
105
    }
K
Kevin Wolf 已提交
106

K
Kevin Wolf 已提交
107 108
    block_index = cluster_index &
        ((1 << (s->cluster_bits - REFCOUNT_SHIFT)) - 1);
K
Kevin Wolf 已提交
109 110 111 112 113 114 115 116 117
    refcount = be16_to_cpu(refcount_block[block_index]);

    ret = qcow2_cache_put(bs, s->refcount_block_cache,
        (void**) &refcount_block);
    if (ret < 0) {
        return ret;
    }

    return refcount;
K
Kevin Wolf 已提交
118 119
}

120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
/*
 * Rounds the refcount table size up to avoid growing the table for each single
 * refcount block that is allocated.
 */
static unsigned int next_refcount_table_size(BDRVQcowState *s,
    unsigned int min_size)
{
    unsigned int min_clusters = (min_size >> (s->cluster_bits - 3)) + 1;
    unsigned int refcount_table_clusters =
        MAX(1, s->refcount_table_size >> (s->cluster_bits - 3));

    while (min_clusters > refcount_table_clusters) {
        refcount_table_clusters = (refcount_table_clusters * 3 + 1) / 2;
    }

    return refcount_table_clusters << (s->cluster_bits - 3);
}

138 139 140 141 142 143 144 145 146 147 148 149 150 151 152

/* Checks if two offsets are described by the same refcount block */
static int in_same_refcount_block(BDRVQcowState *s, uint64_t offset_a,
    uint64_t offset_b)
{
    uint64_t block_a = offset_a >> (2 * s->cluster_bits - REFCOUNT_SHIFT);
    uint64_t block_b = offset_b >> (2 * s->cluster_bits - REFCOUNT_SHIFT);

    return (block_a == block_b);
}

/*
 * Loads a refcount block. If it doesn't exist yet, it is allocated first
 * (including growing the refcount table if needed).
 *
K
Kevin Wolf 已提交
153
 * Returns 0 on success or -errno in error case
154
 */
K
Kevin Wolf 已提交
155 156
static int alloc_refcount_block(BlockDriverState *bs,
    int64_t cluster_index, uint16_t **refcount_block)
K
Kevin Wolf 已提交
157 158
{
    BDRVQcowState *s = bs->opaque;
159 160 161
    unsigned int refcount_table_index;
    int ret;

162
    BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC);
K
Kevin Wolf 已提交
163

164 165 166 167 168 169 170 171 172 173
    /* Find the refcount block for the given cluster */
    refcount_table_index = cluster_index >> (s->cluster_bits - REFCOUNT_SHIFT);

    if (refcount_table_index < s->refcount_table_size) {

        uint64_t refcount_block_offset =
            s->refcount_table[refcount_table_index];

        /* If it's already there, we're done */
        if (refcount_block_offset) {
K
Kevin Wolf 已提交
174 175
             return load_refcount_block(bs, refcount_block_offset,
                 (void**) refcount_block);
176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200
        }
    }

    /*
     * If we came here, we need to allocate something. Something is at least
     * a cluster for the new refcount block. It may also include a new refcount
     * table if the old refcount table is too small.
     *
     * Note that allocating clusters here needs some special care:
     *
     * - We can't use the normal qcow2_alloc_clusters(), it would try to
     *   increase the refcount and very likely we would end up with an endless
     *   recursion. Instead we must place the refcount blocks in a way that
     *   they can describe them themselves.
     *
     * - We need to consider that at this point we are inside update_refcounts
     *   and doing the initial refcount increase. This means that some clusters
     *   have already been allocated by the caller, but their refcount isn't
     *   accurate yet. free_cluster_index tells us where this allocation ends
     *   as long as we don't overwrite it by freeing clusters.
     *
     * - alloc_clusters_noref and qcow2_free_clusters may load a different
     *   refcount block into the cache
     */

K
Kevin Wolf 已提交
201 202 203 204
    *refcount_block = NULL;

    /* We write to the refcount table, so we might depend on L2 tables */
    qcow2_cache_flush(bs, s->l2_table_cache);
205 206

    /* Allocate the refcount block itself and mark it as used */
207 208 209 210
    int64_t new_block = alloc_clusters_noref(bs, s->cluster_size);
    if (new_block < 0) {
        return new_block;
    }
K
Kevin Wolf 已提交
211 212

#ifdef DEBUG_ALLOC2
213 214 215
    fprintf(stderr, "qcow2: Allocate refcount block %d for %" PRIx64
        " at %" PRIx64 "\n",
        refcount_table_index, cluster_index << s->cluster_bits, new_block);
K
Kevin Wolf 已提交
216
#endif
217 218

    if (in_same_refcount_block(s, new_block, cluster_index << s->cluster_bits)) {
219
        /* Zero the new refcount block before updating it */
K
Kevin Wolf 已提交
220 221 222 223 224 225 226
        ret = qcow2_cache_get_empty(bs, s->refcount_block_cache, new_block,
            (void**) refcount_block);
        if (ret < 0) {
            goto fail_block;
        }

        memset(*refcount_block, 0, s->cluster_size);
227

228 229 230
        /* The block describes itself, need to update the cache */
        int block_index = (new_block >> s->cluster_bits) &
            ((1 << (s->cluster_bits - REFCOUNT_SHIFT)) - 1);
K
Kevin Wolf 已提交
231
        (*refcount_block)[block_index] = cpu_to_be16(1);
232 233 234 235 236 237 238
    } else {
        /* Described somewhere else. This can recurse at most twice before we
         * arrive at a block that describes itself. */
        ret = update_refcount(bs, new_block, s->cluster_size, 1);
        if (ret < 0) {
            goto fail_block;
        }
239

240 241
        bdrv_flush(bs->file);

242 243
        /* Initialize the new refcount block only after updating its refcount,
         * update_refcount uses the refcount cache itself */
K
Kevin Wolf 已提交
244 245 246 247 248 249 250
        ret = qcow2_cache_get_empty(bs, s->refcount_block_cache, new_block,
            (void**) refcount_block);
        if (ret < 0) {
            goto fail_block;
        }

        memset(*refcount_block, 0, s->cluster_size);
251 252 253
    }

    /* Now the new refcount block needs to be written to disk */
254
    BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC_WRITE);
K
Kevin Wolf 已提交
255 256
    qcow2_cache_entry_mark_dirty(s->refcount_block_cache, *refcount_block);
    ret = qcow2_cache_flush(bs, s->refcount_block_cache);
257 258 259 260 261 262 263
    if (ret < 0) {
        goto fail_block;
    }

    /* If the refcount table is big enough, just hook the block up there */
    if (refcount_table_index < s->refcount_table_size) {
        uint64_t data64 = cpu_to_be64(new_block);
264
        BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC_HOOKUP);
265
        ret = bdrv_pwrite_sync(bs->file,
266 267 268 269 270 271 272
            s->refcount_table_offset + refcount_table_index * sizeof(uint64_t),
            &data64, sizeof(data64));
        if (ret < 0) {
            goto fail_block;
        }

        s->refcount_table[refcount_table_index] = new_block;
K
Kevin Wolf 已提交
273 274 275 276 277 278
        return 0;
    }

    ret = qcow2_cache_put(bs, s->refcount_block_cache, (void**) refcount_block);
    if (ret < 0) {
        goto fail_block;
279 280 281 282 283 284 285 286 287 288 289 290 291
    }

    /*
     * If we come here, we need to grow the refcount table. Again, a new
     * refcount table needs some space and we can't simply allocate to avoid
     * endless recursion.
     *
     * Therefore let's grab new refcount blocks at the end of the image, which
     * will describe themselves and the new refcount table. This way we can
     * reference them only in the new table and do the switch to the new
     * refcount table at once without producing an inconsistent state in
     * between.
     */
292
    BLKDBG_EVENT(bs->file, BLKDBG_REFTABLE_GROW);
K
Kevin Wolf 已提交
293

294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331
    /* Calculate the number of refcount blocks needed so far */
    uint64_t refcount_block_clusters = 1 << (s->cluster_bits - REFCOUNT_SHIFT);
    uint64_t blocks_used = (s->free_cluster_index +
        refcount_block_clusters - 1) / refcount_block_clusters;

    /* And now we need at least one block more for the new metadata */
    uint64_t table_size = next_refcount_table_size(s, blocks_used + 1);
    uint64_t last_table_size;
    uint64_t blocks_clusters;
    do {
        uint64_t table_clusters = size_to_clusters(s, table_size);
        blocks_clusters = 1 +
            ((table_clusters + refcount_block_clusters - 1)
            / refcount_block_clusters);
        uint64_t meta_clusters = table_clusters + blocks_clusters;

        last_table_size = table_size;
        table_size = next_refcount_table_size(s, blocks_used +
            ((meta_clusters + refcount_block_clusters - 1)
            / refcount_block_clusters));

    } while (last_table_size != table_size);

#ifdef DEBUG_ALLOC2
    fprintf(stderr, "qcow2: Grow refcount table %" PRId32 " => %" PRId64 "\n",
        s->refcount_table_size, table_size);
#endif

    /* Create the new refcount table and blocks */
    uint64_t meta_offset = (blocks_used * refcount_block_clusters) *
        s->cluster_size;
    uint64_t table_offset = meta_offset + blocks_clusters * s->cluster_size;
    uint16_t *new_blocks = qemu_mallocz(blocks_clusters * s->cluster_size);
    uint64_t *new_table = qemu_mallocz(table_size * sizeof(uint64_t));

    assert(meta_offset >= (s->free_cluster_index * s->cluster_size));

    /* Fill the new refcount table */
K
Kevin Wolf 已提交
332
    memcpy(new_table, s->refcount_table,
333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348
        s->refcount_table_size * sizeof(uint64_t));
    new_table[refcount_table_index] = new_block;

    int i;
    for (i = 0; i < blocks_clusters; i++) {
        new_table[blocks_used + i] = meta_offset + (i * s->cluster_size);
    }

    /* Fill the refcount blocks */
    uint64_t table_clusters = size_to_clusters(s, table_size * sizeof(uint64_t));
    int block = 0;
    for (i = 0; i < table_clusters + blocks_clusters; i++) {
        new_blocks[block++] = cpu_to_be16(1);
    }

    /* Write refcount blocks to disk */
349
    BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC_WRITE_BLOCKS);
350
    ret = bdrv_pwrite_sync(bs->file, meta_offset, new_blocks,
351 352 353 354 355 356 357 358 359 360 361
        blocks_clusters * s->cluster_size);
    qemu_free(new_blocks);
    if (ret < 0) {
        goto fail_table;
    }

    /* Write refcount table to disk */
    for(i = 0; i < table_size; i++) {
        cpu_to_be64s(&new_table[i]);
    }

362
    BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC_WRITE_TABLE);
363
    ret = bdrv_pwrite_sync(bs->file, table_offset, new_table,
364 365 366 367 368 369
        table_size * sizeof(uint64_t));
    if (ret < 0) {
        goto fail_table;
    }

    for(i = 0; i < table_size; i++) {
K
Kevin Wolf 已提交
370
        cpu_to_be64s(&new_table[i]);
371
    }
K
Kevin Wolf 已提交
372

373 374
    /* Hook up the new refcount table in the qcow2 header */
    uint8_t data[12];
K
Kevin Wolf 已提交
375
    cpu_to_be64w((uint64_t*)data, table_offset);
376
    cpu_to_be32w((uint32_t*)(data + 8), table_clusters);
377
    BLKDBG_EVENT(bs->file, BLKDBG_REFBLOCK_ALLOC_SWITCH_TABLE);
378
    ret = bdrv_pwrite_sync(bs->file, offsetof(QCowHeader, refcount_table_offset),
379 380 381
        data, sizeof(data));
    if (ret < 0) {
        goto fail_table;
382 383
    }

384 385 386 387
    /* And switch it in memory */
    uint64_t old_table_offset = s->refcount_table_offset;
    uint64_t old_table_size = s->refcount_table_size;

K
Kevin Wolf 已提交
388 389
    qemu_free(s->refcount_table);
    s->refcount_table = new_table;
390
    s->refcount_table_size = table_size;
K
Kevin Wolf 已提交
391 392
    s->refcount_table_offset = table_offset;

393 394
    /* Free old table. Remember, we must not change free_cluster_index */
    uint64_t old_free_cluster_index = s->free_cluster_index;
K
Kevin Wolf 已提交
395
    qcow2_free_clusters(bs, old_table_offset, old_table_size * sizeof(uint64_t));
396
    s->free_cluster_index = old_free_cluster_index;
K
Kevin Wolf 已提交
397

K
Kevin Wolf 已提交
398
    ret = load_refcount_block(bs, new_block, (void**) refcount_block);
399
    if (ret < 0) {
K
Kevin Wolf 已提交
400
        return ret;
K
Kevin Wolf 已提交
401 402
    }

403
    return new_block;
K
Kevin Wolf 已提交
404

405 406 407
fail_table:
    qemu_free(new_table);
fail_block:
K
Kevin Wolf 已提交
408 409
    if (*refcount_block != NULL) {
        qcow2_cache_put(bs, s->refcount_block_cache, (void**) refcount_block);
410
    }
K
Kevin Wolf 已提交
411
    return ret;
412 413
}

K
Kevin Wolf 已提交
414
/* XXX: cache several refcount block clusters ? */
415 416
static int QEMU_WARN_UNUSED_RESULT update_refcount(BlockDriverState *bs,
    int64_t offset, int64_t length, int addend)
K
Kevin Wolf 已提交
417 418 419
{
    BDRVQcowState *s = bs->opaque;
    int64_t start, last, cluster_offset;
K
Kevin Wolf 已提交
420 421
    uint16_t *refcount_block = NULL;
    int64_t old_table_index = -1;
422
    int ret;
K
Kevin Wolf 已提交
423 424

#ifdef DEBUG_ALLOC2
425
    printf("update_refcount: offset=%" PRId64 " size=%" PRId64 " addend=%d\n",
K
Kevin Wolf 已提交
426 427
           offset, length, addend);
#endif
K
Kevin Wolf 已提交
428
    if (length < 0) {
K
Kevin Wolf 已提交
429
        return -EINVAL;
K
Kevin Wolf 已提交
430 431 432 433
    } else if (length == 0) {
        return 0;
    }

K
Kevin Wolf 已提交
434 435 436 437 438
    if (addend < 0) {
        qcow2_cache_set_dependency(bs, s->refcount_block_cache,
            s->l2_table_cache);
    }

K
Kevin Wolf 已提交
439 440 441 442 443 444 445
    start = offset & ~(s->cluster_size - 1);
    last = (offset + length - 1) & ~(s->cluster_size - 1);
    for(cluster_offset = start; cluster_offset <= last;
        cluster_offset += s->cluster_size)
    {
        int block_index, refcount;
        int64_t cluster_index = cluster_offset >> s->cluster_bits;
K
Kevin Wolf 已提交
446 447
        int64_t table_index =
            cluster_index >> (s->cluster_bits - REFCOUNT_SHIFT);
K
Kevin Wolf 已提交
448

K
Kevin Wolf 已提交
449 450 451 452 453 454 455 456 457
        /* Load the refcount block and allocate it if needed */
        if (table_index != old_table_index) {
            if (refcount_block) {
                ret = qcow2_cache_put(bs, s->refcount_block_cache,
                    (void**) &refcount_block);
                if (ret < 0) {
                    goto fail;
                }
            }
458

K
Kevin Wolf 已提交
459
            ret = alloc_refcount_block(bs, cluster_index, &refcount_block);
460
            if (ret < 0) {
K
Kevin Wolf 已提交
461
                goto fail;
K
Kevin Wolf 已提交
462 463
            }
        }
K
Kevin Wolf 已提交
464
        old_table_index = table_index;
K
Kevin Wolf 已提交
465

K
Kevin Wolf 已提交
466
        qcow2_cache_entry_mark_dirty(s->refcount_block_cache, refcount_block);
K
Kevin Wolf 已提交
467 468 469 470 471

        /* we can update the count and save it */
        block_index = cluster_index &
            ((1 << (s->cluster_bits - REFCOUNT_SHIFT)) - 1);

K
Kevin Wolf 已提交
472
        refcount = be16_to_cpu(refcount_block[block_index]);
K
Kevin Wolf 已提交
473
        refcount += addend;
474 475 476 477
        if (refcount < 0 || refcount > 0xffff) {
            ret = -EINVAL;
            goto fail;
        }
K
Kevin Wolf 已提交
478 479 480
        if (refcount == 0 && cluster_index < s->free_cluster_index) {
            s->free_cluster_index = cluster_index;
        }
K
Kevin Wolf 已提交
481
        refcount_block[block_index] = cpu_to_be16(refcount);
K
Kevin Wolf 已提交
482 483
    }

484 485
    ret = 0;
fail:
K
Kevin Wolf 已提交
486
    /* Write last changed block to disk */
K
Kevin Wolf 已提交
487
    if (refcount_block) {
488
        int wret;
K
Kevin Wolf 已提交
489 490
        wret = qcow2_cache_put(bs, s->refcount_block_cache,
            (void**) &refcount_block);
491 492
        if (wret < 0) {
            return ret < 0 ? ret : wret;
K
Kevin Wolf 已提交
493 494 495
        }
    }

496 497 498 499 500 501 502
    /*
     * Try do undo any updates if an error is returned (This may succeed in
     * some cases like ENOSPC for allocating a new refcount block)
     */
    if (ret < 0) {
        int dummy;
        dummy = update_refcount(bs, offset, cluster_offset - offset, -addend);
B
Blue Swirl 已提交
503
        (void)dummy;
504 505 506
    }

    return ret;
K
Kevin Wolf 已提交
507 508
}

509 510 511 512 513 514 515
/*
 * Increases or decreases the refcount of a given cluster by one.
 * addend must be 1 or -1.
 *
 * If the return value is non-negative, it is the new refcount of the cluster.
 * If it is negative, it is -errno and indicates an error.
 */
K
Kevin Wolf 已提交
516 517 518 519 520 521 522 523 524 525 526 527
static int update_cluster_refcount(BlockDriverState *bs,
                                   int64_t cluster_index,
                                   int addend)
{
    BDRVQcowState *s = bs->opaque;
    int ret;

    ret = update_refcount(bs, cluster_index << s->cluster_bits, 1, addend);
    if (ret < 0) {
        return ret;
    }

528 529
    bdrv_flush(bs->file);

K
Kevin Wolf 已提交
530 531 532 533 534 535 536 537 538 539 540 541 542 543
    return get_refcount(bs, cluster_index);
}



/*********************************************************/
/* cluster allocation functions */



/* return < 0 if error */
static int64_t alloc_clusters_noref(BlockDriverState *bs, int64_t size)
{
    BDRVQcowState *s = bs->opaque;
544
    int i, nb_clusters, refcount;
K
Kevin Wolf 已提交
545 546 547 548

    nb_clusters = size_to_clusters(s, size);
retry:
    for(i = 0; i < nb_clusters; i++) {
549
        int64_t next_cluster_index = s->free_cluster_index++;
550 551 552 553 554
        refcount = get_refcount(bs, next_cluster_index);

        if (refcount < 0) {
            return refcount;
        } else if (refcount != 0) {
K
Kevin Wolf 已提交
555
            goto retry;
556
        }
K
Kevin Wolf 已提交
557 558
    }
#ifdef DEBUG_ALLOC2
559
    printf("alloc_clusters: size=%" PRId64 " -> %" PRId64 "\n",
K
Kevin Wolf 已提交
560 561 562 563 564 565
            size,
            (s->free_cluster_index - nb_clusters) << s->cluster_bits);
#endif
    return (s->free_cluster_index - nb_clusters) << s->cluster_bits;
}

K
Kevin Wolf 已提交
566
int64_t qcow2_alloc_clusters(BlockDriverState *bs, int64_t size)
K
Kevin Wolf 已提交
567 568
{
    int64_t offset;
569
    int ret;
K
Kevin Wolf 已提交
570

571
    BLKDBG_EVENT(bs->file, BLKDBG_CLUSTER_ALLOC);
K
Kevin Wolf 已提交
572
    offset = alloc_clusters_noref(bs, size);
573 574 575 576
    if (offset < 0) {
        return offset;
    }

577 578 579 580
    ret = update_refcount(bs, offset, size, 1);
    if (ret < 0) {
        return ret;
    }
581

K
Kevin Wolf 已提交
582 583 584 585 586
    return offset;
}

/* only used to allocate compressed sectors. We try to allocate
   contiguous sectors. size must be <= cluster_size */
K
Kevin Wolf 已提交
587
int64_t qcow2_alloc_bytes(BlockDriverState *bs, int size)
K
Kevin Wolf 已提交
588 589 590 591 592
{
    BDRVQcowState *s = bs->opaque;
    int64_t offset, cluster_offset;
    int free_in_cluster;

593
    BLKDBG_EVENT(bs->file, BLKDBG_CLUSTER_ALLOC_BYTES);
K
Kevin Wolf 已提交
594 595
    assert(size > 0 && size <= s->cluster_size);
    if (s->free_byte_offset == 0) {
K
Kevin Wolf 已提交
596
        s->free_byte_offset = qcow2_alloc_clusters(bs, s->cluster_size);
597 598 599
        if (s->free_byte_offset < 0) {
            return s->free_byte_offset;
        }
K
Kevin Wolf 已提交
600 601 602 603 604 605 606 607 608 609 610 611 612 613
    }
 redo:
    free_in_cluster = s->cluster_size -
        (s->free_byte_offset & (s->cluster_size - 1));
    if (size <= free_in_cluster) {
        /* enough space in current cluster */
        offset = s->free_byte_offset;
        s->free_byte_offset += size;
        free_in_cluster -= size;
        if (free_in_cluster == 0)
            s->free_byte_offset = 0;
        if ((offset & (s->cluster_size - 1)) != 0)
            update_cluster_refcount(bs, offset >> s->cluster_bits, 1);
    } else {
K
Kevin Wolf 已提交
614
        offset = qcow2_alloc_clusters(bs, s->cluster_size);
615 616 617
        if (offset < 0) {
            return offset;
        }
K
Kevin Wolf 已提交
618 619 620 621 622 623 624 625 626 627 628
        cluster_offset = s->free_byte_offset & ~(s->cluster_size - 1);
        if ((cluster_offset + s->cluster_size) == offset) {
            /* we are lucky: contiguous data */
            offset = s->free_byte_offset;
            update_cluster_refcount(bs, offset >> s->cluster_bits, 1);
            s->free_byte_offset += size;
        } else {
            s->free_byte_offset = offset;
            goto redo;
        }
    }
629 630

    bdrv_flush(bs->file);
K
Kevin Wolf 已提交
631 632 633
    return offset;
}

K
Kevin Wolf 已提交
634
void qcow2_free_clusters(BlockDriverState *bs,
K
Kevin Wolf 已提交
635 636
                          int64_t offset, int64_t size)
{
637 638
    int ret;

639
    BLKDBG_EVENT(bs->file, BLKDBG_CLUSTER_FREE);
640 641 642
    ret = update_refcount(bs, offset, size, -1);
    if (ret < 0) {
        fprintf(stderr, "qcow2_free_clusters failed: %s\n", strerror(-ret));
643
        /* TODO Remember the clusters to free them later and avoid leaking */
644
    }
K
Kevin Wolf 已提交
645 646
}

647 648 649 650 651 652 653
/*
 * free_any_clusters
 *
 * free clusters according to its type: compressed or not
 *
 */

K
Kevin Wolf 已提交
654
void qcow2_free_any_clusters(BlockDriverState *bs,
655 656 657 658 659 660 661 662 663 664
    uint64_t cluster_offset, int nb_clusters)
{
    BDRVQcowState *s = bs->opaque;

    /* free the cluster */

    if (cluster_offset & QCOW_OFLAG_COMPRESSED) {
        int nb_csectors;
        nb_csectors = ((cluster_offset >> s->csize_shift) &
                       s->csize_mask) + 1;
K
Kevin Wolf 已提交
665 666 667
        qcow2_free_clusters(bs,
            (cluster_offset & s->cluster_offset_mask) & ~511,
            nb_csectors * 512);
668 669 670
        return;
    }

K
Kevin Wolf 已提交
671
    qcow2_free_clusters(bs, cluster_offset, nb_clusters << s->cluster_bits);
672 673 674 675

    return;
}

K
Kevin Wolf 已提交
676 677 678 679 680 681 682


/*********************************************************/
/* snapshots and image creation */



K
Kevin Wolf 已提交
683 684
void qcow2_create_refcount_update(QCowCreateState *s, int64_t offset,
    int64_t size)
K
Kevin Wolf 已提交
685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701
{
    int refcount;
    int64_t start, last, cluster_offset;
    uint16_t *p;

    start = offset & ~(s->cluster_size - 1);
    last = (offset + size - 1)  & ~(s->cluster_size - 1);
    for(cluster_offset = start; cluster_offset <= last;
        cluster_offset += s->cluster_size) {
        p = &s->refcount_block[cluster_offset >> s->cluster_bits];
        refcount = be16_to_cpu(*p);
        refcount++;
        *p = cpu_to_be16(refcount);
    }
}

/* update the refcounts of snapshots and the copied flag */
K
Kevin Wolf 已提交
702 703
int qcow2_update_snapshot_refcount(BlockDriverState *bs,
    int64_t l1_table_offset, int l1_size, int addend)
K
Kevin Wolf 已提交
704 705 706 707
{
    BDRVQcowState *s = bs->opaque;
    uint64_t *l1_table, *l2_table, l2_offset, offset, l1_size2, l1_allocated;
    int64_t old_offset, old_l2_offset;
708
    int i, j, l1_modified = 0, nb_csectors, refcount;
K
Kevin Wolf 已提交
709
    int ret;
710 711 712 713 714 715 716
    bool old_l2_writethrough, old_refcount_writethrough;

    /* Switch caches to writeback mode during update */
    old_l2_writethrough =
        qcow2_cache_set_writethrough(bs, s->l2_table_cache, false);
    old_refcount_writethrough =
        qcow2_cache_set_writethrough(bs, s->refcount_block_cache, false);
K
Kevin Wolf 已提交
717 718 719 720 721

    l2_table = NULL;
    l1_table = NULL;
    l1_size2 = l1_size * sizeof(uint64_t);
    if (l1_table_offset != s->l1_table_offset) {
722 723 724 725 726
        if (l1_size2 != 0) {
            l1_table = qemu_mallocz(align_offset(l1_size2, 512));
        } else {
            l1_table = NULL;
        }
K
Kevin Wolf 已提交
727
        l1_allocated = 1;
728
        if (bdrv_pread(bs->file, l1_table_offset,
K
Kevin Wolf 已提交
729
                       l1_table, l1_size2) != l1_size2)
730 731
        {
            ret = -EIO;
K
Kevin Wolf 已提交
732
            goto fail;
733 734
        }

K
Kevin Wolf 已提交
735 736 737 738 739 740 741 742 743 744 745 746 747
        for(i = 0;i < l1_size; i++)
            be64_to_cpus(&l1_table[i]);
    } else {
        assert(l1_size == s->l1_size);
        l1_table = s->l1_table;
        l1_allocated = 0;
    }

    for(i = 0; i < l1_size; i++) {
        l2_offset = l1_table[i];
        if (l2_offset) {
            old_l2_offset = l2_offset;
            l2_offset &= ~QCOW_OFLAG_COPIED;
K
Kevin Wolf 已提交
748 749 750 751

            ret = qcow2_cache_get(bs, s->l2_table_cache, l2_offset,
                (void**) &l2_table);
            if (ret < 0) {
K
Kevin Wolf 已提交
752
                goto fail;
K
Kevin Wolf 已提交
753 754
            }

K
Kevin Wolf 已提交
755 756 757 758 759 760 761 762
            for(j = 0; j < s->l2_size; j++) {
                offset = be64_to_cpu(l2_table[j]);
                if (offset != 0) {
                    old_offset = offset;
                    offset &= ~QCOW_OFLAG_COPIED;
                    if (offset & QCOW_OFLAG_COMPRESSED) {
                        nb_csectors = ((offset >> s->csize_shift) &
                                       s->csize_mask) + 1;
763 764 765 766 767 768 769 770
                        if (addend != 0) {
                            int ret;
                            ret = update_refcount(bs,
                                (offset & s->cluster_offset_mask) & ~511,
                                nb_csectors * 512, addend);
                            if (ret < 0) {
                                goto fail;
                            }
771 772 773 774

                            /* TODO Flushing once for the whole function should
                             * be enough */
                            bdrv_flush(bs->file);
775
                        }
K
Kevin Wolf 已提交
776 777 778 779 780 781 782 783
                        /* compressed clusters are never modified */
                        refcount = 2;
                    } else {
                        if (addend != 0) {
                            refcount = update_cluster_refcount(bs, offset >> s->cluster_bits, addend);
                        } else {
                            refcount = get_refcount(bs, offset >> s->cluster_bits);
                        }
784 785

                        if (refcount < 0) {
786
                            ret = -EIO;
787 788
                            goto fail;
                        }
K
Kevin Wolf 已提交
789 790 791 792 793 794
                    }

                    if (refcount == 1) {
                        offset |= QCOW_OFLAG_COPIED;
                    }
                    if (offset != old_offset) {
K
Kevin Wolf 已提交
795 796 797 798
                        if (addend > 0) {
                            qcow2_cache_set_dependency(bs, s->l2_table_cache,
                                s->refcount_block_cache);
                        }
K
Kevin Wolf 已提交
799
                        l2_table[j] = cpu_to_be64(offset);
K
Kevin Wolf 已提交
800
                        qcow2_cache_entry_mark_dirty(s->l2_table_cache, l2_table);
K
Kevin Wolf 已提交
801 802 803
                    }
                }
            }
K
Kevin Wolf 已提交
804 805 806 807

            ret = qcow2_cache_put(bs, s->l2_table_cache, (void**) &l2_table);
            if (ret < 0) {
                goto fail;
K
Kevin Wolf 已提交
808 809
            }

K
Kevin Wolf 已提交
810

K
Kevin Wolf 已提交
811 812 813 814 815
            if (addend != 0) {
                refcount = update_cluster_refcount(bs, l2_offset >> s->cluster_bits, addend);
            } else {
                refcount = get_refcount(bs, l2_offset >> s->cluster_bits);
            }
816
            if (refcount < 0) {
817
                ret = -EIO;
818 819
                goto fail;
            } else if (refcount == 1) {
K
Kevin Wolf 已提交
820 821 822 823 824 825 826 827
                l2_offset |= QCOW_OFLAG_COPIED;
            }
            if (l2_offset != old_l2_offset) {
                l1_table[i] = l2_offset;
                l1_modified = 1;
            }
        }
    }
828 829 830 831 832 833 834 835 836 837 838 839

    ret = 0;
fail:
    if (l2_table) {
        qcow2_cache_put(bs, s->l2_table_cache, (void**) &l2_table);
    }

    /* Enable writethrough cache mode again */
    qcow2_cache_set_writethrough(bs, s->l2_table_cache, old_l2_writethrough);
    qcow2_cache_set_writethrough(bs, s->refcount_block_cache,
        old_refcount_writethrough);

K
Kevin Wolf 已提交
840 841 842
    if (l1_modified) {
        for(i = 0; i < l1_size; i++)
            cpu_to_be64s(&l1_table[i]);
843 844
        if (bdrv_pwrite_sync(bs->file, l1_table_offset, l1_table,
                        l1_size2) < 0)
K
Kevin Wolf 已提交
845 846 847 848 849 850
            goto fail;
        for(i = 0; i < l1_size; i++)
            be64_to_cpus(&l1_table[i]);
    }
    if (l1_allocated)
        qemu_free(l1_table);
851
    return ret;
K
Kevin Wolf 已提交
852 853 854 855 856 857 858 859 860 861 862 863 864 865 866
}




/*********************************************************/
/* refcount checking functions */



/*
 * Increases the refcount for a range of clusters in a given refcount table.
 * This is used to construct a temporary refcount table out of L1 and L2 tables
 * which can be compared the the refcount table saved in the image.
 *
867
 * Modifies the number of errors in res.
K
Kevin Wolf 已提交
868
 */
869 870
static void inc_refcounts(BlockDriverState *bs,
                          BdrvCheckResult *res,
K
Kevin Wolf 已提交
871 872 873 874 875 876 877 878 879
                          uint16_t *refcount_table,
                          int refcount_table_size,
                          int64_t offset, int64_t size)
{
    BDRVQcowState *s = bs->opaque;
    int64_t start, last, cluster_offset;
    int k;

    if (size <= 0)
880
        return;
K
Kevin Wolf 已提交
881 882 883 884 885 886

    start = offset & ~(s->cluster_size - 1);
    last = (offset + size - 1) & ~(s->cluster_size - 1);
    for(cluster_offset = start; cluster_offset <= last;
        cluster_offset += s->cluster_size) {
        k = cluster_offset >> s->cluster_bits;
887
        if (k < 0) {
K
Kevin Wolf 已提交
888 889
            fprintf(stderr, "ERROR: invalid cluster offset=0x%" PRIx64 "\n",
                cluster_offset);
890 891 892 893 894 895
            res->corruptions++;
        } else if (k >= refcount_table_size) {
            fprintf(stderr, "Warning: cluster offset=0x%" PRIx64 " is after "
                "the end of the image file, can't properly check refcounts.\n",
                cluster_offset);
            res->check_errors++;
K
Kevin Wolf 已提交
896 897 898 899
        } else {
            if (++refcount_table[k] == 0) {
                fprintf(stderr, "ERROR: overflow cluster offset=0x%" PRIx64
                    "\n", cluster_offset);
900
                res->corruptions++;
K
Kevin Wolf 已提交
901 902 903 904 905 906 907 908 909 910 911 912 913
            }
        }
    }
}

/*
 * Increases the refcount in the given refcount table for the all clusters
 * referenced in the L2 table. While doing so, performs some checks on L2
 * entries.
 *
 * Returns the number of errors found by the checks or -errno if an internal
 * error occurred.
 */
914
static int check_refcounts_l2(BlockDriverState *bs, BdrvCheckResult *res,
K
Kevin Wolf 已提交
915 916 917 918 919 920 921 922 923 924 925
    uint16_t *refcount_table, int refcount_table_size, int64_t l2_offset,
    int check_copied)
{
    BDRVQcowState *s = bs->opaque;
    uint64_t *l2_table, offset;
    int i, l2_size, nb_csectors, refcount;

    /* Read L2 table from disk */
    l2_size = s->l2_size * sizeof(uint64_t);
    l2_table = qemu_malloc(l2_size);

926
    if (bdrv_pread(bs->file, l2_offset, l2_table, l2_size) != l2_size)
K
Kevin Wolf 已提交
927 928 929 930 931 932 933 934 935 936 937 938 939
        goto fail;

    /* Do the actual checks */
    for(i = 0; i < s->l2_size; i++) {
        offset = be64_to_cpu(l2_table[i]);
        if (offset != 0) {
            if (offset & QCOW_OFLAG_COMPRESSED) {
                /* Compressed clusters don't have QCOW_OFLAG_COPIED */
                if (offset & QCOW_OFLAG_COPIED) {
                    fprintf(stderr, "ERROR: cluster %" PRId64 ": "
                        "copied flag must never be set for compressed "
                        "clusters\n", offset >> s->cluster_bits);
                    offset &= ~QCOW_OFLAG_COPIED;
940
                    res->corruptions++;
K
Kevin Wolf 已提交
941 942 943 944 945 946
                }

                /* Mark cluster as used */
                nb_csectors = ((offset >> s->csize_shift) &
                               s->csize_mask) + 1;
                offset &= s->cluster_offset_mask;
947 948
                inc_refcounts(bs, res, refcount_table, refcount_table_size,
                    offset & ~511, nb_csectors * 512);
K
Kevin Wolf 已提交
949 950 951 952 953 954
            } else {
                /* QCOW_OFLAG_COPIED must be set iff refcount == 1 */
                if (check_copied) {
                    uint64_t entry = offset;
                    offset &= ~QCOW_OFLAG_COPIED;
                    refcount = get_refcount(bs, offset >> s->cluster_bits);
955 956 957
                    if (refcount < 0) {
                        fprintf(stderr, "Can't get refcount for offset %"
                            PRIx64 ": %s\n", entry, strerror(-refcount));
958
                        goto fail;
959
                    }
K
Kevin Wolf 已提交
960 961 962
                    if ((refcount == 1) != ((entry & QCOW_OFLAG_COPIED) != 0)) {
                        fprintf(stderr, "ERROR OFLAG_COPIED: offset=%"
                            PRIx64 " refcount=%d\n", entry, refcount);
963
                        res->corruptions++;
K
Kevin Wolf 已提交
964 965 966 967 968
                    }
                }

                /* Mark cluster as used */
                offset &= ~QCOW_OFLAG_COPIED;
969 970
                inc_refcounts(bs, res, refcount_table,refcount_table_size,
                    offset, s->cluster_size);
K
Kevin Wolf 已提交
971 972 973 974 975

                /* Correct offsets are cluster aligned */
                if (offset & (s->cluster_size - 1)) {
                    fprintf(stderr, "ERROR offset=%" PRIx64 ": Cluster is not "
                        "properly aligned; L2 entry corrupted.\n", offset);
976
                    res->corruptions++;
K
Kevin Wolf 已提交
977 978 979 980 981 982
                }
            }
        }
    }

    qemu_free(l2_table);
983
    return 0;
K
Kevin Wolf 已提交
984 985

fail:
986
    fprintf(stderr, "ERROR: I/O error in check_refcounts_l2\n");
K
Kevin Wolf 已提交
987 988 989 990 991 992 993 994 995 996 997 998 999
    qemu_free(l2_table);
    return -EIO;
}

/*
 * Increases the refcount for the L1 table, its L2 tables and all referenced
 * clusters in the given refcount table. While doing so, performs some checks
 * on L1 and L2 entries.
 *
 * Returns the number of errors found by the checks or -errno if an internal
 * error occurred.
 */
static int check_refcounts_l1(BlockDriverState *bs,
1000
                              BdrvCheckResult *res,
K
Kevin Wolf 已提交
1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012
                              uint16_t *refcount_table,
                              int refcount_table_size,
                              int64_t l1_table_offset, int l1_size,
                              int check_copied)
{
    BDRVQcowState *s = bs->opaque;
    uint64_t *l1_table, l2_offset, l1_size2;
    int i, refcount, ret;

    l1_size2 = l1_size * sizeof(uint64_t);

    /* Mark L1 table as used */
1013 1014
    inc_refcounts(bs, res, refcount_table, refcount_table_size,
        l1_table_offset, l1_size2);
K
Kevin Wolf 已提交
1015 1016

    /* Read L1 table entries from disk */
1017 1018 1019 1020
    if (l1_size2 == 0) {
        l1_table = NULL;
    } else {
        l1_table = qemu_malloc(l1_size2);
1021
        if (bdrv_pread(bs->file, l1_table_offset,
1022 1023 1024 1025 1026
                       l1_table, l1_size2) != l1_size2)
            goto fail;
        for(i = 0;i < l1_size; i++)
            be64_to_cpus(&l1_table[i]);
    }
K
Kevin Wolf 已提交
1027 1028 1029 1030 1031 1032 1033 1034 1035

    /* Do the actual checks */
    for(i = 0; i < l1_size; i++) {
        l2_offset = l1_table[i];
        if (l2_offset) {
            /* QCOW_OFLAG_COPIED must be set iff refcount == 1 */
            if (check_copied) {
                refcount = get_refcount(bs, (l2_offset & ~QCOW_OFLAG_COPIED)
                    >> s->cluster_bits);
1036 1037 1038
                if (refcount < 0) {
                    fprintf(stderr, "Can't get refcount for l2_offset %"
                        PRIx64 ": %s\n", l2_offset, strerror(-refcount));
1039
                    goto fail;
1040
                }
K
Kevin Wolf 已提交
1041 1042 1043
                if ((refcount == 1) != ((l2_offset & QCOW_OFLAG_COPIED) != 0)) {
                    fprintf(stderr, "ERROR OFLAG_COPIED: l2_offset=%" PRIx64
                        " refcount=%d\n", l2_offset, refcount);
1044
                    res->corruptions++;
K
Kevin Wolf 已提交
1045 1046 1047 1048 1049
                }
            }

            /* Mark L2 table as used */
            l2_offset &= ~QCOW_OFLAG_COPIED;
1050 1051
            inc_refcounts(bs, res, refcount_table, refcount_table_size,
                l2_offset, s->cluster_size);
K
Kevin Wolf 已提交
1052 1053 1054 1055 1056

            /* L2 tables are cluster aligned */
            if (l2_offset & (s->cluster_size - 1)) {
                fprintf(stderr, "ERROR l2_offset=%" PRIx64 ": Table is not "
                    "cluster aligned; L1 entry corrupted\n", l2_offset);
1057
                res->corruptions++;
K
Kevin Wolf 已提交
1058 1059 1060
            }

            /* Process and check L2 entries */
1061 1062
            ret = check_refcounts_l2(bs, res, refcount_table,
                refcount_table_size, l2_offset, check_copied);
K
Kevin Wolf 已提交
1063 1064 1065 1066 1067 1068
            if (ret < 0) {
                goto fail;
            }
        }
    }
    qemu_free(l1_table);
1069
    return 0;
K
Kevin Wolf 已提交
1070 1071 1072

fail:
    fprintf(stderr, "ERROR: I/O error in check_refcounts_l1\n");
1073
    res->check_errors++;
K
Kevin Wolf 已提交
1074 1075 1076 1077 1078 1079 1080 1081
    qemu_free(l1_table);
    return -EIO;
}

/*
 * Checks an image for refcount consistency.
 *
 * Returns 0 if no errors are found, the number of errors in case the image is
1082
 * detected as corrupted, and -errno when an internal error occurred.
K
Kevin Wolf 已提交
1083
 */
1084
int qcow2_check_refcounts(BlockDriverState *bs, BdrvCheckResult *res)
K
Kevin Wolf 已提交
1085 1086 1087 1088 1089 1090
{
    BDRVQcowState *s = bs->opaque;
    int64_t size;
    int nb_clusters, refcount1, refcount2, i;
    QCowSnapshot *sn;
    uint16_t *refcount_table;
1091
    int ret;
K
Kevin Wolf 已提交
1092

1093
    size = bdrv_getlength(bs->file);
K
Kevin Wolf 已提交
1094 1095 1096 1097
    nb_clusters = size_to_clusters(s, size);
    refcount_table = qemu_mallocz(nb_clusters * sizeof(uint16_t));

    /* header */
1098 1099
    inc_refcounts(bs, res, refcount_table, nb_clusters,
        0, s->cluster_size);
K
Kevin Wolf 已提交
1100 1101

    /* current L1 table */
1102
    ret = check_refcounts_l1(bs, res, refcount_table, nb_clusters,
K
Kevin Wolf 已提交
1103 1104
                       s->l1_table_offset, s->l1_size, 1);
    if (ret < 0) {
1105
        goto fail;
K
Kevin Wolf 已提交
1106 1107 1108 1109 1110
    }

    /* snapshots */
    for(i = 0; i < s->nb_snapshots; i++) {
        sn = s->snapshots + i;
1111 1112 1113
        ret = check_refcounts_l1(bs, res, refcount_table, nb_clusters,
            sn->l1_table_offset, sn->l1_size, 0);
        if (ret < 0) {
1114
            goto fail;
1115
        }
K
Kevin Wolf 已提交
1116
    }
1117 1118
    inc_refcounts(bs, res, refcount_table, nb_clusters,
        s->snapshots_offset, s->snapshots_size);
K
Kevin Wolf 已提交
1119 1120

    /* refcount data */
1121 1122 1123 1124
    inc_refcounts(bs, res, refcount_table, nb_clusters,
        s->refcount_table_offset,
        s->refcount_table_size * sizeof(uint64_t));

K
Kevin Wolf 已提交
1125
    for(i = 0; i < s->refcount_table_size; i++) {
1126
        uint64_t offset, cluster;
K
Kevin Wolf 已提交
1127
        offset = s->refcount_table[i];
1128
        cluster = offset >> s->cluster_bits;
1129 1130 1131 1132 1133

        /* Refcount blocks are cluster aligned */
        if (offset & (s->cluster_size - 1)) {
            fprintf(stderr, "ERROR refcount block %d is not "
                "cluster aligned; refcount table entry corrupted\n", i);
1134
            res->corruptions++;
1135 1136 1137 1138 1139
            continue;
        }

        if (cluster >= nb_clusters) {
            fprintf(stderr, "ERROR refcount block %d is outside image\n", i);
1140
            res->corruptions++;
1141
            continue;
1142 1143
        }

K
Kevin Wolf 已提交
1144
        if (offset != 0) {
1145 1146
            inc_refcounts(bs, res, refcount_table, nb_clusters,
                offset, s->cluster_size);
1147
            if (refcount_table[cluster] != 1) {
1148
                fprintf(stderr, "ERROR refcount block %d refcount=%d\n",
1149
                    i, refcount_table[cluster]);
1150
                res->corruptions++;
1151
            }
K
Kevin Wolf 已提交
1152 1153 1154 1155 1156 1157
        }
    }

    /* compare ref counts */
    for(i = 0; i < nb_clusters; i++) {
        refcount1 = get_refcount(bs, i);
1158 1159 1160
        if (refcount1 < 0) {
            fprintf(stderr, "Can't get refcount for cluster %d: %s\n",
                i, strerror(-refcount1));
1161
            res->check_errors++;
1162
            continue;
1163 1164
        }

K
Kevin Wolf 已提交
1165 1166
        refcount2 = refcount_table[i];
        if (refcount1 != refcount2) {
1167 1168
            fprintf(stderr, "%s cluster %d refcount=%d reference=%d\n",
                   refcount1 < refcount2 ? "ERROR" : "Leaked",
K
Kevin Wolf 已提交
1169
                   i, refcount1, refcount2);
1170 1171 1172 1173 1174
            if (refcount1 < refcount2) {
                res->corruptions++;
            } else {
                res->leaks++;
            }
K
Kevin Wolf 已提交
1175 1176 1177
        }
    }

1178 1179 1180
    ret = 0;

fail:
K
Kevin Wolf 已提交
1181 1182
    qemu_free(refcount_table);

1183
    return ret;
K
Kevin Wolf 已提交
1184 1185
}