Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 1 | /* |
| 2 | * QEMU Host Memory Backend for hugetlbfs |
| 3 | * |
| 4 | * Copyright (C) 2013-2014 Red Hat Inc |
| 5 | * |
| 6 | * Authors: |
| 7 | * Paolo Bonzini <pbonzini@redhat.com> |
| 8 | * |
| 9 | * This work is licensed under the terms of the GNU GPL, version 2 or later. |
| 10 | * See the COPYING file in the top-level directory. |
| 11 | */ |
Markus Armbruster | 0b8fa32 | 2019-05-23 16:35:07 +0200 | [diff] [blame] | 12 | |
Peter Maydell | 9c05833 | 2016-01-29 17:49:54 +0000 | [diff] [blame] | 13 | #include "qemu/osdep.h" |
Markus Armbruster | da34e65 | 2016-03-14 09:01:28 +0100 | [diff] [blame] | 14 | #include "qapi/error.h" |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 15 | #include "qemu/error-report.h" |
Markus Armbruster | 0b8fa32 | 2019-05-23 16:35:07 +0200 | [diff] [blame] | 16 | #include "qemu/module.h" |
Peter Maydell | b85ea5f | 2022-02-08 20:08:52 +0000 | [diff] [blame] | 17 | #include "qemu/madvise.h" |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 18 | #include "sysemu/hostmem.h" |
| 19 | #include "qom/object_interfaces.h" |
Eduardo Habkost | db1015e | 2020-09-03 16:43:22 -0400 | [diff] [blame] | 20 | #include "qom/object.h" |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 21 | #include "qapi/visitor.h" |
| 22 | #include "qapi/qapi-visit-common.h" |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 23 | |
Eduardo Habkost | 8063396 | 2020-09-16 14:25:19 -0400 | [diff] [blame] | 24 | OBJECT_DECLARE_SIMPLE_TYPE(HostMemoryBackendFile, MEMORY_BACKEND_FILE) |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 25 | |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 26 | |
| 27 | struct HostMemoryBackendFile { |
| 28 | HostMemoryBackend parent_obj; |
Paolo Bonzini | dbcb898 | 2014-06-10 19:15:24 +0800 | [diff] [blame] | 29 | |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 30 | char *mem_path; |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 31 | uint64_t align; |
Alexander Graf | 4b870dc | 2023-04-03 22:14:21 +0000 | [diff] [blame] | 32 | uint64_t offset; |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 33 | bool discard_data; |
| 34 | bool is_pmem; |
Stefan Hajnoczi | 86635aa | 2021-01-04 17:13:19 +0000 | [diff] [blame] | 35 | bool readonly; |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 36 | OnOffAuto rom; |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 37 | }; |
| 38 | |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 39 | static bool |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 40 | file_backend_memory_alloc(HostMemoryBackend *backend, Error **errp) |
| 41 | { |
Igor Mammedov | 5c7ba87 | 2019-02-14 11:10:03 +0800 | [diff] [blame] | 42 | #ifndef CONFIG_POSIX |
| 43 | error_setg(errp, "backend '%s' not supported on this host", |
| 44 | object_get_typename(OBJECT(backend))); |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 45 | return false; |
Igor Mammedov | 5c7ba87 | 2019-02-14 11:10:03 +0800 | [diff] [blame] | 46 | #else |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 47 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(backend); |
Philippe Mathieu-Daudé | 2d7a1eb | 2023-11-20 12:59:15 +0100 | [diff] [blame] | 48 | g_autofree gchar *name = NULL; |
David Hildenbrand | 9181fb7 | 2021-05-10 13:43:23 +0200 | [diff] [blame] | 49 | uint32_t ram_flags; |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 50 | |
| 51 | if (!backend->size) { |
| 52 | error_setg(errp, "can't create backend with size 0"); |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 53 | return false; |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 54 | } |
| 55 | if (!fb->mem_path) { |
Jan Kiszka | c2cb2b0 | 2015-04-24 19:41:26 +0200 | [diff] [blame] | 56 | error_setg(errp, "mem-path property not set"); |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 57 | return false; |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 58 | } |
Stefan Hajnoczi | 314aec4 | 2019-02-14 11:10:04 +0800 | [diff] [blame] | 59 | |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 60 | switch (fb->rom) { |
| 61 | case ON_OFF_AUTO_AUTO: |
| 62 | /* Traditionally, opening the file readonly always resulted in ROM. */ |
| 63 | fb->rom = fb->readonly ? ON_OFF_AUTO_ON : ON_OFF_AUTO_OFF; |
| 64 | break; |
| 65 | case ON_OFF_AUTO_ON: |
| 66 | if (!fb->readonly) { |
| 67 | error_setg(errp, "property 'rom' = 'on' is not supported with" |
| 68 | " 'readonly' = 'off'"); |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 69 | return false; |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 70 | } |
| 71 | break; |
| 72 | case ON_OFF_AUTO_OFF: |
| 73 | if (fb->readonly && backend->share) { |
| 74 | error_setg(errp, "property 'rom' = 'off' is incompatible with" |
| 75 | " 'readonly' = 'on' and 'share' = 'on'"); |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 76 | return false; |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 77 | } |
| 78 | break; |
| 79 | default: |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 80 | g_assert_not_reached(); |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 81 | } |
| 82 | |
Michal Privoznik | 5d9a9a6 | 2024-06-05 12:44:58 +0200 | [diff] [blame] | 83 | backend->aligned = true; |
Marc-André Lureau | fa0cb34 | 2018-09-12 16:18:00 +0400 | [diff] [blame] | 84 | name = host_memory_backend_get_name(backend); |
David Hildenbrand | 9181fb7 | 2021-05-10 13:43:23 +0200 | [diff] [blame] | 85 | ram_flags = backend->share ? RAM_SHARED : 0; |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 86 | ram_flags |= fb->readonly ? RAM_READONLY_FD : 0; |
| 87 | ram_flags |= fb->rom == ON_OFF_AUTO_ON ? RAM_READONLY : 0; |
David Hildenbrand | 9181fb7 | 2021-05-10 13:43:23 +0200 | [diff] [blame] | 88 | ram_flags |= backend->reserve ? 0 : RAM_NORESERVE; |
Xiaoyao Li | 37662d8 | 2024-03-20 03:39:03 -0500 | [diff] [blame] | 89 | ram_flags |= backend->guest_memfd ? RAM_GUEST_MEMFD : 0; |
David Hildenbrand | 9181fb7 | 2021-05-10 13:43:23 +0200 | [diff] [blame] | 90 | ram_flags |= fb->is_pmem ? RAM_PMEM : 0; |
Steve Sistare | b0182e5 | 2023-06-07 08:18:36 -0700 | [diff] [blame] | 91 | ram_flags |= RAM_NAMED_FILE; |
Philippe Mathieu-Daudé | fdb63cf | 2023-11-20 13:50:52 +0100 | [diff] [blame] | 92 | return memory_region_init_ram_from_file(&backend->mr, OBJECT(backend), name, |
| 93 | backend->size, fb->align, ram_flags, |
| 94 | fb->mem_path, fb->offset, errp); |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 95 | #endif |
| 96 | } |
| 97 | |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 98 | static char *get_mem_path(Object *o, Error **errp) |
| 99 | { |
| 100 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 101 | |
| 102 | return g_strdup(fb->mem_path); |
| 103 | } |
| 104 | |
| 105 | static void set_mem_path(Object *o, const char *str, Error **errp) |
| 106 | { |
| 107 | HostMemoryBackend *backend = MEMORY_BACKEND(o); |
| 108 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 109 | |
Peter Xu | 6f4c60e | 2017-03-10 21:09:30 +0800 | [diff] [blame] | 110 | if (host_memory_backend_mr_inited(backend)) { |
Zhang Yi | 21d1683 | 2019-01-02 13:26:24 +0800 | [diff] [blame] | 111 | error_setg(errp, "cannot change property 'mem-path' of %s", |
| 112 | object_get_typename(o)); |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 113 | return; |
| 114 | } |
Daniel P. Berrange | ef1e1e0 | 2015-08-26 12:17:18 +0100 | [diff] [blame] | 115 | g_free(fb->mem_path); |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 116 | fb->mem_path = g_strdup(str); |
| 117 | } |
| 118 | |
Eduardo Habkost | 11ae6ed | 2017-08-24 16:23:15 -0300 | [diff] [blame] | 119 | static bool file_memory_backend_get_discard_data(Object *o, Error **errp) |
| 120 | { |
| 121 | return MEMORY_BACKEND_FILE(o)->discard_data; |
| 122 | } |
| 123 | |
| 124 | static void file_memory_backend_set_discard_data(Object *o, bool value, |
| 125 | Error **errp) |
| 126 | { |
| 127 | MEMORY_BACKEND_FILE(o)->discard_data = value; |
| 128 | } |
| 129 | |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 130 | static void file_memory_backend_get_align(Object *o, Visitor *v, |
| 131 | const char *name, void *opaque, |
| 132 | Error **errp) |
| 133 | { |
| 134 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 135 | uint64_t val = fb->align; |
| 136 | |
| 137 | visit_type_size(v, name, &val, errp); |
| 138 | } |
| 139 | |
| 140 | static void file_memory_backend_set_align(Object *o, Visitor *v, |
| 141 | const char *name, void *opaque, |
| 142 | Error **errp) |
| 143 | { |
| 144 | HostMemoryBackend *backend = MEMORY_BACKEND(o); |
| 145 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 146 | uint64_t val; |
| 147 | |
| 148 | if (host_memory_backend_mr_inited(backend)) { |
Markus Armbruster | dcfe480 | 2020-07-07 18:06:01 +0200 | [diff] [blame] | 149 | error_setg(errp, "cannot change property '%s' of %s", name, |
| 150 | object_get_typename(o)); |
| 151 | return; |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 152 | } |
| 153 | |
Markus Armbruster | 668f62e | 2020-07-07 18:06:02 +0200 | [diff] [blame] | 154 | if (!visit_type_size(v, name, &val, errp)) { |
Markus Armbruster | dcfe480 | 2020-07-07 18:06:01 +0200 | [diff] [blame] | 155 | return; |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 156 | } |
| 157 | fb->align = val; |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 158 | } |
| 159 | |
Alexander Graf | 4b870dc | 2023-04-03 22:14:21 +0000 | [diff] [blame] | 160 | static void file_memory_backend_get_offset(Object *o, Visitor *v, |
| 161 | const char *name, void *opaque, |
| 162 | Error **errp) |
| 163 | { |
| 164 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 165 | uint64_t val = fb->offset; |
| 166 | |
| 167 | visit_type_size(v, name, &val, errp); |
| 168 | } |
| 169 | |
| 170 | static void file_memory_backend_set_offset(Object *o, Visitor *v, |
| 171 | const char *name, void *opaque, |
| 172 | Error **errp) |
| 173 | { |
| 174 | HostMemoryBackend *backend = MEMORY_BACKEND(o); |
| 175 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 176 | uint64_t val; |
| 177 | |
| 178 | if (host_memory_backend_mr_inited(backend)) { |
| 179 | error_setg(errp, "cannot change property '%s' of %s", name, |
| 180 | object_get_typename(o)); |
| 181 | return; |
| 182 | } |
| 183 | |
| 184 | if (!visit_type_size(v, name, &val, errp)) { |
| 185 | return; |
| 186 | } |
| 187 | fb->offset = val; |
| 188 | } |
| 189 | |
Michal Privoznik | def835f | 2021-01-26 08:48:25 +0100 | [diff] [blame] | 190 | #ifdef CONFIG_LIBPMEM |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 191 | static bool file_memory_backend_get_pmem(Object *o, Error **errp) |
| 192 | { |
| 193 | return MEMORY_BACKEND_FILE(o)->is_pmem; |
| 194 | } |
| 195 | |
| 196 | static void file_memory_backend_set_pmem(Object *o, bool value, Error **errp) |
| 197 | { |
| 198 | HostMemoryBackend *backend = MEMORY_BACKEND(o); |
| 199 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 200 | |
| 201 | if (host_memory_backend_mr_inited(backend)) { |
Zhang Yi | 87dc3ce | 2018-10-24 22:14:56 +0800 | [diff] [blame] | 202 | error_setg(errp, "cannot change property 'pmem' of %s.", |
| 203 | object_get_typename(o)); |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 204 | return; |
| 205 | } |
| 206 | |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 207 | fb->is_pmem = value; |
| 208 | } |
Michal Privoznik | def835f | 2021-01-26 08:48:25 +0100 | [diff] [blame] | 209 | #endif /* CONFIG_LIBPMEM */ |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 210 | |
Stefan Hajnoczi | 86635aa | 2021-01-04 17:13:19 +0000 | [diff] [blame] | 211 | static bool file_memory_backend_get_readonly(Object *obj, Error **errp) |
| 212 | { |
| 213 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(obj); |
| 214 | |
| 215 | return fb->readonly; |
| 216 | } |
| 217 | |
| 218 | static void file_memory_backend_set_readonly(Object *obj, bool value, |
| 219 | Error **errp) |
| 220 | { |
| 221 | HostMemoryBackend *backend = MEMORY_BACKEND(obj); |
| 222 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(obj); |
| 223 | |
| 224 | if (host_memory_backend_mr_inited(backend)) { |
| 225 | error_setg(errp, "cannot change property 'readonly' of %s.", |
| 226 | object_get_typename(obj)); |
| 227 | return; |
| 228 | } |
| 229 | |
| 230 | fb->readonly = value; |
| 231 | } |
| 232 | |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 233 | static void file_memory_backend_get_rom(Object *obj, Visitor *v, |
| 234 | const char *name, void *opaque, |
| 235 | Error **errp) |
| 236 | { |
| 237 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(obj); |
| 238 | OnOffAuto rom = fb->rom; |
| 239 | |
| 240 | visit_type_OnOffAuto(v, name, &rom, errp); |
| 241 | } |
| 242 | |
| 243 | static void file_memory_backend_set_rom(Object *obj, Visitor *v, |
| 244 | const char *name, void *opaque, |
| 245 | Error **errp) |
| 246 | { |
| 247 | HostMemoryBackend *backend = MEMORY_BACKEND(obj); |
| 248 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(obj); |
| 249 | |
| 250 | if (host_memory_backend_mr_inited(backend)) { |
| 251 | error_setg(errp, "cannot change property '%s' of %s.", name, |
| 252 | object_get_typename(obj)); |
| 253 | return; |
| 254 | } |
| 255 | |
| 256 | visit_type_OnOffAuto(v, name, &fb->rom, errp); |
| 257 | } |
| 258 | |
Eduardo Habkost | 11ae6ed | 2017-08-24 16:23:15 -0300 | [diff] [blame] | 259 | static void file_backend_unparent(Object *obj) |
| 260 | { |
| 261 | HostMemoryBackend *backend = MEMORY_BACKEND(obj); |
| 262 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(obj); |
| 263 | |
| 264 | if (host_memory_backend_mr_inited(backend) && fb->discard_data) { |
| 265 | void *ptr = memory_region_get_ram_ptr(&backend->mr); |
| 266 | uint64_t sz = memory_region_size(&backend->mr); |
| 267 | |
| 268 | qemu_madvise(ptr, sz, QEMU_MADV_REMOVE); |
| 269 | } |
| 270 | } |
| 271 | |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 272 | static void |
Eduardo Habkost | 026ac48 | 2016-10-13 18:18:41 -0300 | [diff] [blame] | 273 | file_backend_class_init(ObjectClass *oc, void *data) |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 274 | { |
Eduardo Habkost | 026ac48 | 2016-10-13 18:18:41 -0300 | [diff] [blame] | 275 | HostMemoryBackendClass *bc = MEMORY_BACKEND_CLASS(oc); |
| 276 | |
| 277 | bc->alloc = file_backend_memory_alloc; |
Eduardo Habkost | 11ae6ed | 2017-08-24 16:23:15 -0300 | [diff] [blame] | 278 | oc->unparent = file_backend_unparent; |
Eduardo Habkost | 026ac48 | 2016-10-13 18:18:41 -0300 | [diff] [blame] | 279 | |
Eduardo Habkost | 11ae6ed | 2017-08-24 16:23:15 -0300 | [diff] [blame] | 280 | object_class_property_add_bool(oc, "discard-data", |
Markus Armbruster | d262312 | 2020-05-05 17:29:22 +0200 | [diff] [blame] | 281 | file_memory_backend_get_discard_data, file_memory_backend_set_discard_data); |
Eduardo Habkost | 026ac48 | 2016-10-13 18:18:41 -0300 | [diff] [blame] | 282 | object_class_property_add_str(oc, "mem-path", |
Markus Armbruster | d262312 | 2020-05-05 17:29:22 +0200 | [diff] [blame] | 283 | get_mem_path, set_mem_path); |
Haozhong Zhang | 9837684 | 2017-12-11 15:28:04 +0800 | [diff] [blame] | 284 | object_class_property_add(oc, "align", "int", |
| 285 | file_memory_backend_get_align, |
| 286 | file_memory_backend_set_align, |
Markus Armbruster | d262312 | 2020-05-05 17:29:22 +0200 | [diff] [blame] | 287 | NULL, NULL); |
Alexander Graf | 4b870dc | 2023-04-03 22:14:21 +0000 | [diff] [blame] | 288 | object_class_property_add(oc, "offset", "int", |
| 289 | file_memory_backend_get_offset, |
| 290 | file_memory_backend_set_offset, |
| 291 | NULL, NULL); |
| 292 | object_class_property_set_description(oc, "offset", |
| 293 | "Offset into the target file (ex: 1G)"); |
Michal Privoznik | def835f | 2021-01-26 08:48:25 +0100 | [diff] [blame] | 294 | #ifdef CONFIG_LIBPMEM |
Junyan He | a4de855 | 2018-07-18 15:48:00 +0800 | [diff] [blame] | 295 | object_class_property_add_bool(oc, "pmem", |
Markus Armbruster | d262312 | 2020-05-05 17:29:22 +0200 | [diff] [blame] | 296 | file_memory_backend_get_pmem, file_memory_backend_set_pmem); |
Michal Privoznik | def835f | 2021-01-26 08:48:25 +0100 | [diff] [blame] | 297 | #endif |
Stefan Hajnoczi | 86635aa | 2021-01-04 17:13:19 +0000 | [diff] [blame] | 298 | object_class_property_add_bool(oc, "readonly", |
| 299 | file_memory_backend_get_readonly, |
| 300 | file_memory_backend_set_readonly); |
David Hildenbrand | e92666b | 2023-09-06 14:04:55 +0200 | [diff] [blame] | 301 | object_class_property_add(oc, "rom", "OnOffAuto", |
| 302 | file_memory_backend_get_rom, file_memory_backend_set_rom, NULL, NULL); |
| 303 | object_class_property_set_description(oc, "rom", |
| 304 | "Whether to create Read Only Memory (ROM)"); |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 305 | } |
| 306 | |
Marc-André Lureau | bc78a01 | 2016-04-13 18:57:40 +0200 | [diff] [blame] | 307 | static void file_backend_instance_finalize(Object *o) |
| 308 | { |
| 309 | HostMemoryBackendFile *fb = MEMORY_BACKEND_FILE(o); |
| 310 | |
| 311 | g_free(fb->mem_path); |
| 312 | } |
| 313 | |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 314 | static const TypeInfo file_backend_info = { |
| 315 | .name = TYPE_MEMORY_BACKEND_FILE, |
| 316 | .parent = TYPE_MEMORY_BACKEND, |
| 317 | .class_init = file_backend_class_init, |
Marc-André Lureau | bc78a01 | 2016-04-13 18:57:40 +0200 | [diff] [blame] | 318 | .instance_finalize = file_backend_instance_finalize, |
Paolo Bonzini | 52330e1 | 2014-06-10 19:15:21 +0800 | [diff] [blame] | 319 | .instance_size = sizeof(HostMemoryBackendFile), |
| 320 | }; |
| 321 | |
| 322 | static void register_types(void) |
| 323 | { |
| 324 | type_register_static(&file_backend_info); |
| 325 | } |
| 326 | |
| 327 | type_init(register_types); |