blob: 9b937a446b7382ddbea7194a88d44e9fa8b54462 [file] [log] [blame]
Juan Quintela7b1e1a22017-04-17 20:26:27 +02001/*
2 * QEMU System Emulator
3 *
4 * Copyright (c) 2003-2008 Fabrice Bellard
5 * Copyright (c) 2011-2015 Red Hat Inc
6 *
7 * Authors:
8 * Juan Quintela <quintela@redhat.com>
9 *
10 * Permission is hereby granted, free of charge, to any person obtaining a copy
11 * of this software and associated documentation files (the "Software"), to deal
12 * in the Software without restriction, including without limitation the rights
13 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14 * copies of the Software, and to permit persons to whom the Software is
15 * furnished to do so, subject to the following conditions:
16 *
17 * The above copyright notice and this permission notice shall be included in
18 * all copies or substantial portions of the Software.
19 *
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
23 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
25 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
26 * THE SOFTWARE.
27 */
28
29#ifndef QEMU_MIGRATION_RAM_H
30#define QEMU_MIGRATION_RAM_H
31
Markus Armbruster9af23982018-02-11 10:36:01 +010032#include "qapi/qapi-types-migration.h"
Juan Quintela7b1e1a22017-04-17 20:26:27 +020033#include "exec/cpu-common.h"
Juan Quintela71bb07d2018-02-19 19:01:03 +010034#include "io/channel.h"
Juan Quintela7b1e1a22017-04-17 20:26:27 +020035
Juan Quintela93604472017-06-06 19:49:03 +020036extern XBZRLECacheStats xbzrle_counters;
37
Chuan Zheng3ded54b2020-09-16 14:22:00 +080038/* Should be holding either ram_list.mutex, or the RCU lock. */
39#define RAMBLOCK_FOREACH_NOT_IGNORED(block) \
40 INTERNAL_RAMBLOCK_FOREACH(block) \
David Hildenbrandf161c882023-07-06 09:56:08 +020041 if (migrate_ram_is_ignored(block)) {} else
Chuan Zheng3ded54b2020-09-16 14:22:00 +080042
43#define RAMBLOCK_FOREACH_MIGRATABLE(block) \
44 INTERNAL_RAMBLOCK_FOREACH(block) \
45 if (!qemu_ram_is_migratable(block)) {} else
46
Markus Armbruster8b9407a2021-02-02 15:17:32 +010047int xbzrle_cache_resize(uint64_t new_size, Error **errp);
Juan Quintela7b1e1a22017-04-17 20:26:27 +020048uint64_t ram_bytes_remaining(void);
Juan Quintela7b1e1a22017-04-17 20:26:27 +020049uint64_t ram_bytes_total(void);
Rao, Lei91fe9a82021-11-09 11:04:54 +080050void mig_throttle_counter_reset(void);
Juan Quintela7b1e1a22017-04-17 20:26:27 +020051
Juan Quintela7b1e1a22017-04-17 20:26:27 +020052uint64_t ram_pagesize_summary(void);
Peter Xu7aa60702023-10-17 16:26:29 -040053int ram_save_queue_pages(const char *rbname, ram_addr_t start, ram_addr_t len,
54 Error **errp);
Juan Quintela7b1e1a22017-04-17 20:26:27 +020055void ram_postcopy_migrated_memory_release(MigrationState *ms);
56/* For outgoing discard bitmap */
Peter Xu739fcc12021-12-07 19:50:14 +080057void ram_postcopy_send_discard_bitmap(MigrationState *ms);
Juan Quintela7b1e1a22017-04-17 20:26:27 +020058/* For incoming postcopy discard */
59int ram_discard_range(const char *block_name, uint64_t start, size_t length);
60int ram_postcopy_incoming_init(MigrationIncomingState *mis);
Peter Xu36f62f12022-07-07 14:55:02 -040061int ram_load_postcopy(QEMUFile *f, int channel);
Juan Quintela7b1e1a22017-04-17 20:26:27 +020062
Juan Quintela7091dab2023-10-19 10:52:59 +020063void ram_handle_zero(void *host, uint64_t size);
Alexey Perevalovf9494612017-10-05 14:13:20 +030064
Juan Quintela26a26062022-02-22 21:02:03 +010065void ram_transferred_add(uint64_t bytes);
Juan Quintelaa4dbaf82021-12-16 10:19:38 +010066void ram_release_page(const char *rbname, uint64_t offset);
Juan Quintela26a26062022-02-22 21:02:03 +010067
Alexey Perevalovf9494612017-10-05 14:13:20 +030068int ramblock_recv_bitmap_test(RAMBlock *rb, void *host_addr);
Dr. David Alan Gilbert1cba9f62018-03-12 17:21:08 +000069bool ramblock_recv_bitmap_test_byte_offset(RAMBlock *rb, uint64_t byte_offset);
Alexey Perevalovf9494612017-10-05 14:13:20 +030070void ramblock_recv_bitmap_set(RAMBlock *rb, void *host_addr);
71void ramblock_recv_bitmap_set_range(RAMBlock *rb, void *host_addr, size_t nr);
Peter Xua335deb2018-05-02 18:47:28 +080072int64_t ramblock_recv_bitmap_send(QEMUFile *file,
73 const char *block_name);
Peter Xu88577f32023-10-17 16:26:32 -040074bool ram_dirty_bitmap_reload(MigrationState *s, RAMBlock *rb, Error **errp);
David Hildenbrand9470c5e2021-10-11 19:53:43 +020075bool ramblock_page_is_discarded(RAMBlock *rb, ram_addr_t start);
Peter Xu36f62f12022-07-07 14:55:02 -040076void postcopy_preempt_shutdown_file(MigrationState *s);
77void *postcopy_preempt_thread(void *opaque);
Alexey Perevalovf9494612017-10-05 14:13:20 +030078
Zhang Chen13af18f2018-09-03 12:38:48 +080079/* ram cache */
80int colo_init_ram_cache(void);
Lukas Straub24fa16f2020-05-11 13:10:51 +020081void colo_flush_ram_cache(void);
Zhang Chen13af18f2018-09-03 12:38:48 +080082void colo_release_ram_cache(void);
zhanghailiang03930312020-02-24 14:54:10 +080083void colo_incoming_start_dirty_log(void);
Lukas Straub871cfc52023-05-08 21:10:52 +020084void colo_record_bitmap(RAMBlock *block, ram_addr_t *normal, uint32_t pages);
Zhang Chen13af18f2018-09-03 12:38:48 +080085
Andrey Gruzdev6e8c25b2021-01-29 13:14:03 +030086/* Background snapshot */
87bool ram_write_tracking_available(void);
88bool ram_write_tracking_compatible(void);
Andrey Gruzdeveeccb992021-04-01 12:22:25 +030089void ram_write_tracking_prepare(void);
Andrey Gruzdev278e2f52021-01-29 13:14:05 +030090int ram_write_tracking_start(void);
91void ram_write_tracking_stop(void);
Andrey Gruzdev6e8c25b2021-01-29 13:14:03 +030092
Juan Quintela7b1e1a22017-04-17 20:26:27 +020093#endif