7f9241d805
Emulated devices and other BlockBackend users wishing to take advantage of blk_register_buf() all have the same repetitive job: register RAMBlocks with the BlockBackend using RAMBlockNotifier. Add a BlockRAMRegistrar API to do this. A later commit will use this from hw/block/virtio-blk.c. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Reviewed-by: Stefano Garzarella <sgarzare@redhat.com> Message-id: 20221013185908.1297568-10-stefanha@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
38 lines
925 B
C
38 lines
925 B
C
/*
|
|
* BlockBackend RAM Registrar
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
*/
|
|
|
|
#ifndef BLOCK_RAM_REGISTRAR_H
|
|
#define BLOCK_RAM_REGISTRAR_H
|
|
|
|
#include "exec/ramlist.h"
|
|
|
|
/**
|
|
* struct BlockRAMRegistrar:
|
|
*
|
|
* Keeps RAMBlock memory registered with a BlockBackend using
|
|
* blk_register_buf() including hotplugged memory.
|
|
*
|
|
* Emulated devices or other BlockBackend users initialize a BlockRAMRegistrar
|
|
* with blk_ram_registrar_init() before submitting I/O requests with the
|
|
* BDRV_REQ_REGISTERED_BUF flag set.
|
|
*/
|
|
typedef struct {
|
|
BlockBackend *blk;
|
|
RAMBlockNotifier notifier;
|
|
bool ok;
|
|
} BlockRAMRegistrar;
|
|
|
|
void blk_ram_registrar_init(BlockRAMRegistrar *r, BlockBackend *blk);
|
|
void blk_ram_registrar_destroy(BlockRAMRegistrar *r);
|
|
|
|
/* Have all RAMBlocks been registered successfully? */
|
|
static inline bool blk_ram_registrar_ok(BlockRAMRegistrar *r)
|
|
{
|
|
return r->ok;
|
|
}
|
|
|
|
#endif /* BLOCK_RAM_REGISTRAR_H */
|