2 * virtual page mapping and translated block handling
4 * Copyright (c) 2003 Fabrice Bellard
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
23 #include <sys/types.h>
27 #include "qemu-common.h"
35 #include "qemu-timer.h"
37 #include "exec-memory.h"
38 #if defined(CONFIG_USER_ONLY)
40 #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
41 #include <sys/param.h>
42 #if __FreeBSD_version >= 700104
43 #define HAVE_KINFO_GETVMMAP
44 #define sigqueue sigqueue_freebsd /* avoid redefinition */
47 #include <machine/profile.h>
55 #else /* !CONFIG_USER_ONLY */
56 #include "xen-mapcache.h"
60 #define WANT_EXEC_OBSOLETE
61 #include "exec-obsolete.h"
63 //#define DEBUG_TB_INVALIDATE
66 //#define DEBUG_UNASSIGNED
68 /* make various TB consistency checks */
69 //#define DEBUG_TB_CHECK
70 //#define DEBUG_TLB_CHECK
72 //#define DEBUG_IOPORT
73 //#define DEBUG_SUBPAGE
75 #if !defined(CONFIG_USER_ONLY)
76 /* TB consistency checks only implemented for usermode emulation. */
80 #define SMC_BITMAP_USE_THRESHOLD 10
82 static TranslationBlock
*tbs
;
83 static int code_gen_max_blocks
;
84 TranslationBlock
*tb_phys_hash
[CODE_GEN_PHYS_HASH_SIZE
];
86 /* any access to the tbs or the page table must use this lock */
87 spinlock_t tb_lock
= SPIN_LOCK_UNLOCKED
;
89 #if defined(__arm__) || defined(__sparc_v9__)
90 /* The prologue must be reachable with a direct jump. ARM and Sparc64
91 have limited branch ranges (possibly also PPC) so place it in a
92 section close to code segment. */
93 #define code_gen_section \
94 __attribute__((__section__(".gen_code"))) \
95 __attribute__((aligned (32)))
97 /* Maximum alignment for Win32 is 16. */
98 #define code_gen_section \
99 __attribute__((aligned (16)))
101 #define code_gen_section \
102 __attribute__((aligned (32)))
105 uint8_t code_gen_prologue
[1024] code_gen_section
;
106 static uint8_t *code_gen_buffer
;
107 static unsigned long code_gen_buffer_size
;
108 /* threshold to flush the translated code buffer */
109 static unsigned long code_gen_buffer_max_size
;
110 static uint8_t *code_gen_ptr
;
112 #if !defined(CONFIG_USER_ONLY)
114 static int in_migration
;
116 RAMList ram_list
= { .blocks
= QLIST_HEAD_INITIALIZER(ram_list
.blocks
) };
118 static MemoryRegion
*system_memory
;
119 static MemoryRegion
*system_io
;
121 MemoryRegion io_mem_ram
, io_mem_rom
, io_mem_unassigned
, io_mem_notdirty
;
122 static MemoryRegion io_mem_subpage_ram
;
126 CPUArchState
*first_cpu
;
127 /* current CPU in the current thread. It is only valid inside
129 DEFINE_TLS(CPUArchState
*,cpu_single_env
);
130 /* 0 = Do not count executed instructions.
131 1 = Precise instruction counting.
132 2 = Adaptive rate instruction counting. */
135 typedef struct PageDesc
{
136 /* list of TBs intersecting this ram page */
137 TranslationBlock
*first_tb
;
138 /* in order to optimize self modifying code, we count the number
139 of lookups we do to a given page to use a bitmap */
140 unsigned int code_write_count
;
141 uint8_t *code_bitmap
;
142 #if defined(CONFIG_USER_ONLY)
147 /* In system mode we want L1_MAP to be based on ram offsets,
148 while in user mode we want it to be based on virtual addresses. */
149 #if !defined(CONFIG_USER_ONLY)
150 #if HOST_LONG_BITS < TARGET_PHYS_ADDR_SPACE_BITS
151 # define L1_MAP_ADDR_SPACE_BITS HOST_LONG_BITS
153 # define L1_MAP_ADDR_SPACE_BITS TARGET_PHYS_ADDR_SPACE_BITS
156 # define L1_MAP_ADDR_SPACE_BITS TARGET_VIRT_ADDR_SPACE_BITS
159 /* Size of the L2 (and L3, etc) page tables. */
161 #define L2_SIZE (1 << L2_BITS)
163 #define P_L2_LEVELS \
164 (((TARGET_PHYS_ADDR_SPACE_BITS - TARGET_PAGE_BITS - 1) / L2_BITS) + 1)
166 /* The bits remaining after N lower levels of page tables. */
167 #define V_L1_BITS_REM \
168 ((L1_MAP_ADDR_SPACE_BITS - TARGET_PAGE_BITS) % L2_BITS)
170 #if V_L1_BITS_REM < 4
171 #define V_L1_BITS (V_L1_BITS_REM + L2_BITS)
173 #define V_L1_BITS V_L1_BITS_REM
176 #define V_L1_SIZE ((target_ulong)1 << V_L1_BITS)
178 #define V_L1_SHIFT (L1_MAP_ADDR_SPACE_BITS - TARGET_PAGE_BITS - V_L1_BITS)
180 unsigned long qemu_real_host_page_size
;
181 unsigned long qemu_host_page_size
;
182 unsigned long qemu_host_page_mask
;
184 /* This is a multi-level map on the virtual address space.
185 The bottom level has pointers to PageDesc. */
186 static void *l1_map
[V_L1_SIZE
];
188 #if !defined(CONFIG_USER_ONLY)
189 typedef struct PhysPageEntry PhysPageEntry
;
191 static MemoryRegionSection
*phys_sections
;
192 static unsigned phys_sections_nb
, phys_sections_nb_alloc
;
193 static uint16_t phys_section_unassigned
;
194 static uint16_t phys_section_notdirty
;
195 static uint16_t phys_section_rom
;
196 static uint16_t phys_section_watch
;
198 struct PhysPageEntry
{
199 uint16_t is_leaf
: 1;
200 /* index into phys_sections (is_leaf) or phys_map_nodes (!is_leaf) */
204 /* Simple allocator for PhysPageEntry nodes */
205 static PhysPageEntry (*phys_map_nodes
)[L2_SIZE
];
206 static unsigned phys_map_nodes_nb
, phys_map_nodes_nb_alloc
;
208 #define PHYS_MAP_NODE_NIL (((uint16_t)~0) >> 1)
210 /* This is a multi-level map on the physical address space.
211 The bottom level has pointers to MemoryRegionSections. */
212 static PhysPageEntry phys_map
= { .ptr
= PHYS_MAP_NODE_NIL
, .is_leaf
= 0 };
214 static void io_mem_init(void);
215 static void memory_map_init(void);
217 static MemoryRegion io_mem_watch
;
222 static const char *logfilename
= "qemu.log";
224 static const char *logfilename
= "/tmp/qemu.log";
228 static int log_append
= 0;
231 #if !defined(CONFIG_USER_ONLY)
232 static int tlb_flush_count
;
234 static int tb_flush_count
;
235 static int tb_phys_invalidate_count
;
238 static void map_exec(void *addr
, long size
)
241 VirtualProtect(addr
, size
,
242 PAGE_EXECUTE_READWRITE
, &old_protect
);
246 static void map_exec(void *addr
, long size
)
248 unsigned long start
, end
, page_size
;
250 page_size
= getpagesize();
251 start
= (unsigned long)addr
;
252 start
&= ~(page_size
- 1);
254 end
= (unsigned long)addr
+ size
;
255 end
+= page_size
- 1;
256 end
&= ~(page_size
- 1);
258 mprotect((void *)start
, end
- start
,
259 PROT_READ
| PROT_WRITE
| PROT_EXEC
);
263 static void page_init(void)
265 /* NOTE: we can always suppose that qemu_host_page_size >=
269 SYSTEM_INFO system_info
;
271 GetSystemInfo(&system_info
);
272 qemu_real_host_page_size
= system_info
.dwPageSize
;
275 qemu_real_host_page_size
= getpagesize();
277 if (qemu_host_page_size
== 0)
278 qemu_host_page_size
= qemu_real_host_page_size
;
279 if (qemu_host_page_size
< TARGET_PAGE_SIZE
)
280 qemu_host_page_size
= TARGET_PAGE_SIZE
;
281 qemu_host_page_mask
= ~(qemu_host_page_size
- 1);
283 #if defined(CONFIG_BSD) && defined(CONFIG_USER_ONLY)
285 #ifdef HAVE_KINFO_GETVMMAP
286 struct kinfo_vmentry
*freep
;
289 freep
= kinfo_getvmmap(getpid(), &cnt
);
292 for (i
= 0; i
< cnt
; i
++) {
293 unsigned long startaddr
, endaddr
;
295 startaddr
= freep
[i
].kve_start
;
296 endaddr
= freep
[i
].kve_end
;
297 if (h2g_valid(startaddr
)) {
298 startaddr
= h2g(startaddr
) & TARGET_PAGE_MASK
;
300 if (h2g_valid(endaddr
)) {
301 endaddr
= h2g(endaddr
);
302 page_set_flags(startaddr
, endaddr
, PAGE_RESERVED
);
304 #if TARGET_ABI_BITS <= L1_MAP_ADDR_SPACE_BITS
306 page_set_flags(startaddr
, endaddr
, PAGE_RESERVED
);
317 last_brk
= (unsigned long)sbrk(0);
319 f
= fopen("/compat/linux/proc/self/maps", "r");
324 unsigned long startaddr
, endaddr
;
327 n
= fscanf (f
, "%lx-%lx %*[^\n]\n", &startaddr
, &endaddr
);
329 if (n
== 2 && h2g_valid(startaddr
)) {
330 startaddr
= h2g(startaddr
) & TARGET_PAGE_MASK
;
332 if (h2g_valid(endaddr
)) {
333 endaddr
= h2g(endaddr
);
337 page_set_flags(startaddr
, endaddr
, PAGE_RESERVED
);
349 static PageDesc
*page_find_alloc(tb_page_addr_t index
, int alloc
)
355 #if defined(CONFIG_USER_ONLY)
356 /* We can't use g_malloc because it may recurse into a locked mutex. */
357 # define ALLOC(P, SIZE) \
359 P = mmap(NULL, SIZE, PROT_READ | PROT_WRITE, \
360 MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); \
363 # define ALLOC(P, SIZE) \
364 do { P = g_malloc0(SIZE); } while (0)
367 /* Level 1. Always allocated. */
368 lp
= l1_map
+ ((index
>> V_L1_SHIFT
) & (V_L1_SIZE
- 1));
371 for (i
= V_L1_SHIFT
/ L2_BITS
- 1; i
> 0; i
--) {
378 ALLOC(p
, sizeof(void *) * L2_SIZE
);
382 lp
= p
+ ((index
>> (i
* L2_BITS
)) & (L2_SIZE
- 1));
390 ALLOC(pd
, sizeof(PageDesc
) * L2_SIZE
);
396 return pd
+ (index
& (L2_SIZE
- 1));
399 static inline PageDesc
*page_find(tb_page_addr_t index
)
401 return page_find_alloc(index
, 0);
404 #if !defined(CONFIG_USER_ONLY)
406 static void phys_map_node_reserve(unsigned nodes
)
408 if (phys_map_nodes_nb
+ nodes
> phys_map_nodes_nb_alloc
) {
409 typedef PhysPageEntry Node
[L2_SIZE
];
410 phys_map_nodes_nb_alloc
= MAX(phys_map_nodes_nb_alloc
* 2, 16);
411 phys_map_nodes_nb_alloc
= MAX(phys_map_nodes_nb_alloc
,
412 phys_map_nodes_nb
+ nodes
);
413 phys_map_nodes
= g_renew(Node
, phys_map_nodes
,
414 phys_map_nodes_nb_alloc
);
418 static uint16_t phys_map_node_alloc(void)
423 ret
= phys_map_nodes_nb
++;
424 assert(ret
!= PHYS_MAP_NODE_NIL
);
425 assert(ret
!= phys_map_nodes_nb_alloc
);
426 for (i
= 0; i
< L2_SIZE
; ++i
) {
427 phys_map_nodes
[ret
][i
].is_leaf
= 0;
428 phys_map_nodes
[ret
][i
].ptr
= PHYS_MAP_NODE_NIL
;
433 static void phys_map_nodes_reset(void)
435 phys_map_nodes_nb
= 0;
439 static void phys_page_set_level(PhysPageEntry
*lp
, target_phys_addr_t
*index
,
440 target_phys_addr_t
*nb
, uint16_t leaf
,
445 target_phys_addr_t step
= (target_phys_addr_t
)1 << (level
* L2_BITS
);
447 if (!lp
->is_leaf
&& lp
->ptr
== PHYS_MAP_NODE_NIL
) {
448 lp
->ptr
= phys_map_node_alloc();
449 p
= phys_map_nodes
[lp
->ptr
];
451 for (i
= 0; i
< L2_SIZE
; i
++) {
453 p
[i
].ptr
= phys_section_unassigned
;
457 p
= phys_map_nodes
[lp
->ptr
];
459 lp
= &p
[(*index
>> (level
* L2_BITS
)) & (L2_SIZE
- 1)];
461 while (*nb
&& lp
< &p
[L2_SIZE
]) {
462 if ((*index
& (step
- 1)) == 0 && *nb
>= step
) {
468 phys_page_set_level(lp
, index
, nb
, leaf
, level
- 1);
474 static void phys_page_set(target_phys_addr_t index
, target_phys_addr_t nb
,
477 /* Wildly overreserve - it doesn't matter much. */
478 phys_map_node_reserve(3 * P_L2_LEVELS
);
480 phys_page_set_level(&phys_map
, &index
, &nb
, leaf
, P_L2_LEVELS
- 1);
483 static MemoryRegionSection
*phys_page_find(target_phys_addr_t index
)
485 PhysPageEntry lp
= phys_map
;
488 uint16_t s_index
= phys_section_unassigned
;
490 for (i
= P_L2_LEVELS
- 1; i
>= 0 && !lp
.is_leaf
; i
--) {
491 if (lp
.ptr
== PHYS_MAP_NODE_NIL
) {
494 p
= phys_map_nodes
[lp
.ptr
];
495 lp
= p
[(index
>> (i
* L2_BITS
)) & (L2_SIZE
- 1)];
500 return &phys_sections
[s_index
];
503 static target_phys_addr_t
section_addr(MemoryRegionSection
*section
,
504 target_phys_addr_t addr
)
506 addr
-= section
->offset_within_address_space
;
507 addr
+= section
->offset_within_region
;
511 static void tlb_protect_code(ram_addr_t ram_addr
);
512 static void tlb_unprotect_code_phys(CPUArchState
*env
, ram_addr_t ram_addr
,
514 #define mmap_lock() do { } while(0)
515 #define mmap_unlock() do { } while(0)
518 #define DEFAULT_CODE_GEN_BUFFER_SIZE (32 * 1024 * 1024)
520 #if defined(CONFIG_USER_ONLY)
521 /* Currently it is not recommended to allocate big chunks of data in
522 user mode. It will change when a dedicated libc will be used */
523 #define USE_STATIC_CODE_GEN_BUFFER
526 #ifdef USE_STATIC_CODE_GEN_BUFFER
527 static uint8_t static_code_gen_buffer
[DEFAULT_CODE_GEN_BUFFER_SIZE
]
528 __attribute__((aligned (CODE_GEN_ALIGN
)));
531 static void code_gen_alloc(unsigned long tb_size
)
533 #ifdef USE_STATIC_CODE_GEN_BUFFER
534 code_gen_buffer
= static_code_gen_buffer
;
535 code_gen_buffer_size
= DEFAULT_CODE_GEN_BUFFER_SIZE
;
536 map_exec(code_gen_buffer
, code_gen_buffer_size
);
538 code_gen_buffer_size
= tb_size
;
539 if (code_gen_buffer_size
== 0) {
540 #if defined(CONFIG_USER_ONLY)
541 code_gen_buffer_size
= DEFAULT_CODE_GEN_BUFFER_SIZE
;
543 /* XXX: needs adjustments */
544 code_gen_buffer_size
= (unsigned long)(ram_size
/ 4);
547 if (code_gen_buffer_size
< MIN_CODE_GEN_BUFFER_SIZE
)
548 code_gen_buffer_size
= MIN_CODE_GEN_BUFFER_SIZE
;
549 /* The code gen buffer location may have constraints depending on
550 the host cpu and OS */
551 #if defined(__linux__)
556 flags
= MAP_PRIVATE
| MAP_ANONYMOUS
;
557 #if defined(__x86_64__)
559 /* Cannot map more than that */
560 if (code_gen_buffer_size
> (800 * 1024 * 1024))
561 code_gen_buffer_size
= (800 * 1024 * 1024);
562 #elif defined(__sparc_v9__)
563 // Map the buffer below 2G, so we can use direct calls and branches
565 start
= (void *) 0x60000000UL
;
566 if (code_gen_buffer_size
> (512 * 1024 * 1024))
567 code_gen_buffer_size
= (512 * 1024 * 1024);
568 #elif defined(__arm__)
569 /* Keep the buffer no bigger than 16MB to branch between blocks */
570 if (code_gen_buffer_size
> 16 * 1024 * 1024)
571 code_gen_buffer_size
= 16 * 1024 * 1024;
572 #elif defined(__s390x__)
573 /* Map the buffer so that we can use direct calls and branches. */
574 /* We have a +- 4GB range on the branches; leave some slop. */
575 if (code_gen_buffer_size
> (3ul * 1024 * 1024 * 1024)) {
576 code_gen_buffer_size
= 3ul * 1024 * 1024 * 1024;
578 start
= (void *)0x90000000UL
;
580 code_gen_buffer
= mmap(start
, code_gen_buffer_size
,
581 PROT_WRITE
| PROT_READ
| PROT_EXEC
,
583 if (code_gen_buffer
== MAP_FAILED
) {
584 fprintf(stderr
, "Could not allocate dynamic translator buffer\n");
588 #elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__) \
589 || defined(__DragonFly__) || defined(__OpenBSD__) \
590 || defined(__NetBSD__)
594 flags
= MAP_PRIVATE
| MAP_ANONYMOUS
;
595 #if defined(__x86_64__)
596 /* FreeBSD doesn't have MAP_32BIT, use MAP_FIXED and assume
597 * 0x40000000 is free */
599 addr
= (void *)0x40000000;
600 /* Cannot map more than that */
601 if (code_gen_buffer_size
> (800 * 1024 * 1024))
602 code_gen_buffer_size
= (800 * 1024 * 1024);
603 #elif defined(__sparc_v9__)
604 // Map the buffer below 2G, so we can use direct calls and branches
606 addr
= (void *) 0x60000000UL
;
607 if (code_gen_buffer_size
> (512 * 1024 * 1024)) {
608 code_gen_buffer_size
= (512 * 1024 * 1024);
611 code_gen_buffer
= mmap(addr
, code_gen_buffer_size
,
612 PROT_WRITE
| PROT_READ
| PROT_EXEC
,
614 if (code_gen_buffer
== MAP_FAILED
) {
615 fprintf(stderr
, "Could not allocate dynamic translator buffer\n");
620 code_gen_buffer
= g_malloc(code_gen_buffer_size
);
621 map_exec(code_gen_buffer
, code_gen_buffer_size
);
623 #endif /* !USE_STATIC_CODE_GEN_BUFFER */
624 map_exec(code_gen_prologue
, sizeof(code_gen_prologue
));
625 code_gen_buffer_max_size
= code_gen_buffer_size
-
626 (TCG_MAX_OP_SIZE
* OPC_BUF_SIZE
);
627 code_gen_max_blocks
= code_gen_buffer_size
/ CODE_GEN_AVG_BLOCK_SIZE
;
628 tbs
= g_malloc(code_gen_max_blocks
* sizeof(TranslationBlock
));
631 /* Must be called before using the QEMU cpus. 'tb_size' is the size
632 (in bytes) allocated to the translation buffer. Zero means default
634 void tcg_exec_init(unsigned long tb_size
)
637 code_gen_alloc(tb_size
);
638 code_gen_ptr
= code_gen_buffer
;
639 tcg_register_jit(code_gen_buffer
, code_gen_buffer_size
);
641 #if !defined(CONFIG_USER_ONLY) || !defined(CONFIG_USE_GUEST_BASE)
642 /* There's no guest base to take into account, so go ahead and
643 initialize the prologue now. */
644 tcg_prologue_init(&tcg_ctx
);
648 bool tcg_enabled(void)
650 return code_gen_buffer
!= NULL
;
653 void cpu_exec_init_all(void)
655 #if !defined(CONFIG_USER_ONLY)
661 #if defined(CPU_SAVE_VERSION) && !defined(CONFIG_USER_ONLY)
663 static int cpu_common_post_load(void *opaque
, int version_id
)
665 CPUArchState
*env
= opaque
;
667 /* 0x01 was CPU_INTERRUPT_EXIT. This line can be removed when the
668 version_id is increased. */
669 env
->interrupt_request
&= ~0x01;
675 static const VMStateDescription vmstate_cpu_common
= {
676 .name
= "cpu_common",
678 .minimum_version_id
= 1,
679 .minimum_version_id_old
= 1,
680 .post_load
= cpu_common_post_load
,
681 .fields
= (VMStateField
[]) {
682 VMSTATE_UINT32(halted
, CPUArchState
),
683 VMSTATE_UINT32(interrupt_request
, CPUArchState
),
684 VMSTATE_END_OF_LIST()
689 CPUArchState
*qemu_get_cpu(int cpu
)
691 CPUArchState
*env
= first_cpu
;
694 if (env
->cpu_index
== cpu
)
702 void cpu_exec_init(CPUArchState
*env
)
707 #if defined(CONFIG_USER_ONLY)
710 env
->next_cpu
= NULL
;
713 while (*penv
!= NULL
) {
714 penv
= &(*penv
)->next_cpu
;
717 env
->cpu_index
= cpu_index
;
719 QTAILQ_INIT(&env
->breakpoints
);
720 QTAILQ_INIT(&env
->watchpoints
);
721 #ifndef CONFIG_USER_ONLY
722 env
->thread_id
= qemu_get_thread_id();
725 #if defined(CONFIG_USER_ONLY)
728 #if defined(CPU_SAVE_VERSION) && !defined(CONFIG_USER_ONLY)
729 vmstate_register(NULL
, cpu_index
, &vmstate_cpu_common
, env
);
730 register_savevm(NULL
, "cpu", cpu_index
, CPU_SAVE_VERSION
,
731 cpu_save
, cpu_load
, env
);
735 /* Allocate a new translation block. Flush the translation buffer if
736 too many translation blocks or too much generated code. */
737 static TranslationBlock
*tb_alloc(target_ulong pc
)
739 TranslationBlock
*tb
;
741 if (nb_tbs
>= code_gen_max_blocks
||
742 (code_gen_ptr
- code_gen_buffer
) >= code_gen_buffer_max_size
)
750 void tb_free(TranslationBlock
*tb
)
752 /* In practice this is mostly used for single use temporary TB
753 Ignore the hard cases and just back up if this TB happens to
754 be the last one generated. */
755 if (nb_tbs
> 0 && tb
== &tbs
[nb_tbs
- 1]) {
756 code_gen_ptr
= tb
->tc_ptr
;
761 static inline void invalidate_page_bitmap(PageDesc
*p
)
763 if (p
->code_bitmap
) {
764 g_free(p
->code_bitmap
);
765 p
->code_bitmap
= NULL
;
767 p
->code_write_count
= 0;
770 /* Set to NULL all the 'first_tb' fields in all PageDescs. */
772 static void page_flush_tb_1 (int level
, void **lp
)
781 for (i
= 0; i
< L2_SIZE
; ++i
) {
782 pd
[i
].first_tb
= NULL
;
783 invalidate_page_bitmap(pd
+ i
);
787 for (i
= 0; i
< L2_SIZE
; ++i
) {
788 page_flush_tb_1 (level
- 1, pp
+ i
);
793 static void page_flush_tb(void)
796 for (i
= 0; i
< V_L1_SIZE
; i
++) {
797 page_flush_tb_1(V_L1_SHIFT
/ L2_BITS
- 1, l1_map
+ i
);
801 /* flush all the translation blocks */
802 /* XXX: tb_flush is currently not thread safe */
803 void tb_flush(CPUArchState
*env1
)
806 #if defined(DEBUG_FLUSH)
807 printf("qemu: flush code_size=%ld nb_tbs=%d avg_tb_size=%ld\n",
808 (unsigned long)(code_gen_ptr
- code_gen_buffer
),
810 ((unsigned long)(code_gen_ptr
- code_gen_buffer
)) / nb_tbs
: 0);
812 if ((unsigned long)(code_gen_ptr
- code_gen_buffer
) > code_gen_buffer_size
)
813 cpu_abort(env1
, "Internal error: code buffer overflow\n");
817 for(env
= first_cpu
; env
!= NULL
; env
= env
->next_cpu
) {
818 memset (env
->tb_jmp_cache
, 0, TB_JMP_CACHE_SIZE
* sizeof (void *));
821 memset (tb_phys_hash
, 0, CODE_GEN_PHYS_HASH_SIZE
* sizeof (void *));
824 code_gen_ptr
= code_gen_buffer
;
825 /* XXX: flush processor icache at this point if cache flush is
830 #ifdef DEBUG_TB_CHECK
832 static void tb_invalidate_check(target_ulong address
)
834 TranslationBlock
*tb
;
836 address
&= TARGET_PAGE_MASK
;
837 for(i
= 0;i
< CODE_GEN_PHYS_HASH_SIZE
; i
++) {
838 for(tb
= tb_phys_hash
[i
]; tb
!= NULL
; tb
= tb
->phys_hash_next
) {
839 if (!(address
+ TARGET_PAGE_SIZE
<= tb
->pc
||
840 address
>= tb
->pc
+ tb
->size
)) {
841 printf("ERROR invalidate: address=" TARGET_FMT_lx
842 " PC=%08lx size=%04x\n",
843 address
, (long)tb
->pc
, tb
->size
);
849 /* verify that all the pages have correct rights for code */
850 static void tb_page_check(void)
852 TranslationBlock
*tb
;
853 int i
, flags1
, flags2
;
855 for(i
= 0;i
< CODE_GEN_PHYS_HASH_SIZE
; i
++) {
856 for(tb
= tb_phys_hash
[i
]; tb
!= NULL
; tb
= tb
->phys_hash_next
) {
857 flags1
= page_get_flags(tb
->pc
);
858 flags2
= page_get_flags(tb
->pc
+ tb
->size
- 1);
859 if ((flags1
& PAGE_WRITE
) || (flags2
& PAGE_WRITE
)) {
860 printf("ERROR page flags: PC=%08lx size=%04x f1=%x f2=%x\n",
861 (long)tb
->pc
, tb
->size
, flags1
, flags2
);
869 /* invalidate one TB */
870 static inline void tb_remove(TranslationBlock
**ptb
, TranslationBlock
*tb
,
873 TranslationBlock
*tb1
;
877 *ptb
= *(TranslationBlock
**)((char *)tb1
+ next_offset
);
880 ptb
= (TranslationBlock
**)((char *)tb1
+ next_offset
);
884 static inline void tb_page_remove(TranslationBlock
**ptb
, TranslationBlock
*tb
)
886 TranslationBlock
*tb1
;
892 tb1
= (TranslationBlock
*)((long)tb1
& ~3);
894 *ptb
= tb1
->page_next
[n1
];
897 ptb
= &tb1
->page_next
[n1
];
901 static inline void tb_jmp_remove(TranslationBlock
*tb
, int n
)
903 TranslationBlock
*tb1
, **ptb
;
906 ptb
= &tb
->jmp_next
[n
];
909 /* find tb(n) in circular list */
913 tb1
= (TranslationBlock
*)((long)tb1
& ~3);
914 if (n1
== n
&& tb1
== tb
)
917 ptb
= &tb1
->jmp_first
;
919 ptb
= &tb1
->jmp_next
[n1
];
922 /* now we can suppress tb(n) from the list */
923 *ptb
= tb
->jmp_next
[n
];
925 tb
->jmp_next
[n
] = NULL
;
929 /* reset the jump entry 'n' of a TB so that it is not chained to
931 static inline void tb_reset_jump(TranslationBlock
*tb
, int n
)
933 tb_set_jmp_target(tb
, n
, (unsigned long)(tb
->tc_ptr
+ tb
->tb_next_offset
[n
]));
936 void tb_phys_invalidate(TranslationBlock
*tb
, tb_page_addr_t page_addr
)
941 tb_page_addr_t phys_pc
;
942 TranslationBlock
*tb1
, *tb2
;
944 /* remove the TB from the hash list */
945 phys_pc
= tb
->page_addr
[0] + (tb
->pc
& ~TARGET_PAGE_MASK
);
946 h
= tb_phys_hash_func(phys_pc
);
947 tb_remove(&tb_phys_hash
[h
], tb
,
948 offsetof(TranslationBlock
, phys_hash_next
));
950 /* remove the TB from the page list */
951 if (tb
->page_addr
[0] != page_addr
) {
952 p
= page_find(tb
->page_addr
[0] >> TARGET_PAGE_BITS
);
953 tb_page_remove(&p
->first_tb
, tb
);
954 invalidate_page_bitmap(p
);
956 if (tb
->page_addr
[1] != -1 && tb
->page_addr
[1] != page_addr
) {
957 p
= page_find(tb
->page_addr
[1] >> TARGET_PAGE_BITS
);
958 tb_page_remove(&p
->first_tb
, tb
);
959 invalidate_page_bitmap(p
);
962 tb_invalidated_flag
= 1;
964 /* remove the TB from the hash list */
965 h
= tb_jmp_cache_hash_func(tb
->pc
);
966 for(env
= first_cpu
; env
!= NULL
; env
= env
->next_cpu
) {
967 if (env
->tb_jmp_cache
[h
] == tb
)
968 env
->tb_jmp_cache
[h
] = NULL
;
971 /* suppress this TB from the two jump lists */
972 tb_jmp_remove(tb
, 0);
973 tb_jmp_remove(tb
, 1);
975 /* suppress any remaining jumps to this TB */
981 tb1
= (TranslationBlock
*)((long)tb1
& ~3);
982 tb2
= tb1
->jmp_next
[n1
];
983 tb_reset_jump(tb1
, n1
);
984 tb1
->jmp_next
[n1
] = NULL
;
987 tb
->jmp_first
= (TranslationBlock
*)((long)tb
| 2); /* fail safe */
989 tb_phys_invalidate_count
++;
992 static inline void set_bits(uint8_t *tab
, int start
, int len
)
998 mask
= 0xff << (start
& 7);
999 if ((start
& ~7) == (end
& ~7)) {
1001 mask
&= ~(0xff << (end
& 7));
1006 start
= (start
+ 8) & ~7;
1008 while (start
< end1
) {
1013 mask
= ~(0xff << (end
& 7));
1019 static void build_page_bitmap(PageDesc
*p
)
1021 int n
, tb_start
, tb_end
;
1022 TranslationBlock
*tb
;
1024 p
->code_bitmap
= g_malloc0(TARGET_PAGE_SIZE
/ 8);
1027 while (tb
!= NULL
) {
1029 tb
= (TranslationBlock
*)((long)tb
& ~3);
1030 /* NOTE: this is subtle as a TB may span two physical pages */
1032 /* NOTE: tb_end may be after the end of the page, but
1033 it is not a problem */
1034 tb_start
= tb
->pc
& ~TARGET_PAGE_MASK
;
1035 tb_end
= tb_start
+ tb
->size
;
1036 if (tb_end
> TARGET_PAGE_SIZE
)
1037 tb_end
= TARGET_PAGE_SIZE
;
1040 tb_end
= ((tb
->pc
+ tb
->size
) & ~TARGET_PAGE_MASK
);
1042 set_bits(p
->code_bitmap
, tb_start
, tb_end
- tb_start
);
1043 tb
= tb
->page_next
[n
];
1047 TranslationBlock
*tb_gen_code(CPUArchState
*env
,
1048 target_ulong pc
, target_ulong cs_base
,
1049 int flags
, int cflags
)
1051 TranslationBlock
*tb
;
1053 tb_page_addr_t phys_pc
, phys_page2
;
1054 target_ulong virt_page2
;
1057 phys_pc
= get_page_addr_code(env
, pc
);
1060 /* flush must be done */
1062 /* cannot fail at this point */
1064 /* Don't forget to invalidate previous TB info. */
1065 tb_invalidated_flag
= 1;
1067 tc_ptr
= code_gen_ptr
;
1068 tb
->tc_ptr
= tc_ptr
;
1069 tb
->cs_base
= cs_base
;
1071 tb
->cflags
= cflags
;
1072 cpu_gen_code(env
, tb
, &code_gen_size
);
1073 code_gen_ptr
= (void *)(((unsigned long)code_gen_ptr
+ code_gen_size
+ CODE_GEN_ALIGN
- 1) & ~(CODE_GEN_ALIGN
- 1));
1075 /* check next page if needed */
1076 virt_page2
= (pc
+ tb
->size
- 1) & TARGET_PAGE_MASK
;
1078 if ((pc
& TARGET_PAGE_MASK
) != virt_page2
) {
1079 phys_page2
= get_page_addr_code(env
, virt_page2
);
1081 tb_link_page(tb
, phys_pc
, phys_page2
);
1085 /* invalidate all TBs which intersect with the target physical page
1086 starting in range [start;end[. NOTE: start and end must refer to
1087 the same physical page. 'is_cpu_write_access' should be true if called
1088 from a real cpu write access: the virtual CPU will exit the current
1089 TB if code is modified inside this TB. */
1090 void tb_invalidate_phys_page_range(tb_page_addr_t start
, tb_page_addr_t end
,
1091 int is_cpu_write_access
)
1093 TranslationBlock
*tb
, *tb_next
, *saved_tb
;
1094 CPUArchState
*env
= cpu_single_env
;
1095 tb_page_addr_t tb_start
, tb_end
;
1098 #ifdef TARGET_HAS_PRECISE_SMC
1099 int current_tb_not_found
= is_cpu_write_access
;
1100 TranslationBlock
*current_tb
= NULL
;
1101 int current_tb_modified
= 0;
1102 target_ulong current_pc
= 0;
1103 target_ulong current_cs_base
= 0;
1104 int current_flags
= 0;
1105 #endif /* TARGET_HAS_PRECISE_SMC */
1107 p
= page_find(start
>> TARGET_PAGE_BITS
);
1110 if (!p
->code_bitmap
&&
1111 ++p
->code_write_count
>= SMC_BITMAP_USE_THRESHOLD
&&
1112 is_cpu_write_access
) {
1113 /* build code bitmap */
1114 build_page_bitmap(p
);
1117 /* we remove all the TBs in the range [start, end[ */
1118 /* XXX: see if in some cases it could be faster to invalidate all the code */
1120 while (tb
!= NULL
) {
1122 tb
= (TranslationBlock
*)((long)tb
& ~3);
1123 tb_next
= tb
->page_next
[n
];
1124 /* NOTE: this is subtle as a TB may span two physical pages */
1126 /* NOTE: tb_end may be after the end of the page, but
1127 it is not a problem */
1128 tb_start
= tb
->page_addr
[0] + (tb
->pc
& ~TARGET_PAGE_MASK
);
1129 tb_end
= tb_start
+ tb
->size
;
1131 tb_start
= tb
->page_addr
[1];
1132 tb_end
= tb_start
+ ((tb
->pc
+ tb
->size
) & ~TARGET_PAGE_MASK
);
1134 if (!(tb_end
<= start
|| tb_start
>= end
)) {
1135 #ifdef TARGET_HAS_PRECISE_SMC
1136 if (current_tb_not_found
) {
1137 current_tb_not_found
= 0;
1139 if (env
->mem_io_pc
) {
1140 /* now we have a real cpu fault */
1141 current_tb
= tb_find_pc(env
->mem_io_pc
);
1144 if (current_tb
== tb
&&
1145 (current_tb
->cflags
& CF_COUNT_MASK
) != 1) {
1146 /* If we are modifying the current TB, we must stop
1147 its execution. We could be more precise by checking
1148 that the modification is after the current PC, but it
1149 would require a specialized function to partially
1150 restore the CPU state */
1152 current_tb_modified
= 1;
1153 cpu_restore_state(current_tb
, env
, env
->mem_io_pc
);
1154 cpu_get_tb_cpu_state(env
, ¤t_pc
, ¤t_cs_base
,
1157 #endif /* TARGET_HAS_PRECISE_SMC */
1158 /* we need to do that to handle the case where a signal
1159 occurs while doing tb_phys_invalidate() */
1162 saved_tb
= env
->current_tb
;
1163 env
->current_tb
= NULL
;
1165 tb_phys_invalidate(tb
, -1);
1167 env
->current_tb
= saved_tb
;
1168 if (env
->interrupt_request
&& env
->current_tb
)
1169 cpu_interrupt(env
, env
->interrupt_request
);
1174 #if !defined(CONFIG_USER_ONLY)
1175 /* if no code remaining, no need to continue to use slow writes */
1177 invalidate_page_bitmap(p
);
1178 if (is_cpu_write_access
) {
1179 tlb_unprotect_code_phys(env
, start
, env
->mem_io_vaddr
);
1183 #ifdef TARGET_HAS_PRECISE_SMC
1184 if (current_tb_modified
) {
1185 /* we generate a block containing just the instruction
1186 modifying the memory. It will ensure that it cannot modify
1188 env
->current_tb
= NULL
;
1189 tb_gen_code(env
, current_pc
, current_cs_base
, current_flags
, 1);
1190 cpu_resume_from_signal(env
, NULL
);
1195 /* len must be <= 8 and start must be a multiple of len */
1196 static inline void tb_invalidate_phys_page_fast(tb_page_addr_t start
, int len
)
1202 qemu_log("modifying code at 0x%x size=%d EIP=%x PC=%08x\n",
1203 cpu_single_env
->mem_io_vaddr
, len
,
1204 cpu_single_env
->eip
,
1205 cpu_single_env
->eip
+ (long)cpu_single_env
->segs
[R_CS
].base
);
1208 p
= page_find(start
>> TARGET_PAGE_BITS
);
1211 if (p
->code_bitmap
) {
1212 offset
= start
& ~TARGET_PAGE_MASK
;
1213 b
= p
->code_bitmap
[offset
>> 3] >> (offset
& 7);
1214 if (b
& ((1 << len
) - 1))
1218 tb_invalidate_phys_page_range(start
, start
+ len
, 1);
1222 #if !defined(CONFIG_SOFTMMU)
1223 static void tb_invalidate_phys_page(tb_page_addr_t addr
,
1224 unsigned long pc
, void *puc
)
1226 TranslationBlock
*tb
;
1229 #ifdef TARGET_HAS_PRECISE_SMC
1230 TranslationBlock
*current_tb
= NULL
;
1231 CPUArchState
*env
= cpu_single_env
;
1232 int current_tb_modified
= 0;
1233 target_ulong current_pc
= 0;
1234 target_ulong current_cs_base
= 0;
1235 int current_flags
= 0;
1238 addr
&= TARGET_PAGE_MASK
;
1239 p
= page_find(addr
>> TARGET_PAGE_BITS
);
1243 #ifdef TARGET_HAS_PRECISE_SMC
1244 if (tb
&& pc
!= 0) {
1245 current_tb
= tb_find_pc(pc
);
1248 while (tb
!= NULL
) {
1250 tb
= (TranslationBlock
*)((long)tb
& ~3);
1251 #ifdef TARGET_HAS_PRECISE_SMC
1252 if (current_tb
== tb
&&
1253 (current_tb
->cflags
& CF_COUNT_MASK
) != 1) {
1254 /* If we are modifying the current TB, we must stop
1255 its execution. We could be more precise by checking
1256 that the modification is after the current PC, but it
1257 would require a specialized function to partially
1258 restore the CPU state */
1260 current_tb_modified
= 1;
1261 cpu_restore_state(current_tb
, env
, pc
);
1262 cpu_get_tb_cpu_state(env
, ¤t_pc
, ¤t_cs_base
,
1265 #endif /* TARGET_HAS_PRECISE_SMC */
1266 tb_phys_invalidate(tb
, addr
);
1267 tb
= tb
->page_next
[n
];
1270 #ifdef TARGET_HAS_PRECISE_SMC
1271 if (current_tb_modified
) {
1272 /* we generate a block containing just the instruction
1273 modifying the memory. It will ensure that it cannot modify
1275 env
->current_tb
= NULL
;
1276 tb_gen_code(env
, current_pc
, current_cs_base
, current_flags
, 1);
1277 cpu_resume_from_signal(env
, puc
);
1283 /* add the tb in the target page and protect it if necessary */
1284 static inline void tb_alloc_page(TranslationBlock
*tb
,
1285 unsigned int n
, tb_page_addr_t page_addr
)
1288 #ifndef CONFIG_USER_ONLY
1289 bool page_already_protected
;
1292 tb
->page_addr
[n
] = page_addr
;
1293 p
= page_find_alloc(page_addr
>> TARGET_PAGE_BITS
, 1);
1294 tb
->page_next
[n
] = p
->first_tb
;
1295 #ifndef CONFIG_USER_ONLY
1296 page_already_protected
= p
->first_tb
!= NULL
;
1298 p
->first_tb
= (TranslationBlock
*)((long)tb
| n
);
1299 invalidate_page_bitmap(p
);
1301 #if defined(TARGET_HAS_SMC) || 1
1303 #if defined(CONFIG_USER_ONLY)
1304 if (p
->flags
& PAGE_WRITE
) {
1309 /* force the host page as non writable (writes will have a
1310 page fault + mprotect overhead) */
1311 page_addr
&= qemu_host_page_mask
;
1313 for(addr
= page_addr
; addr
< page_addr
+ qemu_host_page_size
;
1314 addr
+= TARGET_PAGE_SIZE
) {
1316 p2
= page_find (addr
>> TARGET_PAGE_BITS
);
1320 p2
->flags
&= ~PAGE_WRITE
;
1322 mprotect(g2h(page_addr
), qemu_host_page_size
,
1323 (prot
& PAGE_BITS
) & ~PAGE_WRITE
);
1324 #ifdef DEBUG_TB_INVALIDATE
1325 printf("protecting code page: 0x" TARGET_FMT_lx
"\n",
1330 /* if some code is already present, then the pages are already
1331 protected. So we handle the case where only the first TB is
1332 allocated in a physical page */
1333 if (!page_already_protected
) {
1334 tlb_protect_code(page_addr
);
1338 #endif /* TARGET_HAS_SMC */
1341 /* add a new TB and link it to the physical page tables. phys_page2 is
1342 (-1) to indicate that only one page contains the TB. */
1343 void tb_link_page(TranslationBlock
*tb
,
1344 tb_page_addr_t phys_pc
, tb_page_addr_t phys_page2
)
1347 TranslationBlock
**ptb
;
1349 /* Grab the mmap lock to stop another thread invalidating this TB
1350 before we are done. */
1352 /* add in the physical hash table */
1353 h
= tb_phys_hash_func(phys_pc
);
1354 ptb
= &tb_phys_hash
[h
];
1355 tb
->phys_hash_next
= *ptb
;
1358 /* add in the page list */
1359 tb_alloc_page(tb
, 0, phys_pc
& TARGET_PAGE_MASK
);
1360 if (phys_page2
!= -1)
1361 tb_alloc_page(tb
, 1, phys_page2
);
1363 tb
->page_addr
[1] = -1;
1365 tb
->jmp_first
= (TranslationBlock
*)((long)tb
| 2);
1366 tb
->jmp_next
[0] = NULL
;
1367 tb
->jmp_next
[1] = NULL
;
1369 /* init original jump addresses */
1370 if (tb
->tb_next_offset
[0] != 0xffff)
1371 tb_reset_jump(tb
, 0);
1372 if (tb
->tb_next_offset
[1] != 0xffff)
1373 tb_reset_jump(tb
, 1);
1375 #ifdef DEBUG_TB_CHECK
1381 /* find the TB 'tb' such that tb[0].tc_ptr <= tc_ptr <
1382 tb[1].tc_ptr. Return NULL if not found */
1383 TranslationBlock
*tb_find_pc(unsigned long tc_ptr
)
1385 int m_min
, m_max
, m
;
1387 TranslationBlock
*tb
;
1391 if (tc_ptr
< (unsigned long)code_gen_buffer
||
1392 tc_ptr
>= (unsigned long)code_gen_ptr
)
1394 /* binary search (cf Knuth) */
1397 while (m_min
<= m_max
) {
1398 m
= (m_min
+ m_max
) >> 1;
1400 v
= (unsigned long)tb
->tc_ptr
;
1403 else if (tc_ptr
< v
) {
1412 static void tb_reset_jump_recursive(TranslationBlock
*tb
);
1414 static inline void tb_reset_jump_recursive2(TranslationBlock
*tb
, int n
)
1416 TranslationBlock
*tb1
, *tb_next
, **ptb
;
1419 tb1
= tb
->jmp_next
[n
];
1421 /* find head of list */
1424 tb1
= (TranslationBlock
*)((long)tb1
& ~3);
1427 tb1
= tb1
->jmp_next
[n1
];
1429 /* we are now sure now that tb jumps to tb1 */
1432 /* remove tb from the jmp_first list */
1433 ptb
= &tb_next
->jmp_first
;
1437 tb1
= (TranslationBlock
*)((long)tb1
& ~3);
1438 if (n1
== n
&& tb1
== tb
)
1440 ptb
= &tb1
->jmp_next
[n1
];
1442 *ptb
= tb
->jmp_next
[n
];
1443 tb
->jmp_next
[n
] = NULL
;
1445 /* suppress the jump to next tb in generated code */
1446 tb_reset_jump(tb
, n
);
1448 /* suppress jumps in the tb on which we could have jumped */
1449 tb_reset_jump_recursive(tb_next
);
1453 static void tb_reset_jump_recursive(TranslationBlock
*tb
)
1455 tb_reset_jump_recursive2(tb
, 0);
1456 tb_reset_jump_recursive2(tb
, 1);
1459 #if defined(TARGET_HAS_ICE)
1460 #if defined(CONFIG_USER_ONLY)
1461 static void breakpoint_invalidate(CPUArchState
*env
, target_ulong pc
)
1463 tb_invalidate_phys_page_range(pc
, pc
+ 1, 0);
1466 static void breakpoint_invalidate(CPUArchState
*env
, target_ulong pc
)
1468 target_phys_addr_t addr
;
1469 ram_addr_t ram_addr
;
1470 MemoryRegionSection
*section
;
1472 addr
= cpu_get_phys_page_debug(env
, pc
);
1473 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
1474 if (!(memory_region_is_ram(section
->mr
)
1475 || (section
->mr
->rom_device
&& section
->mr
->readable
))) {
1478 ram_addr
= (memory_region_get_ram_addr(section
->mr
) & TARGET_PAGE_MASK
)
1479 + section_addr(section
, addr
);
1480 tb_invalidate_phys_page_range(ram_addr
, ram_addr
+ 1, 0);
1483 #endif /* TARGET_HAS_ICE */
1485 #if defined(CONFIG_USER_ONLY)
1486 void cpu_watchpoint_remove_all(CPUArchState
*env
, int mask
)
1491 int cpu_watchpoint_insert(CPUArchState
*env
, target_ulong addr
, target_ulong len
,
1492 int flags
, CPUWatchpoint
**watchpoint
)
1497 /* Add a watchpoint. */
1498 int cpu_watchpoint_insert(CPUArchState
*env
, target_ulong addr
, target_ulong len
,
1499 int flags
, CPUWatchpoint
**watchpoint
)
1501 target_ulong len_mask
= ~(len
- 1);
1504 /* sanity checks: allow power-of-2 lengths, deny unaligned watchpoints */
1505 if ((len
& (len
- 1)) || (addr
& ~len_mask
) ||
1506 len
== 0 || len
> TARGET_PAGE_SIZE
) {
1507 fprintf(stderr
, "qemu: tried to set invalid watchpoint at "
1508 TARGET_FMT_lx
", len=" TARGET_FMT_lu
"\n", addr
, len
);
1511 wp
= g_malloc(sizeof(*wp
));
1514 wp
->len_mask
= len_mask
;
1517 /* keep all GDB-injected watchpoints in front */
1519 QTAILQ_INSERT_HEAD(&env
->watchpoints
, wp
, entry
);
1521 QTAILQ_INSERT_TAIL(&env
->watchpoints
, wp
, entry
);
1523 tlb_flush_page(env
, addr
);
1530 /* Remove a specific watchpoint. */
1531 int cpu_watchpoint_remove(CPUArchState
*env
, target_ulong addr
, target_ulong len
,
1534 target_ulong len_mask
= ~(len
- 1);
1537 QTAILQ_FOREACH(wp
, &env
->watchpoints
, entry
) {
1538 if (addr
== wp
->vaddr
&& len_mask
== wp
->len_mask
1539 && flags
== (wp
->flags
& ~BP_WATCHPOINT_HIT
)) {
1540 cpu_watchpoint_remove_by_ref(env
, wp
);
1547 /* Remove a specific watchpoint by reference. */
1548 void cpu_watchpoint_remove_by_ref(CPUArchState
*env
, CPUWatchpoint
*watchpoint
)
1550 QTAILQ_REMOVE(&env
->watchpoints
, watchpoint
, entry
);
1552 tlb_flush_page(env
, watchpoint
->vaddr
);
1557 /* Remove all matching watchpoints. */
1558 void cpu_watchpoint_remove_all(CPUArchState
*env
, int mask
)
1560 CPUWatchpoint
*wp
, *next
;
1562 QTAILQ_FOREACH_SAFE(wp
, &env
->watchpoints
, entry
, next
) {
1563 if (wp
->flags
& mask
)
1564 cpu_watchpoint_remove_by_ref(env
, wp
);
1569 /* Add a breakpoint. */
1570 int cpu_breakpoint_insert(CPUArchState
*env
, target_ulong pc
, int flags
,
1571 CPUBreakpoint
**breakpoint
)
1573 #if defined(TARGET_HAS_ICE)
1576 bp
= g_malloc(sizeof(*bp
));
1581 /* keep all GDB-injected breakpoints in front */
1583 QTAILQ_INSERT_HEAD(&env
->breakpoints
, bp
, entry
);
1585 QTAILQ_INSERT_TAIL(&env
->breakpoints
, bp
, entry
);
1587 breakpoint_invalidate(env
, pc
);
1597 /* Remove a specific breakpoint. */
1598 int cpu_breakpoint_remove(CPUArchState
*env
, target_ulong pc
, int flags
)
1600 #if defined(TARGET_HAS_ICE)
1603 QTAILQ_FOREACH(bp
, &env
->breakpoints
, entry
) {
1604 if (bp
->pc
== pc
&& bp
->flags
== flags
) {
1605 cpu_breakpoint_remove_by_ref(env
, bp
);
1615 /* Remove a specific breakpoint by reference. */
1616 void cpu_breakpoint_remove_by_ref(CPUArchState
*env
, CPUBreakpoint
*breakpoint
)
1618 #if defined(TARGET_HAS_ICE)
1619 QTAILQ_REMOVE(&env
->breakpoints
, breakpoint
, entry
);
1621 breakpoint_invalidate(env
, breakpoint
->pc
);
1627 /* Remove all matching breakpoints. */
1628 void cpu_breakpoint_remove_all(CPUArchState
*env
, int mask
)
1630 #if defined(TARGET_HAS_ICE)
1631 CPUBreakpoint
*bp
, *next
;
1633 QTAILQ_FOREACH_SAFE(bp
, &env
->breakpoints
, entry
, next
) {
1634 if (bp
->flags
& mask
)
1635 cpu_breakpoint_remove_by_ref(env
, bp
);
1640 /* enable or disable single step mode. EXCP_DEBUG is returned by the
1641 CPU loop after each instruction */
1642 void cpu_single_step(CPUArchState
*env
, int enabled
)
1644 #if defined(TARGET_HAS_ICE)
1645 if (env
->singlestep_enabled
!= enabled
) {
1646 env
->singlestep_enabled
= enabled
;
1648 kvm_update_guest_debug(env
, 0);
1650 /* must flush all the translated code to avoid inconsistencies */
1651 /* XXX: only flush what is necessary */
1658 /* enable or disable low levels log */
1659 void cpu_set_log(int log_flags
)
1661 loglevel
= log_flags
;
1662 if (loglevel
&& !logfile
) {
1663 logfile
= fopen(logfilename
, log_append
? "a" : "w");
1665 perror(logfilename
);
1668 #if !defined(CONFIG_SOFTMMU)
1669 /* must avoid mmap() usage of glibc by setting a buffer "by hand" */
1671 static char logfile_buf
[4096];
1672 setvbuf(logfile
, logfile_buf
, _IOLBF
, sizeof(logfile_buf
));
1674 #elif defined(_WIN32)
1675 /* Win32 doesn't support line-buffering, so use unbuffered output. */
1676 setvbuf(logfile
, NULL
, _IONBF
, 0);
1678 setvbuf(logfile
, NULL
, _IOLBF
, 0);
1682 if (!loglevel
&& logfile
) {
1688 void cpu_set_log_filename(const char *filename
)
1690 logfilename
= strdup(filename
);
1695 cpu_set_log(loglevel
);
1698 static void cpu_unlink_tb(CPUArchState
*env
)
1700 /* FIXME: TB unchaining isn't SMP safe. For now just ignore the
1701 problem and hope the cpu will stop of its own accord. For userspace
1702 emulation this often isn't actually as bad as it sounds. Often
1703 signals are used primarily to interrupt blocking syscalls. */
1704 TranslationBlock
*tb
;
1705 static spinlock_t interrupt_lock
= SPIN_LOCK_UNLOCKED
;
1707 spin_lock(&interrupt_lock
);
1708 tb
= env
->current_tb
;
1709 /* if the cpu is currently executing code, we must unlink it and
1710 all the potentially executing TB */
1712 env
->current_tb
= NULL
;
1713 tb_reset_jump_recursive(tb
);
1715 spin_unlock(&interrupt_lock
);
1718 #ifndef CONFIG_USER_ONLY
1719 /* mask must never be zero, except for A20 change call */
1720 static void tcg_handle_interrupt(CPUArchState
*env
, int mask
)
1724 old_mask
= env
->interrupt_request
;
1725 env
->interrupt_request
|= mask
;
1728 * If called from iothread context, wake the target cpu in
1731 if (!qemu_cpu_is_self(env
)) {
1737 env
->icount_decr
.u16
.high
= 0xffff;
1739 && (mask
& ~old_mask
) != 0) {
1740 cpu_abort(env
, "Raised interrupt while not in I/O function");
1747 CPUInterruptHandler cpu_interrupt_handler
= tcg_handle_interrupt
;
1749 #else /* CONFIG_USER_ONLY */
1751 void cpu_interrupt(CPUArchState
*env
, int mask
)
1753 env
->interrupt_request
|= mask
;
1756 #endif /* CONFIG_USER_ONLY */
1758 void cpu_reset_interrupt(CPUArchState
*env
, int mask
)
1760 env
->interrupt_request
&= ~mask
;
1763 void cpu_exit(CPUArchState
*env
)
1765 env
->exit_request
= 1;
1769 const CPULogItem cpu_log_items
[] = {
1770 { CPU_LOG_TB_OUT_ASM
, "out_asm",
1771 "show generated host assembly code for each compiled TB" },
1772 { CPU_LOG_TB_IN_ASM
, "in_asm",
1773 "show target assembly code for each compiled TB" },
1774 { CPU_LOG_TB_OP
, "op",
1775 "show micro ops for each compiled TB" },
1776 { CPU_LOG_TB_OP_OPT
, "op_opt",
1779 "before eflags optimization and "
1781 "after liveness analysis" },
1782 { CPU_LOG_INT
, "int",
1783 "show interrupts/exceptions in short format" },
1784 { CPU_LOG_EXEC
, "exec",
1785 "show trace before each executed TB (lots of logs)" },
1786 { CPU_LOG_TB_CPU
, "cpu",
1787 "show CPU state before block translation" },
1789 { CPU_LOG_PCALL
, "pcall",
1790 "show protected mode far calls/returns/exceptions" },
1791 { CPU_LOG_RESET
, "cpu_reset",
1792 "show CPU state before CPU resets" },
1795 { CPU_LOG_IOPORT
, "ioport",
1796 "show all i/o ports accesses" },
1801 static int cmp1(const char *s1
, int n
, const char *s2
)
1803 if (strlen(s2
) != n
)
1805 return memcmp(s1
, s2
, n
) == 0;
1808 /* takes a comma separated list of log masks. Return 0 if error. */
1809 int cpu_str_to_log_mask(const char *str
)
1811 const CPULogItem
*item
;
1818 p1
= strchr(p
, ',');
1821 if(cmp1(p
,p1
-p
,"all")) {
1822 for(item
= cpu_log_items
; item
->mask
!= 0; item
++) {
1826 for(item
= cpu_log_items
; item
->mask
!= 0; item
++) {
1827 if (cmp1(p
, p1
- p
, item
->name
))
1841 void cpu_abort(CPUArchState
*env
, const char *fmt
, ...)
1848 fprintf(stderr
, "qemu: fatal: ");
1849 vfprintf(stderr
, fmt
, ap
);
1850 fprintf(stderr
, "\n");
1852 cpu_dump_state(env
, stderr
, fprintf
, X86_DUMP_FPU
| X86_DUMP_CCOP
);
1854 cpu_dump_state(env
, stderr
, fprintf
, 0);
1856 if (qemu_log_enabled()) {
1857 qemu_log("qemu: fatal: ");
1858 qemu_log_vprintf(fmt
, ap2
);
1861 log_cpu_state(env
, X86_DUMP_FPU
| X86_DUMP_CCOP
);
1863 log_cpu_state(env
, 0);
1870 #if defined(CONFIG_USER_ONLY)
1872 struct sigaction act
;
1873 sigfillset(&act
.sa_mask
);
1874 act
.sa_handler
= SIG_DFL
;
1875 sigaction(SIGABRT
, &act
, NULL
);
1881 CPUArchState
*cpu_copy(CPUArchState
*env
)
1883 CPUArchState
*new_env
= cpu_init(env
->cpu_model_str
);
1884 CPUArchState
*next_cpu
= new_env
->next_cpu
;
1885 int cpu_index
= new_env
->cpu_index
;
1886 #if defined(TARGET_HAS_ICE)
1891 memcpy(new_env
, env
, sizeof(CPUArchState
));
1893 /* Preserve chaining and index. */
1894 new_env
->next_cpu
= next_cpu
;
1895 new_env
->cpu_index
= cpu_index
;
1897 /* Clone all break/watchpoints.
1898 Note: Once we support ptrace with hw-debug register access, make sure
1899 BP_CPU break/watchpoints are handled correctly on clone. */
1900 QTAILQ_INIT(&env
->breakpoints
);
1901 QTAILQ_INIT(&env
->watchpoints
);
1902 #if defined(TARGET_HAS_ICE)
1903 QTAILQ_FOREACH(bp
, &env
->breakpoints
, entry
) {
1904 cpu_breakpoint_insert(new_env
, bp
->pc
, bp
->flags
, NULL
);
1906 QTAILQ_FOREACH(wp
, &env
->watchpoints
, entry
) {
1907 cpu_watchpoint_insert(new_env
, wp
->vaddr
, (~wp
->len_mask
) + 1,
1915 #if !defined(CONFIG_USER_ONLY)
1917 static inline void tlb_flush_jmp_cache(CPUArchState
*env
, target_ulong addr
)
1921 /* Discard jump cache entries for any tb which might potentially
1922 overlap the flushed page. */
1923 i
= tb_jmp_cache_hash_page(addr
- TARGET_PAGE_SIZE
);
1924 memset (&env
->tb_jmp_cache
[i
], 0,
1925 TB_JMP_PAGE_SIZE
* sizeof(TranslationBlock
*));
1927 i
= tb_jmp_cache_hash_page(addr
);
1928 memset (&env
->tb_jmp_cache
[i
], 0,
1929 TB_JMP_PAGE_SIZE
* sizeof(TranslationBlock
*));
1932 static CPUTLBEntry s_cputlb_empty_entry
= {
1940 * If flush_global is true (the usual case), flush all tlb entries.
1941 * If flush_global is false, flush (at least) all tlb entries not
1944 * Since QEMU doesn't currently implement a global/not-global flag
1945 * for tlb entries, at the moment tlb_flush() will also flush all
1946 * tlb entries in the flush_global == false case. This is OK because
1947 * CPU architectures generally permit an implementation to drop
1948 * entries from the TLB at any time, so flushing more entries than
1949 * required is only an efficiency issue, not a correctness issue.
1951 void tlb_flush(CPUArchState
*env
, int flush_global
)
1955 #if defined(DEBUG_TLB)
1956 printf("tlb_flush:\n");
1958 /* must reset current TB so that interrupts cannot modify the
1959 links while we are modifying them */
1960 env
->current_tb
= NULL
;
1962 for(i
= 0; i
< CPU_TLB_SIZE
; i
++) {
1964 for (mmu_idx
= 0; mmu_idx
< NB_MMU_MODES
; mmu_idx
++) {
1965 env
->tlb_table
[mmu_idx
][i
] = s_cputlb_empty_entry
;
1969 memset (env
->tb_jmp_cache
, 0, TB_JMP_CACHE_SIZE
* sizeof (void *));
1971 env
->tlb_flush_addr
= -1;
1972 env
->tlb_flush_mask
= 0;
1976 static inline void tlb_flush_entry(CPUTLBEntry
*tlb_entry
, target_ulong addr
)
1978 if (addr
== (tlb_entry
->addr_read
&
1979 (TARGET_PAGE_MASK
| TLB_INVALID_MASK
)) ||
1980 addr
== (tlb_entry
->addr_write
&
1981 (TARGET_PAGE_MASK
| TLB_INVALID_MASK
)) ||
1982 addr
== (tlb_entry
->addr_code
&
1983 (TARGET_PAGE_MASK
| TLB_INVALID_MASK
))) {
1984 *tlb_entry
= s_cputlb_empty_entry
;
1988 void tlb_flush_page(CPUArchState
*env
, target_ulong addr
)
1993 #if defined(DEBUG_TLB)
1994 printf("tlb_flush_page: " TARGET_FMT_lx
"\n", addr
);
1996 /* Check if we need to flush due to large pages. */
1997 if ((addr
& env
->tlb_flush_mask
) == env
->tlb_flush_addr
) {
1998 #if defined(DEBUG_TLB)
1999 printf("tlb_flush_page: forced full flush ("
2000 TARGET_FMT_lx
"/" TARGET_FMT_lx
")\n",
2001 env
->tlb_flush_addr
, env
->tlb_flush_mask
);
2006 /* must reset current TB so that interrupts cannot modify the
2007 links while we are modifying them */
2008 env
->current_tb
= NULL
;
2010 addr
&= TARGET_PAGE_MASK
;
2011 i
= (addr
>> TARGET_PAGE_BITS
) & (CPU_TLB_SIZE
- 1);
2012 for (mmu_idx
= 0; mmu_idx
< NB_MMU_MODES
; mmu_idx
++)
2013 tlb_flush_entry(&env
->tlb_table
[mmu_idx
][i
], addr
);
2015 tlb_flush_jmp_cache(env
, addr
);
2018 /* update the TLBs so that writes to code in the virtual page 'addr'
2020 static void tlb_protect_code(ram_addr_t ram_addr
)
2022 cpu_physical_memory_reset_dirty(ram_addr
,
2023 ram_addr
+ TARGET_PAGE_SIZE
,
2027 /* update the TLB so that writes in physical page 'phys_addr' are no longer
2028 tested for self modifying code */
2029 static void tlb_unprotect_code_phys(CPUArchState
*env
, ram_addr_t ram_addr
,
2032 cpu_physical_memory_set_dirty_flags(ram_addr
, CODE_DIRTY_FLAG
);
2035 static bool tlb_is_dirty_ram(CPUTLBEntry
*tlbe
)
2037 return (tlbe
->addr_write
& (TLB_INVALID_MASK
|TLB_MMIO
|TLB_NOTDIRTY
)) == 0;
2040 static inline void tlb_reset_dirty_range(CPUTLBEntry
*tlb_entry
,
2041 unsigned long start
, unsigned long length
)
2044 if (tlb_is_dirty_ram(tlb_entry
)) {
2045 addr
= (tlb_entry
->addr_write
& TARGET_PAGE_MASK
) + tlb_entry
->addend
;
2046 if ((addr
- start
) < length
) {
2047 tlb_entry
->addr_write
|= TLB_NOTDIRTY
;
2052 /* Note: start and end must be within the same ram block. */
2053 void cpu_physical_memory_reset_dirty(ram_addr_t start
, ram_addr_t end
,
2057 unsigned long length
, start1
;
2060 start
&= TARGET_PAGE_MASK
;
2061 end
= TARGET_PAGE_ALIGN(end
);
2063 length
= end
- start
;
2066 cpu_physical_memory_mask_dirty_range(start
, length
, dirty_flags
);
2068 /* we modify the TLB cache so that the dirty bit will be set again
2069 when accessing the range */
2070 start1
= (unsigned long)qemu_safe_ram_ptr(start
);
2071 /* Check that we don't span multiple blocks - this breaks the
2072 address comparisons below. */
2073 if ((unsigned long)qemu_safe_ram_ptr(end
- 1) - start1
2074 != (end
- 1) - start
) {
2078 for(env
= first_cpu
; env
!= NULL
; env
= env
->next_cpu
) {
2080 for (mmu_idx
= 0; mmu_idx
< NB_MMU_MODES
; mmu_idx
++) {
2081 for(i
= 0; i
< CPU_TLB_SIZE
; i
++)
2082 tlb_reset_dirty_range(&env
->tlb_table
[mmu_idx
][i
],
2088 int cpu_physical_memory_set_dirty_tracking(int enable
)
2091 in_migration
= enable
;
2095 static inline void tlb_update_dirty(CPUTLBEntry
*tlb_entry
)
2097 ram_addr_t ram_addr
;
2100 if (tlb_is_dirty_ram(tlb_entry
)) {
2101 p
= (void *)(unsigned long)((tlb_entry
->addr_write
& TARGET_PAGE_MASK
)
2102 + tlb_entry
->addend
);
2103 ram_addr
= qemu_ram_addr_from_host_nofail(p
);
2104 if (!cpu_physical_memory_is_dirty(ram_addr
)) {
2105 tlb_entry
->addr_write
|= TLB_NOTDIRTY
;
2110 /* update the TLB according to the current state of the dirty bits */
2111 void cpu_tlb_update_dirty(CPUArchState
*env
)
2115 for (mmu_idx
= 0; mmu_idx
< NB_MMU_MODES
; mmu_idx
++) {
2116 for(i
= 0; i
< CPU_TLB_SIZE
; i
++)
2117 tlb_update_dirty(&env
->tlb_table
[mmu_idx
][i
]);
2121 static inline void tlb_set_dirty1(CPUTLBEntry
*tlb_entry
, target_ulong vaddr
)
2123 if (tlb_entry
->addr_write
== (vaddr
| TLB_NOTDIRTY
))
2124 tlb_entry
->addr_write
= vaddr
;
2127 /* update the TLB corresponding to virtual page vaddr
2128 so that it is no longer dirty */
2129 static inline void tlb_set_dirty(CPUArchState
*env
, target_ulong vaddr
)
2134 vaddr
&= TARGET_PAGE_MASK
;
2135 i
= (vaddr
>> TARGET_PAGE_BITS
) & (CPU_TLB_SIZE
- 1);
2136 for (mmu_idx
= 0; mmu_idx
< NB_MMU_MODES
; mmu_idx
++)
2137 tlb_set_dirty1(&env
->tlb_table
[mmu_idx
][i
], vaddr
);
2140 /* Our TLB does not support large pages, so remember the area covered by
2141 large pages and trigger a full TLB flush if these are invalidated. */
2142 static void tlb_add_large_page(CPUArchState
*env
, target_ulong vaddr
,
2145 target_ulong mask
= ~(size
- 1);
2147 if (env
->tlb_flush_addr
== (target_ulong
)-1) {
2148 env
->tlb_flush_addr
= vaddr
& mask
;
2149 env
->tlb_flush_mask
= mask
;
2152 /* Extend the existing region to include the new page.
2153 This is a compromise between unnecessary flushes and the cost
2154 of maintaining a full variable size TLB. */
2155 mask
&= env
->tlb_flush_mask
;
2156 while (((env
->tlb_flush_addr
^ vaddr
) & mask
) != 0) {
2159 env
->tlb_flush_addr
&= mask
;
2160 env
->tlb_flush_mask
= mask
;
2163 static bool is_ram_rom(MemoryRegionSection
*s
)
2165 return memory_region_is_ram(s
->mr
);
2168 static bool is_romd(MemoryRegionSection
*s
)
2170 MemoryRegion
*mr
= s
->mr
;
2172 return mr
->rom_device
&& mr
->readable
;
2175 static bool is_ram_rom_romd(MemoryRegionSection
*s
)
2177 return is_ram_rom(s
) || is_romd(s
);
2180 /* Add a new TLB entry. At most one entry for a given virtual address
2181 is permitted. Only a single TARGET_PAGE_SIZE region is mapped, the
2182 supplied size is only used by tlb_flush_page. */
2183 void tlb_set_page(CPUArchState
*env
, target_ulong vaddr
,
2184 target_phys_addr_t paddr
, int prot
,
2185 int mmu_idx
, target_ulong size
)
2187 MemoryRegionSection
*section
;
2189 target_ulong address
;
2190 target_ulong code_address
;
2191 unsigned long addend
;
2194 target_phys_addr_t iotlb
;
2196 assert(size
>= TARGET_PAGE_SIZE
);
2197 if (size
!= TARGET_PAGE_SIZE
) {
2198 tlb_add_large_page(env
, vaddr
, size
);
2200 section
= phys_page_find(paddr
>> TARGET_PAGE_BITS
);
2201 #if defined(DEBUG_TLB)
2202 printf("tlb_set_page: vaddr=" TARGET_FMT_lx
" paddr=0x" TARGET_FMT_plx
2203 " prot=%x idx=%d pd=0x%08lx\n",
2204 vaddr
, paddr
, prot
, mmu_idx
, pd
);
2208 if (!is_ram_rom_romd(section
)) {
2209 /* IO memory case (romd handled later) */
2210 address
|= TLB_MMIO
;
2212 if (is_ram_rom_romd(section
)) {
2213 addend
= (unsigned long)memory_region_get_ram_ptr(section
->mr
)
2214 + section_addr(section
, paddr
);
2218 if (is_ram_rom(section
)) {
2220 iotlb
= (memory_region_get_ram_addr(section
->mr
) & TARGET_PAGE_MASK
)
2221 + section_addr(section
, paddr
);
2222 if (!section
->readonly
)
2223 iotlb
|= phys_section_notdirty
;
2225 iotlb
|= phys_section_rom
;
2227 /* IO handlers are currently passed a physical address.
2228 It would be nice to pass an offset from the base address
2229 of that region. This would avoid having to special case RAM,
2230 and avoid full address decoding in every device.
2231 We can't use the high bits of pd for this because
2232 IO_MEM_ROMD uses these as a ram address. */
2233 iotlb
= section
- phys_sections
;
2234 iotlb
+= section_addr(section
, paddr
);
2237 code_address
= address
;
2238 /* Make accesses to pages with watchpoints go via the
2239 watchpoint trap routines. */
2240 QTAILQ_FOREACH(wp
, &env
->watchpoints
, entry
) {
2241 if (vaddr
== (wp
->vaddr
& TARGET_PAGE_MASK
)) {
2242 /* Avoid trapping reads of pages with a write breakpoint. */
2243 if ((prot
& PAGE_WRITE
) || (wp
->flags
& BP_MEM_READ
)) {
2244 iotlb
= phys_section_watch
+ paddr
;
2245 address
|= TLB_MMIO
;
2251 index
= (vaddr
>> TARGET_PAGE_BITS
) & (CPU_TLB_SIZE
- 1);
2252 env
->iotlb
[mmu_idx
][index
] = iotlb
- vaddr
;
2253 te
= &env
->tlb_table
[mmu_idx
][index
];
2254 te
->addend
= addend
- vaddr
;
2255 if (prot
& PAGE_READ
) {
2256 te
->addr_read
= address
;
2261 if (prot
& PAGE_EXEC
) {
2262 te
->addr_code
= code_address
;
2266 if (prot
& PAGE_WRITE
) {
2267 if ((memory_region_is_ram(section
->mr
) && section
->readonly
)
2268 || is_romd(section
)) {
2269 /* Write access calls the I/O callback. */
2270 te
->addr_write
= address
| TLB_MMIO
;
2271 } else if (memory_region_is_ram(section
->mr
)
2272 && !cpu_physical_memory_is_dirty(
2273 section
->mr
->ram_addr
2274 + section_addr(section
, paddr
))) {
2275 te
->addr_write
= address
| TLB_NOTDIRTY
;
2277 te
->addr_write
= address
;
2280 te
->addr_write
= -1;
2286 void tlb_flush(CPUArchState
*env
, int flush_global
)
2290 void tlb_flush_page(CPUArchState
*env
, target_ulong addr
)
2295 * Walks guest process memory "regions" one by one
2296 * and calls callback function 'fn' for each region.
2299 struct walk_memory_regions_data
2301 walk_memory_regions_fn fn
;
2303 unsigned long start
;
2307 static int walk_memory_regions_end(struct walk_memory_regions_data
*data
,
2308 abi_ulong end
, int new_prot
)
2310 if (data
->start
!= -1ul) {
2311 int rc
= data
->fn(data
->priv
, data
->start
, end
, data
->prot
);
2317 data
->start
= (new_prot
? end
: -1ul);
2318 data
->prot
= new_prot
;
2323 static int walk_memory_regions_1(struct walk_memory_regions_data
*data
,
2324 abi_ulong base
, int level
, void **lp
)
2330 return walk_memory_regions_end(data
, base
, 0);
2335 for (i
= 0; i
< L2_SIZE
; ++i
) {
2336 int prot
= pd
[i
].flags
;
2338 pa
= base
| (i
<< TARGET_PAGE_BITS
);
2339 if (prot
!= data
->prot
) {
2340 rc
= walk_memory_regions_end(data
, pa
, prot
);
2348 for (i
= 0; i
< L2_SIZE
; ++i
) {
2349 pa
= base
| ((abi_ulong
)i
<<
2350 (TARGET_PAGE_BITS
+ L2_BITS
* level
));
2351 rc
= walk_memory_regions_1(data
, pa
, level
- 1, pp
+ i
);
2361 int walk_memory_regions(void *priv
, walk_memory_regions_fn fn
)
2363 struct walk_memory_regions_data data
;
2371 for (i
= 0; i
< V_L1_SIZE
; i
++) {
2372 int rc
= walk_memory_regions_1(&data
, (abi_ulong
)i
<< V_L1_SHIFT
,
2373 V_L1_SHIFT
/ L2_BITS
- 1, l1_map
+ i
);
2379 return walk_memory_regions_end(&data
, 0, 0);
2382 static int dump_region(void *priv
, abi_ulong start
,
2383 abi_ulong end
, unsigned long prot
)
2385 FILE *f
= (FILE *)priv
;
2387 (void) fprintf(f
, TARGET_ABI_FMT_lx
"-"TARGET_ABI_FMT_lx
2388 " "TARGET_ABI_FMT_lx
" %c%c%c\n",
2389 start
, end
, end
- start
,
2390 ((prot
& PAGE_READ
) ? 'r' : '-'),
2391 ((prot
& PAGE_WRITE
) ? 'w' : '-'),
2392 ((prot
& PAGE_EXEC
) ? 'x' : '-'));
2397 /* dump memory mappings */
2398 void page_dump(FILE *f
)
2400 (void) fprintf(f
, "%-8s %-8s %-8s %s\n",
2401 "start", "end", "size", "prot");
2402 walk_memory_regions(f
, dump_region
);
2405 int page_get_flags(target_ulong address
)
2409 p
= page_find(address
>> TARGET_PAGE_BITS
);
2415 /* Modify the flags of a page and invalidate the code if necessary.
2416 The flag PAGE_WRITE_ORG is positioned automatically depending
2417 on PAGE_WRITE. The mmap_lock should already be held. */
2418 void page_set_flags(target_ulong start
, target_ulong end
, int flags
)
2420 target_ulong addr
, len
;
2422 /* This function should never be called with addresses outside the
2423 guest address space. If this assert fires, it probably indicates
2424 a missing call to h2g_valid. */
2425 #if TARGET_ABI_BITS > L1_MAP_ADDR_SPACE_BITS
2426 assert(end
< ((abi_ulong
)1 << L1_MAP_ADDR_SPACE_BITS
));
2428 assert(start
< end
);
2430 start
= start
& TARGET_PAGE_MASK
;
2431 end
= TARGET_PAGE_ALIGN(end
);
2433 if (flags
& PAGE_WRITE
) {
2434 flags
|= PAGE_WRITE_ORG
;
2437 for (addr
= start
, len
= end
- start
;
2439 len
-= TARGET_PAGE_SIZE
, addr
+= TARGET_PAGE_SIZE
) {
2440 PageDesc
*p
= page_find_alloc(addr
>> TARGET_PAGE_BITS
, 1);
2442 /* If the write protection bit is set, then we invalidate
2444 if (!(p
->flags
& PAGE_WRITE
) &&
2445 (flags
& PAGE_WRITE
) &&
2447 tb_invalidate_phys_page(addr
, 0, NULL
);
2453 int page_check_range(target_ulong start
, target_ulong len
, int flags
)
2459 /* This function should never be called with addresses outside the
2460 guest address space. If this assert fires, it probably indicates
2461 a missing call to h2g_valid. */
2462 #if TARGET_ABI_BITS > L1_MAP_ADDR_SPACE_BITS
2463 assert(start
< ((abi_ulong
)1 << L1_MAP_ADDR_SPACE_BITS
));
2469 if (start
+ len
- 1 < start
) {
2470 /* We've wrapped around. */
2474 end
= TARGET_PAGE_ALIGN(start
+len
); /* must do before we loose bits in the next step */
2475 start
= start
& TARGET_PAGE_MASK
;
2477 for (addr
= start
, len
= end
- start
;
2479 len
-= TARGET_PAGE_SIZE
, addr
+= TARGET_PAGE_SIZE
) {
2480 p
= page_find(addr
>> TARGET_PAGE_BITS
);
2483 if( !(p
->flags
& PAGE_VALID
) )
2486 if ((flags
& PAGE_READ
) && !(p
->flags
& PAGE_READ
))
2488 if (flags
& PAGE_WRITE
) {
2489 if (!(p
->flags
& PAGE_WRITE_ORG
))
2491 /* unprotect the page if it was put read-only because it
2492 contains translated code */
2493 if (!(p
->flags
& PAGE_WRITE
)) {
2494 if (!page_unprotect(addr
, 0, NULL
))
2503 /* called from signal handler: invalidate the code and unprotect the
2504 page. Return TRUE if the fault was successfully handled. */
2505 int page_unprotect(target_ulong address
, unsigned long pc
, void *puc
)
2509 target_ulong host_start
, host_end
, addr
;
2511 /* Technically this isn't safe inside a signal handler. However we
2512 know this only ever happens in a synchronous SEGV handler, so in
2513 practice it seems to be ok. */
2516 p
= page_find(address
>> TARGET_PAGE_BITS
);
2522 /* if the page was really writable, then we change its
2523 protection back to writable */
2524 if ((p
->flags
& PAGE_WRITE_ORG
) && !(p
->flags
& PAGE_WRITE
)) {
2525 host_start
= address
& qemu_host_page_mask
;
2526 host_end
= host_start
+ qemu_host_page_size
;
2529 for (addr
= host_start
; addr
< host_end
; addr
+= TARGET_PAGE_SIZE
) {
2530 p
= page_find(addr
>> TARGET_PAGE_BITS
);
2531 p
->flags
|= PAGE_WRITE
;
2534 /* and since the content will be modified, we must invalidate
2535 the corresponding translated code. */
2536 tb_invalidate_phys_page(addr
, pc
, puc
);
2537 #ifdef DEBUG_TB_CHECK
2538 tb_invalidate_check(addr
);
2541 mprotect((void *)g2h(host_start
), qemu_host_page_size
,
2551 static inline void tlb_set_dirty(CPUArchState
*env
,
2552 unsigned long addr
, target_ulong vaddr
)
2555 #endif /* defined(CONFIG_USER_ONLY) */
2557 #if !defined(CONFIG_USER_ONLY)
2559 #define SUBPAGE_IDX(addr) ((addr) & ~TARGET_PAGE_MASK)
2560 typedef struct subpage_t
{
2562 target_phys_addr_t base
;
2563 uint16_t sub_section
[TARGET_PAGE_SIZE
];
2566 static int subpage_register (subpage_t
*mmio
, uint32_t start
, uint32_t end
,
2568 static subpage_t
*subpage_init(target_phys_addr_t base
);
2569 static void destroy_page_desc(uint16_t section_index
)
2571 MemoryRegionSection
*section
= &phys_sections
[section_index
];
2572 MemoryRegion
*mr
= section
->mr
;
2575 subpage_t
*subpage
= container_of(mr
, subpage_t
, iomem
);
2576 memory_region_destroy(&subpage
->iomem
);
2581 static void destroy_l2_mapping(PhysPageEntry
*lp
, unsigned level
)
2586 if (lp
->ptr
== PHYS_MAP_NODE_NIL
) {
2590 p
= phys_map_nodes
[lp
->ptr
];
2591 for (i
= 0; i
< L2_SIZE
; ++i
) {
2592 if (!p
[i
].is_leaf
) {
2593 destroy_l2_mapping(&p
[i
], level
- 1);
2595 destroy_page_desc(p
[i
].ptr
);
2599 lp
->ptr
= PHYS_MAP_NODE_NIL
;
2602 static void destroy_all_mappings(void)
2604 destroy_l2_mapping(&phys_map
, P_L2_LEVELS
- 1);
2605 phys_map_nodes_reset();
2608 static uint16_t phys_section_add(MemoryRegionSection
*section
)
2610 if (phys_sections_nb
== phys_sections_nb_alloc
) {
2611 phys_sections_nb_alloc
= MAX(phys_sections_nb_alloc
* 2, 16);
2612 phys_sections
= g_renew(MemoryRegionSection
, phys_sections
,
2613 phys_sections_nb_alloc
);
2615 phys_sections
[phys_sections_nb
] = *section
;
2616 return phys_sections_nb
++;
2619 static void phys_sections_clear(void)
2621 phys_sections_nb
= 0;
2624 /* register physical memory.
2625 For RAM, 'size' must be a multiple of the target page size.
2626 If (phys_offset & ~TARGET_PAGE_MASK) != 0, then it is an
2627 io memory page. The address used when calling the IO function is
2628 the offset from the start of the region, plus region_offset. Both
2629 start_addr and region_offset are rounded down to a page boundary
2630 before calculating this offset. This should not be a problem unless
2631 the low bits of start_addr and region_offset differ. */
2632 static void register_subpage(MemoryRegionSection
*section
)
2635 target_phys_addr_t base
= section
->offset_within_address_space
2637 MemoryRegionSection
*existing
= phys_page_find(base
>> TARGET_PAGE_BITS
);
2638 MemoryRegionSection subsection
= {
2639 .offset_within_address_space
= base
,
2640 .size
= TARGET_PAGE_SIZE
,
2642 target_phys_addr_t start
, end
;
2644 assert(existing
->mr
->subpage
|| existing
->mr
== &io_mem_unassigned
);
2646 if (!(existing
->mr
->subpage
)) {
2647 subpage
= subpage_init(base
);
2648 subsection
.mr
= &subpage
->iomem
;
2649 phys_page_set(base
>> TARGET_PAGE_BITS
, 1,
2650 phys_section_add(&subsection
));
2652 subpage
= container_of(existing
->mr
, subpage_t
, iomem
);
2654 start
= section
->offset_within_address_space
& ~TARGET_PAGE_MASK
;
2655 end
= start
+ section
->size
;
2656 subpage_register(subpage
, start
, end
, phys_section_add(section
));
2660 static void register_multipage(MemoryRegionSection
*section
)
2662 target_phys_addr_t start_addr
= section
->offset_within_address_space
;
2663 ram_addr_t size
= section
->size
;
2664 target_phys_addr_t addr
;
2665 uint16_t section_index
= phys_section_add(section
);
2670 phys_page_set(addr
>> TARGET_PAGE_BITS
, size
>> TARGET_PAGE_BITS
,
2674 void cpu_register_physical_memory_log(MemoryRegionSection
*section
,
2677 MemoryRegionSection now
= *section
, remain
= *section
;
2679 if ((now
.offset_within_address_space
& ~TARGET_PAGE_MASK
)
2680 || (now
.size
< TARGET_PAGE_SIZE
)) {
2681 now
.size
= MIN(TARGET_PAGE_ALIGN(now
.offset_within_address_space
)
2682 - now
.offset_within_address_space
,
2684 register_subpage(&now
);
2685 remain
.size
-= now
.size
;
2686 remain
.offset_within_address_space
+= now
.size
;
2687 remain
.offset_within_region
+= now
.size
;
2690 now
.size
&= TARGET_PAGE_MASK
;
2692 register_multipage(&now
);
2693 remain
.size
-= now
.size
;
2694 remain
.offset_within_address_space
+= now
.size
;
2695 remain
.offset_within_region
+= now
.size
;
2699 register_subpage(&now
);
2704 void qemu_register_coalesced_mmio(target_phys_addr_t addr
, ram_addr_t size
)
2707 kvm_coalesce_mmio_region(addr
, size
);
2710 void qemu_unregister_coalesced_mmio(target_phys_addr_t addr
, ram_addr_t size
)
2713 kvm_uncoalesce_mmio_region(addr
, size
);
2716 void qemu_flush_coalesced_mmio_buffer(void)
2719 kvm_flush_coalesced_mmio_buffer();
2722 #if defined(__linux__) && !defined(TARGET_S390X)
2724 #include <sys/vfs.h>
2726 #define HUGETLBFS_MAGIC 0x958458f6
2728 static long gethugepagesize(const char *path
)
2734 ret
= statfs(path
, &fs
);
2735 } while (ret
!= 0 && errno
== EINTR
);
2742 if (fs
.f_type
!= HUGETLBFS_MAGIC
)
2743 fprintf(stderr
, "Warning: path not on HugeTLBFS: %s\n", path
);
2748 static void *file_ram_alloc(RAMBlock
*block
,
2758 unsigned long hpagesize
;
2760 hpagesize
= gethugepagesize(path
);
2765 if (memory
< hpagesize
) {
2769 if (kvm_enabled() && !kvm_has_sync_mmu()) {
2770 fprintf(stderr
, "host lacks kvm mmu notifiers, -mem-path unsupported\n");
2774 if (asprintf(&filename
, "%s/qemu_back_mem.XXXXXX", path
) == -1) {
2778 fd
= mkstemp(filename
);
2780 perror("unable to create backing store for hugepages");
2787 memory
= (memory
+hpagesize
-1) & ~(hpagesize
-1);
2790 * ftruncate is not supported by hugetlbfs in older
2791 * hosts, so don't bother bailing out on errors.
2792 * If anything goes wrong with it under other filesystems,
2795 if (ftruncate(fd
, memory
))
2796 perror("ftruncate");
2799 /* NB: MAP_POPULATE won't exhaustively alloc all phys pages in the case
2800 * MAP_PRIVATE is requested. For mem_prealloc we mmap as MAP_SHARED
2801 * to sidestep this quirk.
2803 flags
= mem_prealloc
? MAP_POPULATE
| MAP_SHARED
: MAP_PRIVATE
;
2804 area
= mmap(0, memory
, PROT_READ
| PROT_WRITE
, flags
, fd
, 0);
2806 area
= mmap(0, memory
, PROT_READ
| PROT_WRITE
, MAP_PRIVATE
, fd
, 0);
2808 if (area
== MAP_FAILED
) {
2809 perror("file_ram_alloc: can't mmap RAM pages");
2818 static ram_addr_t
find_ram_offset(ram_addr_t size
)
2820 RAMBlock
*block
, *next_block
;
2821 ram_addr_t offset
= RAM_ADDR_MAX
, mingap
= RAM_ADDR_MAX
;
2823 if (QLIST_EMPTY(&ram_list
.blocks
))
2826 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
2827 ram_addr_t end
, next
= RAM_ADDR_MAX
;
2829 end
= block
->offset
+ block
->length
;
2831 QLIST_FOREACH(next_block
, &ram_list
.blocks
, next
) {
2832 if (next_block
->offset
>= end
) {
2833 next
= MIN(next
, next_block
->offset
);
2836 if (next
- end
>= size
&& next
- end
< mingap
) {
2838 mingap
= next
- end
;
2842 if (offset
== RAM_ADDR_MAX
) {
2843 fprintf(stderr
, "Failed to find gap of requested size: %" PRIu64
"\n",
2851 static ram_addr_t
last_ram_offset(void)
2854 ram_addr_t last
= 0;
2856 QLIST_FOREACH(block
, &ram_list
.blocks
, next
)
2857 last
= MAX(last
, block
->offset
+ block
->length
);
2862 void qemu_ram_set_idstr(ram_addr_t addr
, const char *name
, DeviceState
*dev
)
2864 RAMBlock
*new_block
, *block
;
2867 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
2868 if (block
->offset
== addr
) {
2874 assert(!new_block
->idstr
[0]);
2876 if (dev
&& dev
->parent_bus
&& dev
->parent_bus
->info
->get_dev_path
) {
2877 char *id
= dev
->parent_bus
->info
->get_dev_path(dev
);
2879 snprintf(new_block
->idstr
, sizeof(new_block
->idstr
), "%s/", id
);
2883 pstrcat(new_block
->idstr
, sizeof(new_block
->idstr
), name
);
2885 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
2886 if (block
!= new_block
&& !strcmp(block
->idstr
, new_block
->idstr
)) {
2887 fprintf(stderr
, "RAMBlock \"%s\" already registered, abort!\n",
2894 ram_addr_t
qemu_ram_alloc_from_ptr(ram_addr_t size
, void *host
,
2897 RAMBlock
*new_block
;
2899 size
= TARGET_PAGE_ALIGN(size
);
2900 new_block
= g_malloc0(sizeof(*new_block
));
2903 new_block
->offset
= find_ram_offset(size
);
2905 new_block
->host
= host
;
2906 new_block
->flags
|= RAM_PREALLOC_MASK
;
2909 #if defined (__linux__) && !defined(TARGET_S390X)
2910 new_block
->host
= file_ram_alloc(new_block
, size
, mem_path
);
2911 if (!new_block
->host
) {
2912 new_block
->host
= qemu_vmalloc(size
);
2913 qemu_madvise(new_block
->host
, size
, QEMU_MADV_MERGEABLE
);
2916 fprintf(stderr
, "-mem-path option unsupported\n");
2920 #if defined(TARGET_S390X) && defined(CONFIG_KVM)
2921 /* S390 KVM requires the topmost vma of the RAM to be smaller than
2922 an system defined value, which is at least 256GB. Larger systems
2923 have larger values. We put the guest between the end of data
2924 segment (system break) and this value. We use 32GB as a base to
2925 have enough room for the system break to grow. */
2926 new_block
->host
= mmap((void*)0x800000000, size
,
2927 PROT_EXEC
|PROT_READ
|PROT_WRITE
,
2928 MAP_SHARED
| MAP_ANONYMOUS
| MAP_FIXED
, -1, 0);
2929 if (new_block
->host
== MAP_FAILED
) {
2930 fprintf(stderr
, "Allocating RAM failed\n");
2934 if (xen_enabled()) {
2935 xen_ram_alloc(new_block
->offset
, size
, mr
);
2937 new_block
->host
= qemu_vmalloc(size
);
2940 qemu_madvise(new_block
->host
, size
, QEMU_MADV_MERGEABLE
);
2943 new_block
->length
= size
;
2945 QLIST_INSERT_HEAD(&ram_list
.blocks
, new_block
, next
);
2947 ram_list
.phys_dirty
= g_realloc(ram_list
.phys_dirty
,
2948 last_ram_offset() >> TARGET_PAGE_BITS
);
2949 memset(ram_list
.phys_dirty
+ (new_block
->offset
>> TARGET_PAGE_BITS
),
2950 0xff, size
>> TARGET_PAGE_BITS
);
2953 kvm_setup_guest_memory(new_block
->host
, size
);
2955 return new_block
->offset
;
2958 ram_addr_t
qemu_ram_alloc(ram_addr_t size
, MemoryRegion
*mr
)
2960 return qemu_ram_alloc_from_ptr(size
, NULL
, mr
);
2963 void qemu_ram_free_from_ptr(ram_addr_t addr
)
2967 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
2968 if (addr
== block
->offset
) {
2969 QLIST_REMOVE(block
, next
);
2976 void qemu_ram_free(ram_addr_t addr
)
2980 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
2981 if (addr
== block
->offset
) {
2982 QLIST_REMOVE(block
, next
);
2983 if (block
->flags
& RAM_PREALLOC_MASK
) {
2985 } else if (mem_path
) {
2986 #if defined (__linux__) && !defined(TARGET_S390X)
2988 munmap(block
->host
, block
->length
);
2991 qemu_vfree(block
->host
);
2997 #if defined(TARGET_S390X) && defined(CONFIG_KVM)
2998 munmap(block
->host
, block
->length
);
3000 if (xen_enabled()) {
3001 xen_invalidate_map_cache_entry(block
->host
);
3003 qemu_vfree(block
->host
);
3015 void qemu_ram_remap(ram_addr_t addr
, ram_addr_t length
)
3022 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
3023 offset
= addr
- block
->offset
;
3024 if (offset
< block
->length
) {
3025 vaddr
= block
->host
+ offset
;
3026 if (block
->flags
& RAM_PREALLOC_MASK
) {
3030 munmap(vaddr
, length
);
3032 #if defined(__linux__) && !defined(TARGET_S390X)
3035 flags
|= mem_prealloc
? MAP_POPULATE
| MAP_SHARED
:
3038 flags
|= MAP_PRIVATE
;
3040 area
= mmap(vaddr
, length
, PROT_READ
| PROT_WRITE
,
3041 flags
, block
->fd
, offset
);
3043 flags
|= MAP_PRIVATE
| MAP_ANONYMOUS
;
3044 area
= mmap(vaddr
, length
, PROT_READ
| PROT_WRITE
,
3051 #if defined(TARGET_S390X) && defined(CONFIG_KVM)
3052 flags
|= MAP_SHARED
| MAP_ANONYMOUS
;
3053 area
= mmap(vaddr
, length
, PROT_EXEC
|PROT_READ
|PROT_WRITE
,
3056 flags
|= MAP_PRIVATE
| MAP_ANONYMOUS
;
3057 area
= mmap(vaddr
, length
, PROT_READ
| PROT_WRITE
,
3061 if (area
!= vaddr
) {
3062 fprintf(stderr
, "Could not remap addr: "
3063 RAM_ADDR_FMT
"@" RAM_ADDR_FMT
"\n",
3067 qemu_madvise(vaddr
, length
, QEMU_MADV_MERGEABLE
);
3073 #endif /* !_WIN32 */
3075 /* Return a host pointer to ram allocated with qemu_ram_alloc.
3076 With the exception of the softmmu code in this file, this should
3077 only be used for local memory (e.g. video ram) that the device owns,
3078 and knows it isn't going to access beyond the end of the block.
3080 It should not be used for general purpose DMA.
3081 Use cpu_physical_memory_map/cpu_physical_memory_rw instead.
3083 void *qemu_get_ram_ptr(ram_addr_t addr
)
3087 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
3088 if (addr
- block
->offset
< block
->length
) {
3089 /* Move this entry to to start of the list. */
3090 if (block
!= QLIST_FIRST(&ram_list
.blocks
)) {
3091 QLIST_REMOVE(block
, next
);
3092 QLIST_INSERT_HEAD(&ram_list
.blocks
, block
, next
);
3094 if (xen_enabled()) {
3095 /* We need to check if the requested address is in the RAM
3096 * because we don't want to map the entire memory in QEMU.
3097 * In that case just map until the end of the page.
3099 if (block
->offset
== 0) {
3100 return xen_map_cache(addr
, 0, 0);
3101 } else if (block
->host
== NULL
) {
3103 xen_map_cache(block
->offset
, block
->length
, 1);
3106 return block
->host
+ (addr
- block
->offset
);
3110 fprintf(stderr
, "Bad ram offset %" PRIx64
"\n", (uint64_t)addr
);
3116 /* Return a host pointer to ram allocated with qemu_ram_alloc.
3117 * Same as qemu_get_ram_ptr but avoid reordering ramblocks.
3119 void *qemu_safe_ram_ptr(ram_addr_t addr
)
3123 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
3124 if (addr
- block
->offset
< block
->length
) {
3125 if (xen_enabled()) {
3126 /* We need to check if the requested address is in the RAM
3127 * because we don't want to map the entire memory in QEMU.
3128 * In that case just map until the end of the page.
3130 if (block
->offset
== 0) {
3131 return xen_map_cache(addr
, 0, 0);
3132 } else if (block
->host
== NULL
) {
3134 xen_map_cache(block
->offset
, block
->length
, 1);
3137 return block
->host
+ (addr
- block
->offset
);
3141 fprintf(stderr
, "Bad ram offset %" PRIx64
"\n", (uint64_t)addr
);
3147 /* Return a host pointer to guest's ram. Similar to qemu_get_ram_ptr
3148 * but takes a size argument */
3149 void *qemu_ram_ptr_length(ram_addr_t addr
, ram_addr_t
*size
)
3154 if (xen_enabled()) {
3155 return xen_map_cache(addr
, *size
, 1);
3159 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
3160 if (addr
- block
->offset
< block
->length
) {
3161 if (addr
- block
->offset
+ *size
> block
->length
)
3162 *size
= block
->length
- addr
+ block
->offset
;
3163 return block
->host
+ (addr
- block
->offset
);
3167 fprintf(stderr
, "Bad ram offset %" PRIx64
"\n", (uint64_t)addr
);
3172 void qemu_put_ram_ptr(void *addr
)
3174 trace_qemu_put_ram_ptr(addr
);
3177 int qemu_ram_addr_from_host(void *ptr
, ram_addr_t
*ram_addr
)
3180 uint8_t *host
= ptr
;
3182 if (xen_enabled()) {
3183 *ram_addr
= xen_ram_addr_from_mapcache(ptr
);
3187 QLIST_FOREACH(block
, &ram_list
.blocks
, next
) {
3188 /* This case append when the block is not mapped. */
3189 if (block
->host
== NULL
) {
3192 if (host
- block
->host
< block
->length
) {
3193 *ram_addr
= block
->offset
+ (host
- block
->host
);
3201 /* Some of the softmmu routines need to translate from a host pointer
3202 (typically a TLB entry) back to a ram offset. */
3203 ram_addr_t
qemu_ram_addr_from_host_nofail(void *ptr
)
3205 ram_addr_t ram_addr
;
3207 if (qemu_ram_addr_from_host(ptr
, &ram_addr
)) {
3208 fprintf(stderr
, "Bad ram pointer %p\n", ptr
);
3214 static uint64_t unassigned_mem_read(void *opaque
, target_phys_addr_t addr
,
3217 #ifdef DEBUG_UNASSIGNED
3218 printf("Unassigned mem read " TARGET_FMT_plx
"\n", addr
);
3220 #if defined(TARGET_ALPHA) || defined(TARGET_SPARC) || defined(TARGET_MICROBLAZE)
3221 cpu_unassigned_access(cpu_single_env
, addr
, 0, 0, 0, size
);
3226 static void unassigned_mem_write(void *opaque
, target_phys_addr_t addr
,
3227 uint64_t val
, unsigned size
)
3229 #ifdef DEBUG_UNASSIGNED
3230 printf("Unassigned mem write " TARGET_FMT_plx
" = 0x%"PRIx64
"\n", addr
, val
);
3232 #if defined(TARGET_ALPHA) || defined(TARGET_SPARC) || defined(TARGET_MICROBLAZE)
3233 cpu_unassigned_access(cpu_single_env
, addr
, 1, 0, 0, size
);
3237 static const MemoryRegionOps unassigned_mem_ops
= {
3238 .read
= unassigned_mem_read
,
3239 .write
= unassigned_mem_write
,
3240 .endianness
= DEVICE_NATIVE_ENDIAN
,
3243 static uint64_t error_mem_read(void *opaque
, target_phys_addr_t addr
,
3249 static void error_mem_write(void *opaque
, target_phys_addr_t addr
,
3250 uint64_t value
, unsigned size
)
3255 static const MemoryRegionOps error_mem_ops
= {
3256 .read
= error_mem_read
,
3257 .write
= error_mem_write
,
3258 .endianness
= DEVICE_NATIVE_ENDIAN
,
3261 static const MemoryRegionOps rom_mem_ops
= {
3262 .read
= error_mem_read
,
3263 .write
= unassigned_mem_write
,
3264 .endianness
= DEVICE_NATIVE_ENDIAN
,
3267 static void notdirty_mem_write(void *opaque
, target_phys_addr_t ram_addr
,
3268 uint64_t val
, unsigned size
)
3271 dirty_flags
= cpu_physical_memory_get_dirty_flags(ram_addr
);
3272 if (!(dirty_flags
& CODE_DIRTY_FLAG
)) {
3273 #if !defined(CONFIG_USER_ONLY)
3274 tb_invalidate_phys_page_fast(ram_addr
, size
);
3275 dirty_flags
= cpu_physical_memory_get_dirty_flags(ram_addr
);
3280 stb_p(qemu_get_ram_ptr(ram_addr
), val
);
3283 stw_p(qemu_get_ram_ptr(ram_addr
), val
);
3286 stl_p(qemu_get_ram_ptr(ram_addr
), val
);
3291 dirty_flags
|= (0xff & ~CODE_DIRTY_FLAG
);
3292 cpu_physical_memory_set_dirty_flags(ram_addr
, dirty_flags
);
3293 /* we remove the notdirty callback only if the code has been
3295 if (dirty_flags
== 0xff)
3296 tlb_set_dirty(cpu_single_env
, cpu_single_env
->mem_io_vaddr
);
3299 static const MemoryRegionOps notdirty_mem_ops
= {
3300 .read
= error_mem_read
,
3301 .write
= notdirty_mem_write
,
3302 .endianness
= DEVICE_NATIVE_ENDIAN
,
3305 /* Generate a debug exception if a watchpoint has been hit. */
3306 static void check_watchpoint(int offset
, int len_mask
, int flags
)
3308 CPUArchState
*env
= cpu_single_env
;
3309 target_ulong pc
, cs_base
;
3310 TranslationBlock
*tb
;
3315 if (env
->watchpoint_hit
) {
3316 /* We re-entered the check after replacing the TB. Now raise
3317 * the debug interrupt so that is will trigger after the
3318 * current instruction. */
3319 cpu_interrupt(env
, CPU_INTERRUPT_DEBUG
);
3322 vaddr
= (env
->mem_io_vaddr
& TARGET_PAGE_MASK
) + offset
;
3323 QTAILQ_FOREACH(wp
, &env
->watchpoints
, entry
) {
3324 if ((vaddr
== (wp
->vaddr
& len_mask
) ||
3325 (vaddr
& wp
->len_mask
) == wp
->vaddr
) && (wp
->flags
& flags
)) {
3326 wp
->flags
|= BP_WATCHPOINT_HIT
;
3327 if (!env
->watchpoint_hit
) {
3328 env
->watchpoint_hit
= wp
;
3329 tb
= tb_find_pc(env
->mem_io_pc
);
3331 cpu_abort(env
, "check_watchpoint: could not find TB for "
3332 "pc=%p", (void *)env
->mem_io_pc
);
3334 cpu_restore_state(tb
, env
, env
->mem_io_pc
);
3335 tb_phys_invalidate(tb
, -1);
3336 if (wp
->flags
& BP_STOP_BEFORE_ACCESS
) {
3337 env
->exception_index
= EXCP_DEBUG
;
3340 cpu_get_tb_cpu_state(env
, &pc
, &cs_base
, &cpu_flags
);
3341 tb_gen_code(env
, pc
, cs_base
, cpu_flags
, 1);
3342 cpu_resume_from_signal(env
, NULL
);
3346 wp
->flags
&= ~BP_WATCHPOINT_HIT
;
3351 /* Watchpoint access routines. Watchpoints are inserted using TLB tricks,
3352 so these check for a hit then pass through to the normal out-of-line
3354 static uint64_t watch_mem_read(void *opaque
, target_phys_addr_t addr
,
3357 check_watchpoint(addr
& ~TARGET_PAGE_MASK
, ~(size
- 1), BP_MEM_READ
);
3359 case 1: return ldub_phys(addr
);
3360 case 2: return lduw_phys(addr
);
3361 case 4: return ldl_phys(addr
);
3366 static void watch_mem_write(void *opaque
, target_phys_addr_t addr
,
3367 uint64_t val
, unsigned size
)
3369 check_watchpoint(addr
& ~TARGET_PAGE_MASK
, ~(size
- 1), BP_MEM_WRITE
);
3372 stb_phys(addr
, val
);
3375 stw_phys(addr
, val
);
3378 stl_phys(addr
, val
);
3384 static const MemoryRegionOps watch_mem_ops
= {
3385 .read
= watch_mem_read
,
3386 .write
= watch_mem_write
,
3387 .endianness
= DEVICE_NATIVE_ENDIAN
,
3390 static uint64_t subpage_read(void *opaque
, target_phys_addr_t addr
,
3393 subpage_t
*mmio
= opaque
;
3394 unsigned int idx
= SUBPAGE_IDX(addr
);
3395 MemoryRegionSection
*section
;
3396 #if defined(DEBUG_SUBPAGE)
3397 printf("%s: subpage %p len %d addr " TARGET_FMT_plx
" idx %d\n", __func__
,
3398 mmio
, len
, addr
, idx
);
3401 section
= &phys_sections
[mmio
->sub_section
[idx
]];
3403 addr
-= section
->offset_within_address_space
;
3404 addr
+= section
->offset_within_region
;
3405 return io_mem_read(section
->mr
, addr
, len
);
3408 static void subpage_write(void *opaque
, target_phys_addr_t addr
,
3409 uint64_t value
, unsigned len
)
3411 subpage_t
*mmio
= opaque
;
3412 unsigned int idx
= SUBPAGE_IDX(addr
);
3413 MemoryRegionSection
*section
;
3414 #if defined(DEBUG_SUBPAGE)
3415 printf("%s: subpage %p len %d addr " TARGET_FMT_plx
3416 " idx %d value %"PRIx64
"\n",
3417 __func__
, mmio
, len
, addr
, idx
, value
);
3420 section
= &phys_sections
[mmio
->sub_section
[idx
]];
3422 addr
-= section
->offset_within_address_space
;
3423 addr
+= section
->offset_within_region
;
3424 io_mem_write(section
->mr
, addr
, value
, len
);
3427 static const MemoryRegionOps subpage_ops
= {
3428 .read
= subpage_read
,
3429 .write
= subpage_write
,
3430 .endianness
= DEVICE_NATIVE_ENDIAN
,
3433 static uint64_t subpage_ram_read(void *opaque
, target_phys_addr_t addr
,
3436 ram_addr_t raddr
= addr
;
3437 void *ptr
= qemu_get_ram_ptr(raddr
);
3439 case 1: return ldub_p(ptr
);
3440 case 2: return lduw_p(ptr
);
3441 case 4: return ldl_p(ptr
);
3446 static void subpage_ram_write(void *opaque
, target_phys_addr_t addr
,
3447 uint64_t value
, unsigned size
)
3449 ram_addr_t raddr
= addr
;
3450 void *ptr
= qemu_get_ram_ptr(raddr
);
3452 case 1: return stb_p(ptr
, value
);
3453 case 2: return stw_p(ptr
, value
);
3454 case 4: return stl_p(ptr
, value
);
3459 static const MemoryRegionOps subpage_ram_ops
= {
3460 .read
= subpage_ram_read
,
3461 .write
= subpage_ram_write
,
3462 .endianness
= DEVICE_NATIVE_ENDIAN
,
3465 static int subpage_register (subpage_t
*mmio
, uint32_t start
, uint32_t end
,
3470 if (start
>= TARGET_PAGE_SIZE
|| end
>= TARGET_PAGE_SIZE
)
3472 idx
= SUBPAGE_IDX(start
);
3473 eidx
= SUBPAGE_IDX(end
);
3474 #if defined(DEBUG_SUBPAGE)
3475 printf("%s: %p start %08x end %08x idx %08x eidx %08x mem %ld\n", __func__
,
3476 mmio
, start
, end
, idx
, eidx
, memory
);
3478 if (memory_region_is_ram(phys_sections
[section
].mr
)) {
3479 MemoryRegionSection new_section
= phys_sections
[section
];
3480 new_section
.mr
= &io_mem_subpage_ram
;
3481 section
= phys_section_add(&new_section
);
3483 for (; idx
<= eidx
; idx
++) {
3484 mmio
->sub_section
[idx
] = section
;
3490 static subpage_t
*subpage_init(target_phys_addr_t base
)
3494 mmio
= g_malloc0(sizeof(subpage_t
));
3497 memory_region_init_io(&mmio
->iomem
, &subpage_ops
, mmio
,
3498 "subpage", TARGET_PAGE_SIZE
);
3499 mmio
->iomem
.subpage
= true;
3500 #if defined(DEBUG_SUBPAGE)
3501 printf("%s: %p base " TARGET_FMT_plx
" len %08x %d\n", __func__
,
3502 mmio
, base
, TARGET_PAGE_SIZE
, subpage_memory
);
3504 subpage_register(mmio
, 0, TARGET_PAGE_SIZE
-1, phys_section_unassigned
);
3509 static uint16_t dummy_section(MemoryRegion
*mr
)
3511 MemoryRegionSection section
= {
3513 .offset_within_address_space
= 0,
3514 .offset_within_region
= 0,
3518 return phys_section_add(§ion
);
3521 MemoryRegion
*iotlb_to_region(target_phys_addr_t index
)
3523 return phys_sections
[index
& ~TARGET_PAGE_MASK
].mr
;
3526 static void io_mem_init(void)
3528 memory_region_init_io(&io_mem_ram
, &error_mem_ops
, NULL
, "ram", UINT64_MAX
);
3529 memory_region_init_io(&io_mem_rom
, &rom_mem_ops
, NULL
, "rom", UINT64_MAX
);
3530 memory_region_init_io(&io_mem_unassigned
, &unassigned_mem_ops
, NULL
,
3531 "unassigned", UINT64_MAX
);
3532 memory_region_init_io(&io_mem_notdirty
, ¬dirty_mem_ops
, NULL
,
3533 "notdirty", UINT64_MAX
);
3534 memory_region_init_io(&io_mem_subpage_ram
, &subpage_ram_ops
, NULL
,
3535 "subpage-ram", UINT64_MAX
);
3536 memory_region_init_io(&io_mem_watch
, &watch_mem_ops
, NULL
,
3537 "watch", UINT64_MAX
);
3540 static void core_begin(MemoryListener
*listener
)
3542 destroy_all_mappings();
3543 phys_sections_clear();
3544 phys_map
.ptr
= PHYS_MAP_NODE_NIL
;
3545 phys_section_unassigned
= dummy_section(&io_mem_unassigned
);
3546 phys_section_notdirty
= dummy_section(&io_mem_notdirty
);
3547 phys_section_rom
= dummy_section(&io_mem_rom
);
3548 phys_section_watch
= dummy_section(&io_mem_watch
);
3551 static void core_commit(MemoryListener
*listener
)
3555 /* since each CPU stores ram addresses in its TLB cache, we must
3556 reset the modified entries */
3558 for(env
= first_cpu
; env
!= NULL
; env
= env
->next_cpu
) {
3563 static void core_region_add(MemoryListener
*listener
,
3564 MemoryRegionSection
*section
)
3566 cpu_register_physical_memory_log(section
, section
->readonly
);
3569 static void core_region_del(MemoryListener
*listener
,
3570 MemoryRegionSection
*section
)
3574 static void core_region_nop(MemoryListener
*listener
,
3575 MemoryRegionSection
*section
)
3577 cpu_register_physical_memory_log(section
, section
->readonly
);
3580 static void core_log_start(MemoryListener
*listener
,
3581 MemoryRegionSection
*section
)
3585 static void core_log_stop(MemoryListener
*listener
,
3586 MemoryRegionSection
*section
)
3590 static void core_log_sync(MemoryListener
*listener
,
3591 MemoryRegionSection
*section
)
3595 static void core_log_global_start(MemoryListener
*listener
)
3597 cpu_physical_memory_set_dirty_tracking(1);
3600 static void core_log_global_stop(MemoryListener
*listener
)
3602 cpu_physical_memory_set_dirty_tracking(0);
3605 static void core_eventfd_add(MemoryListener
*listener
,
3606 MemoryRegionSection
*section
,
3607 bool match_data
, uint64_t data
, int fd
)
3611 static void core_eventfd_del(MemoryListener
*listener
,
3612 MemoryRegionSection
*section
,
3613 bool match_data
, uint64_t data
, int fd
)
3617 static void io_begin(MemoryListener
*listener
)
3621 static void io_commit(MemoryListener
*listener
)
3625 static void io_region_add(MemoryListener
*listener
,
3626 MemoryRegionSection
*section
)
3628 MemoryRegionIORange
*mrio
= g_new(MemoryRegionIORange
, 1);
3630 mrio
->mr
= section
->mr
;
3631 mrio
->offset
= section
->offset_within_region
;
3632 iorange_init(&mrio
->iorange
, &memory_region_iorange_ops
,
3633 section
->offset_within_address_space
, section
->size
);
3634 ioport_register(&mrio
->iorange
);
3637 static void io_region_del(MemoryListener
*listener
,
3638 MemoryRegionSection
*section
)
3640 isa_unassign_ioport(section
->offset_within_address_space
, section
->size
);
3643 static void io_region_nop(MemoryListener
*listener
,
3644 MemoryRegionSection
*section
)
3648 static void io_log_start(MemoryListener
*listener
,
3649 MemoryRegionSection
*section
)
3653 static void io_log_stop(MemoryListener
*listener
,
3654 MemoryRegionSection
*section
)
3658 static void io_log_sync(MemoryListener
*listener
,
3659 MemoryRegionSection
*section
)
3663 static void io_log_global_start(MemoryListener
*listener
)
3667 static void io_log_global_stop(MemoryListener
*listener
)
3671 static void io_eventfd_add(MemoryListener
*listener
,
3672 MemoryRegionSection
*section
,
3673 bool match_data
, uint64_t data
, int fd
)
3677 static void io_eventfd_del(MemoryListener
*listener
,
3678 MemoryRegionSection
*section
,
3679 bool match_data
, uint64_t data
, int fd
)
3683 static MemoryListener core_memory_listener
= {
3684 .begin
= core_begin
,
3685 .commit
= core_commit
,
3686 .region_add
= core_region_add
,
3687 .region_del
= core_region_del
,
3688 .region_nop
= core_region_nop
,
3689 .log_start
= core_log_start
,
3690 .log_stop
= core_log_stop
,
3691 .log_sync
= core_log_sync
,
3692 .log_global_start
= core_log_global_start
,
3693 .log_global_stop
= core_log_global_stop
,
3694 .eventfd_add
= core_eventfd_add
,
3695 .eventfd_del
= core_eventfd_del
,
3699 static MemoryListener io_memory_listener
= {
3701 .commit
= io_commit
,
3702 .region_add
= io_region_add
,
3703 .region_del
= io_region_del
,
3704 .region_nop
= io_region_nop
,
3705 .log_start
= io_log_start
,
3706 .log_stop
= io_log_stop
,
3707 .log_sync
= io_log_sync
,
3708 .log_global_start
= io_log_global_start
,
3709 .log_global_stop
= io_log_global_stop
,
3710 .eventfd_add
= io_eventfd_add
,
3711 .eventfd_del
= io_eventfd_del
,
3715 static void memory_map_init(void)
3717 system_memory
= g_malloc(sizeof(*system_memory
));
3718 memory_region_init(system_memory
, "system", INT64_MAX
);
3719 set_system_memory_map(system_memory
);
3721 system_io
= g_malloc(sizeof(*system_io
));
3722 memory_region_init(system_io
, "io", 65536);
3723 set_system_io_map(system_io
);
3725 memory_listener_register(&core_memory_listener
, system_memory
);
3726 memory_listener_register(&io_memory_listener
, system_io
);
3729 MemoryRegion
*get_system_memory(void)
3731 return system_memory
;
3734 MemoryRegion
*get_system_io(void)
3739 #endif /* !defined(CONFIG_USER_ONLY) */
3741 /* physical memory access (slow version, mainly for debug) */
3742 #if defined(CONFIG_USER_ONLY)
3743 int cpu_memory_rw_debug(CPUArchState
*env
, target_ulong addr
,
3744 uint8_t *buf
, int len
, int is_write
)
3751 page
= addr
& TARGET_PAGE_MASK
;
3752 l
= (page
+ TARGET_PAGE_SIZE
) - addr
;
3755 flags
= page_get_flags(page
);
3756 if (!(flags
& PAGE_VALID
))
3759 if (!(flags
& PAGE_WRITE
))
3761 /* XXX: this code should not depend on lock_user */
3762 if (!(p
= lock_user(VERIFY_WRITE
, addr
, l
, 0)))
3765 unlock_user(p
, addr
, l
);
3767 if (!(flags
& PAGE_READ
))
3769 /* XXX: this code should not depend on lock_user */
3770 if (!(p
= lock_user(VERIFY_READ
, addr
, l
, 1)))
3773 unlock_user(p
, addr
, 0);
3783 void cpu_physical_memory_rw(target_phys_addr_t addr
, uint8_t *buf
,
3784 int len
, int is_write
)
3789 target_phys_addr_t page
;
3790 MemoryRegionSection
*section
;
3793 page
= addr
& TARGET_PAGE_MASK
;
3794 l
= (page
+ TARGET_PAGE_SIZE
) - addr
;
3797 section
= phys_page_find(page
>> TARGET_PAGE_BITS
);
3800 if (!memory_region_is_ram(section
->mr
)) {
3801 target_phys_addr_t addr1
;
3802 addr1
= section_addr(section
, addr
);
3803 /* XXX: could force cpu_single_env to NULL to avoid
3805 if (l
>= 4 && ((addr1
& 3) == 0)) {
3806 /* 32 bit write access */
3808 io_mem_write(section
->mr
, addr1
, val
, 4);
3810 } else if (l
>= 2 && ((addr1
& 1) == 0)) {
3811 /* 16 bit write access */
3813 io_mem_write(section
->mr
, addr1
, val
, 2);
3816 /* 8 bit write access */
3818 io_mem_write(section
->mr
, addr1
, val
, 1);
3821 } else if (!section
->readonly
) {
3823 addr1
= memory_region_get_ram_addr(section
->mr
)
3824 + section_addr(section
, addr
);
3826 ptr
= qemu_get_ram_ptr(addr1
);
3827 memcpy(ptr
, buf
, l
);
3828 if (!cpu_physical_memory_is_dirty(addr1
)) {
3829 /* invalidate code */
3830 tb_invalidate_phys_page_range(addr1
, addr1
+ l
, 0);
3832 cpu_physical_memory_set_dirty_flags(
3833 addr1
, (0xff & ~CODE_DIRTY_FLAG
));
3835 qemu_put_ram_ptr(ptr
);
3838 if (!is_ram_rom_romd(section
)) {
3839 target_phys_addr_t addr1
;
3841 addr1
= section_addr(section
, addr
);
3842 if (l
>= 4 && ((addr1
& 3) == 0)) {
3843 /* 32 bit read access */
3844 val
= io_mem_read(section
->mr
, addr1
, 4);
3847 } else if (l
>= 2 && ((addr1
& 1) == 0)) {
3848 /* 16 bit read access */
3849 val
= io_mem_read(section
->mr
, addr1
, 2);
3853 /* 8 bit read access */
3854 val
= io_mem_read(section
->mr
, addr1
, 1);
3860 ptr
= qemu_get_ram_ptr(section
->mr
->ram_addr
3861 + section_addr(section
, addr
));
3862 memcpy(buf
, ptr
, l
);
3863 qemu_put_ram_ptr(ptr
);
3872 /* used for ROM loading : can write in RAM and ROM */
3873 void cpu_physical_memory_write_rom(target_phys_addr_t addr
,
3874 const uint8_t *buf
, int len
)
3878 target_phys_addr_t page
;
3879 MemoryRegionSection
*section
;
3882 page
= addr
& TARGET_PAGE_MASK
;
3883 l
= (page
+ TARGET_PAGE_SIZE
) - addr
;
3886 section
= phys_page_find(page
>> TARGET_PAGE_BITS
);
3888 if (!is_ram_rom_romd(section
)) {
3891 unsigned long addr1
;
3892 addr1
= memory_region_get_ram_addr(section
->mr
)
3893 + section_addr(section
, addr
);
3895 ptr
= qemu_get_ram_ptr(addr1
);
3896 memcpy(ptr
, buf
, l
);
3897 qemu_put_ram_ptr(ptr
);
3907 target_phys_addr_t addr
;
3908 target_phys_addr_t len
;
3911 static BounceBuffer bounce
;
3913 typedef struct MapClient
{
3915 void (*callback
)(void *opaque
);
3916 QLIST_ENTRY(MapClient
) link
;
3919 static QLIST_HEAD(map_client_list
, MapClient
) map_client_list
3920 = QLIST_HEAD_INITIALIZER(map_client_list
);
3922 void *cpu_register_map_client(void *opaque
, void (*callback
)(void *opaque
))
3924 MapClient
*client
= g_malloc(sizeof(*client
));
3926 client
->opaque
= opaque
;
3927 client
->callback
= callback
;
3928 QLIST_INSERT_HEAD(&map_client_list
, client
, link
);
3932 void cpu_unregister_map_client(void *_client
)
3934 MapClient
*client
= (MapClient
*)_client
;
3936 QLIST_REMOVE(client
, link
);
3940 static void cpu_notify_map_clients(void)
3944 while (!QLIST_EMPTY(&map_client_list
)) {
3945 client
= QLIST_FIRST(&map_client_list
);
3946 client
->callback(client
->opaque
);
3947 cpu_unregister_map_client(client
);
3951 /* Map a physical memory region into a host virtual address.
3952 * May map a subset of the requested range, given by and returned in *plen.
3953 * May return NULL if resources needed to perform the mapping are exhausted.
3954 * Use only for reads OR writes - not for read-modify-write operations.
3955 * Use cpu_register_map_client() to know when retrying the map operation is
3956 * likely to succeed.
3958 void *cpu_physical_memory_map(target_phys_addr_t addr
,
3959 target_phys_addr_t
*plen
,
3962 target_phys_addr_t len
= *plen
;
3963 target_phys_addr_t todo
= 0;
3965 target_phys_addr_t page
;
3966 MemoryRegionSection
*section
;
3967 ram_addr_t raddr
= RAM_ADDR_MAX
;
3972 page
= addr
& TARGET_PAGE_MASK
;
3973 l
= (page
+ TARGET_PAGE_SIZE
) - addr
;
3976 section
= phys_page_find(page
>> TARGET_PAGE_BITS
);
3978 if (!(memory_region_is_ram(section
->mr
) && !section
->readonly
)) {
3979 if (todo
|| bounce
.buffer
) {
3982 bounce
.buffer
= qemu_memalign(TARGET_PAGE_SIZE
, TARGET_PAGE_SIZE
);
3986 cpu_physical_memory_read(addr
, bounce
.buffer
, l
);
3990 return bounce
.buffer
;
3993 raddr
= memory_region_get_ram_addr(section
->mr
)
3994 + section_addr(section
, addr
);
4002 ret
= qemu_ram_ptr_length(raddr
, &rlen
);
4007 /* Unmaps a memory region previously mapped by cpu_physical_memory_map().
4008 * Will also mark the memory as dirty if is_write == 1. access_len gives
4009 * the amount of memory that was actually read or written by the caller.
4011 void cpu_physical_memory_unmap(void *buffer
, target_phys_addr_t len
,
4012 int is_write
, target_phys_addr_t access_len
)
4014 if (buffer
!= bounce
.buffer
) {
4016 ram_addr_t addr1
= qemu_ram_addr_from_host_nofail(buffer
);
4017 while (access_len
) {
4019 l
= TARGET_PAGE_SIZE
;
4022 if (!cpu_physical_memory_is_dirty(addr1
)) {
4023 /* invalidate code */
4024 tb_invalidate_phys_page_range(addr1
, addr1
+ l
, 0);
4026 cpu_physical_memory_set_dirty_flags(
4027 addr1
, (0xff & ~CODE_DIRTY_FLAG
));
4033 if (xen_enabled()) {
4034 xen_invalidate_map_cache_entry(buffer
);
4039 cpu_physical_memory_write(bounce
.addr
, bounce
.buffer
, access_len
);
4041 qemu_vfree(bounce
.buffer
);
4042 bounce
.buffer
= NULL
;
4043 cpu_notify_map_clients();
4046 /* warning: addr must be aligned */
4047 static inline uint32_t ldl_phys_internal(target_phys_addr_t addr
,
4048 enum device_endian endian
)
4052 MemoryRegionSection
*section
;
4054 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4056 if (!is_ram_rom_romd(section
)) {
4058 addr
= section_addr(section
, addr
);
4059 val
= io_mem_read(section
->mr
, addr
, 4);
4060 #if defined(TARGET_WORDS_BIGENDIAN)
4061 if (endian
== DEVICE_LITTLE_ENDIAN
) {
4065 if (endian
== DEVICE_BIG_ENDIAN
) {
4071 ptr
= qemu_get_ram_ptr((memory_region_get_ram_addr(section
->mr
)
4073 + section_addr(section
, addr
));
4075 case DEVICE_LITTLE_ENDIAN
:
4076 val
= ldl_le_p(ptr
);
4078 case DEVICE_BIG_ENDIAN
:
4079 val
= ldl_be_p(ptr
);
4089 uint32_t ldl_phys(target_phys_addr_t addr
)
4091 return ldl_phys_internal(addr
, DEVICE_NATIVE_ENDIAN
);
4094 uint32_t ldl_le_phys(target_phys_addr_t addr
)
4096 return ldl_phys_internal(addr
, DEVICE_LITTLE_ENDIAN
);
4099 uint32_t ldl_be_phys(target_phys_addr_t addr
)
4101 return ldl_phys_internal(addr
, DEVICE_BIG_ENDIAN
);
4104 /* warning: addr must be aligned */
4105 static inline uint64_t ldq_phys_internal(target_phys_addr_t addr
,
4106 enum device_endian endian
)
4110 MemoryRegionSection
*section
;
4112 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4114 if (!is_ram_rom_romd(section
)) {
4116 addr
= section_addr(section
, addr
);
4118 /* XXX This is broken when device endian != cpu endian.
4119 Fix and add "endian" variable check */
4120 #ifdef TARGET_WORDS_BIGENDIAN
4121 val
= io_mem_read(section
->mr
, addr
, 4) << 32;
4122 val
|= io_mem_read(section
->mr
, addr
+ 4, 4);
4124 val
= io_mem_read(section
->mr
, addr
, 4);
4125 val
|= io_mem_read(section
->mr
, addr
+ 4, 4) << 32;
4129 ptr
= qemu_get_ram_ptr((memory_region_get_ram_addr(section
->mr
)
4131 + section_addr(section
, addr
));
4133 case DEVICE_LITTLE_ENDIAN
:
4134 val
= ldq_le_p(ptr
);
4136 case DEVICE_BIG_ENDIAN
:
4137 val
= ldq_be_p(ptr
);
4147 uint64_t ldq_phys(target_phys_addr_t addr
)
4149 return ldq_phys_internal(addr
, DEVICE_NATIVE_ENDIAN
);
4152 uint64_t ldq_le_phys(target_phys_addr_t addr
)
4154 return ldq_phys_internal(addr
, DEVICE_LITTLE_ENDIAN
);
4157 uint64_t ldq_be_phys(target_phys_addr_t addr
)
4159 return ldq_phys_internal(addr
, DEVICE_BIG_ENDIAN
);
4163 uint32_t ldub_phys(target_phys_addr_t addr
)
4166 cpu_physical_memory_read(addr
, &val
, 1);
4170 /* warning: addr must be aligned */
4171 static inline uint32_t lduw_phys_internal(target_phys_addr_t addr
,
4172 enum device_endian endian
)
4176 MemoryRegionSection
*section
;
4178 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4180 if (!is_ram_rom_romd(section
)) {
4182 addr
= section_addr(section
, addr
);
4183 val
= io_mem_read(section
->mr
, addr
, 2);
4184 #if defined(TARGET_WORDS_BIGENDIAN)
4185 if (endian
== DEVICE_LITTLE_ENDIAN
) {
4189 if (endian
== DEVICE_BIG_ENDIAN
) {
4195 ptr
= qemu_get_ram_ptr((memory_region_get_ram_addr(section
->mr
)
4197 + section_addr(section
, addr
));
4199 case DEVICE_LITTLE_ENDIAN
:
4200 val
= lduw_le_p(ptr
);
4202 case DEVICE_BIG_ENDIAN
:
4203 val
= lduw_be_p(ptr
);
4213 uint32_t lduw_phys(target_phys_addr_t addr
)
4215 return lduw_phys_internal(addr
, DEVICE_NATIVE_ENDIAN
);
4218 uint32_t lduw_le_phys(target_phys_addr_t addr
)
4220 return lduw_phys_internal(addr
, DEVICE_LITTLE_ENDIAN
);
4223 uint32_t lduw_be_phys(target_phys_addr_t addr
)
4225 return lduw_phys_internal(addr
, DEVICE_BIG_ENDIAN
);
4228 /* warning: addr must be aligned. The ram page is not masked as dirty
4229 and the code inside is not invalidated. It is useful if the dirty
4230 bits are used to track modified PTEs */
4231 void stl_phys_notdirty(target_phys_addr_t addr
, uint32_t val
)
4234 MemoryRegionSection
*section
;
4236 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4238 if (!memory_region_is_ram(section
->mr
) || section
->readonly
) {
4239 addr
= section_addr(section
, addr
);
4240 if (memory_region_is_ram(section
->mr
)) {
4241 section
= &phys_sections
[phys_section_rom
];
4243 io_mem_write(section
->mr
, addr
, val
, 4);
4245 unsigned long addr1
= (memory_region_get_ram_addr(section
->mr
)
4247 + section_addr(section
, addr
);
4248 ptr
= qemu_get_ram_ptr(addr1
);
4251 if (unlikely(in_migration
)) {
4252 if (!cpu_physical_memory_is_dirty(addr1
)) {
4253 /* invalidate code */
4254 tb_invalidate_phys_page_range(addr1
, addr1
+ 4, 0);
4256 cpu_physical_memory_set_dirty_flags(
4257 addr1
, (0xff & ~CODE_DIRTY_FLAG
));
4263 void stq_phys_notdirty(target_phys_addr_t addr
, uint64_t val
)
4266 MemoryRegionSection
*section
;
4268 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4270 if (!memory_region_is_ram(section
->mr
) || section
->readonly
) {
4271 addr
= section_addr(section
, addr
);
4272 if (memory_region_is_ram(section
->mr
)) {
4273 section
= &phys_sections
[phys_section_rom
];
4275 #ifdef TARGET_WORDS_BIGENDIAN
4276 io_mem_write(section
->mr
, addr
, val
>> 32, 4);
4277 io_mem_write(section
->mr
, addr
+ 4, (uint32_t)val
, 4);
4279 io_mem_write(section
->mr
, addr
, (uint32_t)val
, 4);
4280 io_mem_write(section
->mr
, addr
+ 4, val
>> 32, 4);
4283 ptr
= qemu_get_ram_ptr((memory_region_get_ram_addr(section
->mr
)
4285 + section_addr(section
, addr
));
4290 /* warning: addr must be aligned */
4291 static inline void stl_phys_internal(target_phys_addr_t addr
, uint32_t val
,
4292 enum device_endian endian
)
4295 MemoryRegionSection
*section
;
4297 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4299 if (!memory_region_is_ram(section
->mr
) || section
->readonly
) {
4300 addr
= section_addr(section
, addr
);
4301 if (memory_region_is_ram(section
->mr
)) {
4302 section
= &phys_sections
[phys_section_rom
];
4304 #if defined(TARGET_WORDS_BIGENDIAN)
4305 if (endian
== DEVICE_LITTLE_ENDIAN
) {
4309 if (endian
== DEVICE_BIG_ENDIAN
) {
4313 io_mem_write(section
->mr
, addr
, val
, 4);
4315 unsigned long addr1
;
4316 addr1
= (memory_region_get_ram_addr(section
->mr
) & TARGET_PAGE_MASK
)
4317 + section_addr(section
, addr
);
4319 ptr
= qemu_get_ram_ptr(addr1
);
4321 case DEVICE_LITTLE_ENDIAN
:
4324 case DEVICE_BIG_ENDIAN
:
4331 if (!cpu_physical_memory_is_dirty(addr1
)) {
4332 /* invalidate code */
4333 tb_invalidate_phys_page_range(addr1
, addr1
+ 4, 0);
4335 cpu_physical_memory_set_dirty_flags(addr1
,
4336 (0xff & ~CODE_DIRTY_FLAG
));
4341 void stl_phys(target_phys_addr_t addr
, uint32_t val
)
4343 stl_phys_internal(addr
, val
, DEVICE_NATIVE_ENDIAN
);
4346 void stl_le_phys(target_phys_addr_t addr
, uint32_t val
)
4348 stl_phys_internal(addr
, val
, DEVICE_LITTLE_ENDIAN
);
4351 void stl_be_phys(target_phys_addr_t addr
, uint32_t val
)
4353 stl_phys_internal(addr
, val
, DEVICE_BIG_ENDIAN
);
4357 void stb_phys(target_phys_addr_t addr
, uint32_t val
)
4360 cpu_physical_memory_write(addr
, &v
, 1);
4363 /* warning: addr must be aligned */
4364 static inline void stw_phys_internal(target_phys_addr_t addr
, uint32_t val
,
4365 enum device_endian endian
)
4368 MemoryRegionSection
*section
;
4370 section
= phys_page_find(addr
>> TARGET_PAGE_BITS
);
4372 if (!memory_region_is_ram(section
->mr
) || section
->readonly
) {
4373 addr
= section_addr(section
, addr
);
4374 if (memory_region_is_ram(section
->mr
)) {
4375 section
= &phys_sections
[phys_section_rom
];
4377 #if defined(TARGET_WORDS_BIGENDIAN)
4378 if (endian
== DEVICE_LITTLE_ENDIAN
) {
4382 if (endian
== DEVICE_BIG_ENDIAN
) {
4386 io_mem_write(section
->mr
, addr
, val
, 2);
4388 unsigned long addr1
;
4389 addr1
= (memory_region_get_ram_addr(section
->mr
) & TARGET_PAGE_MASK
)
4390 + section_addr(section
, addr
);
4392 ptr
= qemu_get_ram_ptr(addr1
);
4394 case DEVICE_LITTLE_ENDIAN
:
4397 case DEVICE_BIG_ENDIAN
:
4404 if (!cpu_physical_memory_is_dirty(addr1
)) {
4405 /* invalidate code */
4406 tb_invalidate_phys_page_range(addr1
, addr1
+ 2, 0);
4408 cpu_physical_memory_set_dirty_flags(addr1
,
4409 (0xff & ~CODE_DIRTY_FLAG
));
4414 void stw_phys(target_phys_addr_t addr
, uint32_t val
)
4416 stw_phys_internal(addr
, val
, DEVICE_NATIVE_ENDIAN
);
4419 void stw_le_phys(target_phys_addr_t addr
, uint32_t val
)
4421 stw_phys_internal(addr
, val
, DEVICE_LITTLE_ENDIAN
);
4424 void stw_be_phys(target_phys_addr_t addr
, uint32_t val
)
4426 stw_phys_internal(addr
, val
, DEVICE_BIG_ENDIAN
);
4430 void stq_phys(target_phys_addr_t addr
, uint64_t val
)
4433 cpu_physical_memory_write(addr
, &val
, 8);
4436 void stq_le_phys(target_phys_addr_t addr
, uint64_t val
)
4438 val
= cpu_to_le64(val
);
4439 cpu_physical_memory_write(addr
, &val
, 8);
4442 void stq_be_phys(target_phys_addr_t addr
, uint64_t val
)
4444 val
= cpu_to_be64(val
);
4445 cpu_physical_memory_write(addr
, &val
, 8);
4448 /* virtual memory access for debug (includes writing to ROM) */
4449 int cpu_memory_rw_debug(CPUArchState
*env
, target_ulong addr
,
4450 uint8_t *buf
, int len
, int is_write
)
4453 target_phys_addr_t phys_addr
;
4457 page
= addr
& TARGET_PAGE_MASK
;
4458 phys_addr
= cpu_get_phys_page_debug(env
, page
);
4459 /* if no physical page mapped, return an error */
4460 if (phys_addr
== -1)
4462 l
= (page
+ TARGET_PAGE_SIZE
) - addr
;
4465 phys_addr
+= (addr
& ~TARGET_PAGE_MASK
);
4467 cpu_physical_memory_write_rom(phys_addr
, buf
, l
);
4469 cpu_physical_memory_rw(phys_addr
, buf
, l
, is_write
);
4478 /* in deterministic execution mode, instructions doing device I/Os
4479 must be at the end of the TB */
4480 void cpu_io_recompile(CPUArchState
*env
, void *retaddr
)
4482 TranslationBlock
*tb
;
4484 target_ulong pc
, cs_base
;
4487 tb
= tb_find_pc((unsigned long)retaddr
);
4489 cpu_abort(env
, "cpu_io_recompile: could not find TB for pc=%p",
4492 n
= env
->icount_decr
.u16
.low
+ tb
->icount
;
4493 cpu_restore_state(tb
, env
, (unsigned long)retaddr
);
4494 /* Calculate how many instructions had been executed before the fault
4496 n
= n
- env
->icount_decr
.u16
.low
;
4497 /* Generate a new TB ending on the I/O insn. */
4499 /* On MIPS and SH, delay slot instructions can only be restarted if
4500 they were already the first instruction in the TB. If this is not
4501 the first instruction in a TB then re-execute the preceding
4503 #if defined(TARGET_MIPS)
4504 if ((env
->hflags
& MIPS_HFLAG_BMASK
) != 0 && n
> 1) {
4505 env
->active_tc
.PC
-= 4;
4506 env
->icount_decr
.u16
.low
++;
4507 env
->hflags
&= ~MIPS_HFLAG_BMASK
;
4509 #elif defined(TARGET_SH4)
4510 if ((env
->flags
& ((DELAY_SLOT
| DELAY_SLOT_CONDITIONAL
))) != 0
4513 env
->icount_decr
.u16
.low
++;
4514 env
->flags
&= ~(DELAY_SLOT
| DELAY_SLOT_CONDITIONAL
);
4517 /* This should never happen. */
4518 if (n
> CF_COUNT_MASK
)
4519 cpu_abort(env
, "TB too big during recompile");
4521 cflags
= n
| CF_LAST_IO
;
4523 cs_base
= tb
->cs_base
;
4525 tb_phys_invalidate(tb
, -1);
4526 /* FIXME: In theory this could raise an exception. In practice
4527 we have already translated the block once so it's probably ok. */
4528 tb_gen_code(env
, pc
, cs_base
, flags
, cflags
);
4529 /* TODO: If env->pc != tb->pc (i.e. the faulting instruction was not
4530 the first in the TB) then we end up generating a whole new TB and
4531 repeating the fault, which is horribly inefficient.
4532 Better would be to execute just this insn uncached, or generate a
4534 cpu_resume_from_signal(env
, NULL
);
4537 #if !defined(CONFIG_USER_ONLY)
4539 void dump_exec_info(FILE *f
, fprintf_function cpu_fprintf
)
4541 int i
, target_code_size
, max_target_code_size
;
4542 int direct_jmp_count
, direct_jmp2_count
, cross_page
;
4543 TranslationBlock
*tb
;
4545 target_code_size
= 0;
4546 max_target_code_size
= 0;
4548 direct_jmp_count
= 0;
4549 direct_jmp2_count
= 0;
4550 for(i
= 0; i
< nb_tbs
; i
++) {
4552 target_code_size
+= tb
->size
;
4553 if (tb
->size
> max_target_code_size
)
4554 max_target_code_size
= tb
->size
;
4555 if (tb
->page_addr
[1] != -1)
4557 if (tb
->tb_next_offset
[0] != 0xffff) {
4559 if (tb
->tb_next_offset
[1] != 0xffff) {
4560 direct_jmp2_count
++;
4564 /* XXX: avoid using doubles ? */
4565 cpu_fprintf(f
, "Translation buffer state:\n");
4566 cpu_fprintf(f
, "gen code size %td/%ld\n",
4567 code_gen_ptr
- code_gen_buffer
, code_gen_buffer_max_size
);
4568 cpu_fprintf(f
, "TB count %d/%d\n",
4569 nb_tbs
, code_gen_max_blocks
);
4570 cpu_fprintf(f
, "TB avg target size %d max=%d bytes\n",
4571 nb_tbs
? target_code_size
/ nb_tbs
: 0,
4572 max_target_code_size
);
4573 cpu_fprintf(f
, "TB avg host size %td bytes (expansion ratio: %0.1f)\n",
4574 nb_tbs
? (code_gen_ptr
- code_gen_buffer
) / nb_tbs
: 0,
4575 target_code_size
? (double) (code_gen_ptr
- code_gen_buffer
) / target_code_size
: 0);
4576 cpu_fprintf(f
, "cross page TB count %d (%d%%)\n",
4578 nb_tbs
? (cross_page
* 100) / nb_tbs
: 0);
4579 cpu_fprintf(f
, "direct jump count %d (%d%%) (2 jumps=%d %d%%)\n",
4581 nb_tbs
? (direct_jmp_count
* 100) / nb_tbs
: 0,
4583 nb_tbs
? (direct_jmp2_count
* 100) / nb_tbs
: 0);
4584 cpu_fprintf(f
, "\nStatistics:\n");
4585 cpu_fprintf(f
, "TB flush count %d\n", tb_flush_count
);
4586 cpu_fprintf(f
, "TB invalidate count %d\n", tb_phys_invalidate_count
);
4587 cpu_fprintf(f
, "TLB flush count %d\n", tlb_flush_count
);
4588 tcg_dump_info(f
, cpu_fprintf
);
4591 /* NOTE: this function can trigger an exception */
4592 /* NOTE2: the returned address is not exactly the physical address: it
4593 is the offset relative to phys_ram_base */
4594 tb_page_addr_t
get_page_addr_code(CPUArchState
*env1
, target_ulong addr
)
4596 int mmu_idx
, page_index
, pd
;
4600 page_index
= (addr
>> TARGET_PAGE_BITS
) & (CPU_TLB_SIZE
- 1);
4601 mmu_idx
= cpu_mmu_index(env1
);
4602 if (unlikely(env1
->tlb_table
[mmu_idx
][page_index
].addr_code
!=
4603 (addr
& TARGET_PAGE_MASK
))) {
4604 #ifdef CONFIG_TCG_PASS_AREG0
4605 cpu_ldub_code(env1
, addr
);
4610 pd
= env1
->iotlb
[mmu_idx
][page_index
] & ~TARGET_PAGE_MASK
;
4611 mr
= iotlb_to_region(pd
);
4612 if (mr
!= &io_mem_ram
&& mr
!= &io_mem_rom
4613 && mr
!= &io_mem_notdirty
&& !mr
->rom_device
4614 && mr
!= &io_mem_watch
) {
4615 #if defined(TARGET_ALPHA) || defined(TARGET_MIPS) || defined(TARGET_SPARC)
4616 cpu_unassigned_access(env1
, addr
, 0, 1, 0, 4);
4618 cpu_abort(env1
, "Trying to execute code outside RAM or ROM at 0x" TARGET_FMT_lx
"\n", addr
);
4621 p
= (void *)((uintptr_t)addr
+ env1
->tlb_table
[mmu_idx
][page_index
].addend
);
4622 return qemu_ram_addr_from_host_nofail(p
);
4626 * A helper function for the _utterly broken_ virtio device model to find out if
4627 * it's running on a big endian machine. Don't do this at home kids!
4629 bool virtio_is_big_endian(void);
4630 bool virtio_is_big_endian(void)
4632 #if defined(TARGET_WORDS_BIGENDIAN)
4639 #define MMUSUFFIX _cmmu
4641 #define GETPC() NULL
4642 #define env cpu_single_env
4643 #define SOFTMMU_CODE_ACCESS
4646 #include "softmmu_template.h"
4649 #include "softmmu_template.h"
4652 #include "softmmu_template.h"
4655 #include "softmmu_template.h"