Skip to content

Commit

Permalink
Stop including qemu-common.h in memory.h
Browse files Browse the repository at this point in the history
Including qemu-common.h from other header files is generally a bad
idea, because it means it's very easy to end up with a circular
dependency. For instance, if we wanted to include memory.h from
qom/cpu.h we'd end up with this loop:
 memory.h -> qemu-common.h -> cpu.h -> cpu-qom.h -> qom/cpu.h -> memory.h

Remove the include from memory.h. This requires us to fix up a few
other files which were inadvertently getting declarations indirectly
through memory.h.

The biggest change is splitting the fprintf_function typedef out
into its own header so other headers can get at it without having
to include qemu-common.h.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Message-Id: <1435933104-15216-1-git-send-email-peter.maydell@linaro.org>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
  • Loading branch information
pm215 authored and bonzini committed Jul 6, 2015
1 parent de7ea88 commit fba0a59
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 5 deletions.
2 changes: 2 additions & 0 deletions include/exec/cpu-common.h
Expand Up @@ -13,6 +13,8 @@

#include "qemu/bswap.h"
#include "qemu/queue.h"
#include "qemu/fprintf-fn.h"
#include "qemu/typedefs.h"

/**
* CPUListState:
Expand Down
1 change: 0 additions & 1 deletion include/exec/memory.h
Expand Up @@ -23,7 +23,6 @@

#include <stdint.h>
#include <stdbool.h>
#include "qemu-common.h"
#include "exec/cpu-common.h"
#ifndef CONFIG_USER_ONLY
#include "exec/hwaddr.h"
Expand Down
1 change: 1 addition & 0 deletions include/hw/arm/arm.h
Expand Up @@ -14,6 +14,7 @@
#include "exec/memory.h"
#include "hw/irq.h"
#include "qemu/notify.h"
#include "cpu.h"

/* armv7m.c */
qemu_irq *armv7m_init(MemoryRegion *system_memory, int mem_size, int num_irq,
Expand Down
4 changes: 1 addition & 3 deletions include/qemu-common.h
Expand Up @@ -15,6 +15,7 @@
#include "qemu/compiler.h"
#include "config-host.h"
#include "qemu/typedefs.h"
#include "qemu/fprintf-fn.h"

#if defined(__arm__) || defined(__sparc__) || defined(__mips__) || defined(__hppa__) || defined(__ia64__)
#define WORDS_ALIGNED
Expand Down Expand Up @@ -85,9 +86,6 @@
# error Unknown pointer size
#endif

typedef int (*fprintf_function)(FILE *f, const char *fmt, ...)
GCC_FMT_ATTR(2, 3);

#ifdef _WIN32
#define fsync _commit
#if !defined(lseek)
Expand Down
17 changes: 17 additions & 0 deletions include/qemu/fprintf-fn.h
@@ -0,0 +1,17 @@
/*
* Typedef for fprintf-alike function pointers.
*
* This work is licensed under the terms of the GNU GPL, version 2 or later.
* See the COPYING file in the top-level directory.
*/

#ifndef QEMU_FPRINTF_FN_H
#define QEMU_FPRINTF_FN_H 1

#include "qemu/compiler.h"
#include <stdio.h>

typedef int (*fprintf_function)(FILE *f, const char *fmt, ...)
GCC_FMT_ATTR(2, 3);

#endif
2 changes: 1 addition & 1 deletion target-s390x/mmu_helper.c
Expand Up @@ -17,8 +17,8 @@

#include "qemu/error-report.h"
#include "exec/address-spaces.h"
#include "sysemu/kvm.h"
#include "cpu.h"
#include "sysemu/kvm.h"

/* #define DEBUG_S390 */
/* #define DEBUG_S390_PTE */
Expand Down

0 comments on commit fba0a59

Please sign in to comment.