Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Declarations for obsolete exec.c functions |
| 3 | * |
| 4 | * Copyright 2011 Red Hat, Inc. and/or its affiliates |
| 5 | * |
| 6 | * Authors: |
| 7 | * Avi Kivity <avi@redhat.com> |
| 8 | * |
Paolo Bonzini | 6b620ca | 2012-01-13 17:44:23 +0100 | [diff] [blame] | 9 | * This work is licensed under the terms of the GNU GPL, version 2 or |
| 10 | * later. See the COPYING file in the top-level directory. |
Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 11 | * |
| 12 | */ |
| 13 | |
| 14 | /* |
| 15 | * This header is for use by exec.c and memory.c ONLY. Do not include it. |
| 16 | * The functions declared here will be removed soon. |
| 17 | */ |
| 18 | |
| 19 | #ifndef EXEC_OBSOLETE_H |
| 20 | #define EXEC_OBSOLETE_H |
| 21 | |
| 22 | #ifndef WANT_EXEC_OBSOLETE |
| 23 | #error Do not include exec-obsolete.h |
| 24 | #endif |
| 25 | |
| 26 | #ifndef CONFIG_USER_ONLY |
| 27 | |
Avi Kivity | c5705a7 | 2011-12-20 15:59:12 +0200 | [diff] [blame] | 28 | ram_addr_t qemu_ram_alloc_from_ptr(ram_addr_t size, void *host, |
Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 29 | MemoryRegion *mr); |
Avi Kivity | c5705a7 | 2011-12-20 15:59:12 +0200 | [diff] [blame] | 30 | ram_addr_t qemu_ram_alloc(ram_addr_t size, MemoryRegion *mr); |
Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 31 | void qemu_ram_free(ram_addr_t addr); |
| 32 | void qemu_ram_free_from_ptr(ram_addr_t addr); |
| 33 | |
Avi Kivity | a621f38 | 2012-01-02 13:12:08 +0200 | [diff] [blame] | 34 | struct MemoryRegion; |
| 35 | int cpu_register_io_memory(MemoryRegion *mr); |
Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 36 | void cpu_unregister_io_memory(int table_address); |
| 37 | |
Avi Kivity | dd81124 | 2012-01-02 12:17:03 +0200 | [diff] [blame] | 38 | struct MemoryRegionSection; |
| 39 | void cpu_register_physical_memory_log(struct MemoryRegionSection *section, |
| 40 | bool readable, bool readonly); |
Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 41 | |
| 42 | void qemu_register_coalesced_mmio(target_phys_addr_t addr, ram_addr_t size); |
| 43 | void qemu_unregister_coalesced_mmio(target_phys_addr_t addr, ram_addr_t size); |
| 44 | |
Avi Kivity | 8f77558 | 2011-12-21 14:14:07 +0200 | [diff] [blame] | 45 | int cpu_physical_memory_set_dirty_tracking(int enable); |
| 46 | |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 47 | #define VGA_DIRTY_FLAG 0x01 |
| 48 | #define CODE_DIRTY_FLAG 0x02 |
| 49 | #define MIGRATION_DIRTY_FLAG 0x08 |
| 50 | |
| 51 | /* read dirty bit (return 0 or 1) */ |
| 52 | static inline int cpu_physical_memory_is_dirty(ram_addr_t addr) |
| 53 | { |
| 54 | return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] == 0xff; |
| 55 | } |
| 56 | |
| 57 | static inline int cpu_physical_memory_get_dirty_flags(ram_addr_t addr) |
| 58 | { |
| 59 | return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS]; |
| 60 | } |
| 61 | |
| 62 | static inline int cpu_physical_memory_get_dirty(ram_addr_t addr, |
| 63 | int dirty_flags) |
| 64 | { |
| 65 | return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] & dirty_flags; |
| 66 | } |
| 67 | |
| 68 | static inline void cpu_physical_memory_set_dirty(ram_addr_t addr) |
| 69 | { |
| 70 | ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] = 0xff; |
| 71 | } |
| 72 | |
| 73 | static inline int cpu_physical_memory_set_dirty_flags(ram_addr_t addr, |
| 74 | int dirty_flags) |
| 75 | { |
| 76 | return ram_list.phys_dirty[addr >> TARGET_PAGE_BITS] |= dirty_flags; |
| 77 | } |
| 78 | |
Blue Swirl | fd4aa97 | 2011-10-16 16:04:59 +0000 | [diff] [blame^] | 79 | static inline void cpu_physical_memory_set_dirty_range(ram_addr_t start, |
| 80 | ram_addr_t length, |
| 81 | int dirty_flags) |
| 82 | { |
| 83 | uint8_t *p; |
| 84 | ram_addr_t addr, end; |
| 85 | |
| 86 | end = start + length; |
| 87 | p = ram_list.phys_dirty + (start >> TARGET_PAGE_BITS); |
| 88 | for (addr = start; addr <= end; addr += TARGET_PAGE_SIZE) { |
| 89 | *p++ |= dirty_flags; |
| 90 | } |
| 91 | } |
| 92 | |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 93 | static inline void cpu_physical_memory_mask_dirty_range(ram_addr_t start, |
Blue Swirl | 59abb06 | 2012-01-22 11:00:44 +0000 | [diff] [blame] | 94 | ram_addr_t length, |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 95 | int dirty_flags) |
| 96 | { |
Blue Swirl | 59abb06 | 2012-01-22 11:00:44 +0000 | [diff] [blame] | 97 | int mask; |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 98 | uint8_t *p; |
Blue Swirl | 59abb06 | 2012-01-22 11:00:44 +0000 | [diff] [blame] | 99 | ram_addr_t addr, end; |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 100 | |
Blue Swirl | 59abb06 | 2012-01-22 11:00:44 +0000 | [diff] [blame] | 101 | end = start + length; |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 102 | mask = ~dirty_flags; |
| 103 | p = ram_list.phys_dirty + (start >> TARGET_PAGE_BITS); |
Blue Swirl | 59abb06 | 2012-01-22 11:00:44 +0000 | [diff] [blame] | 104 | for (addr = start; addr <= end; addr += TARGET_PAGE_SIZE) { |
| 105 | *p++ &= mask; |
Avi Kivity | 7638e0d | 2011-12-21 14:16:38 +0200 | [diff] [blame] | 106 | } |
| 107 | } |
| 108 | |
| 109 | void cpu_physical_memory_reset_dirty(ram_addr_t start, ram_addr_t end, |
| 110 | int dirty_flags); |
Avi Kivity | 67d95c1 | 2011-12-15 15:25:22 +0200 | [diff] [blame] | 111 | #endif |
| 112 | |
| 113 | #endif |