提交 7d99a001 编写于 作者: B blueswir1

Add noreturn function attribute

Introduce noreturn attribute and attach it to cpu_loop_exit as well as
interrupt/exception helpers for i386. This avoids a bunch of gcc4
warnings.

[ Note that this patch comes with a workaround to include qemu-common.h
even in cases where is currently causes conflicts with dyngen-exec.h.
I've been told that these conflicts will get resolved in the future
(/me will try to have a look as well - as time permits). ]
Signed-off-by: NJan Kiszka <jan.kiszka@siemens.com>


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6303 c046a42c-6fe2-441c-8c8c-71466251a162
上级 fdf7ed96
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
#ifndef CPU_ALL_H #ifndef CPU_ALL_H
#define CPU_ALL_H #define CPU_ALL_H
#include "qemu-common.h"
#if defined(__arm__) || defined(__sparc__) || defined(__mips__) || defined(__hppa__) #if defined(__arm__) || defined(__sparc__) || defined(__mips__) || defined(__hppa__)
#define WORDS_ALIGNED #define WORDS_ALIGNED
#endif #endif
...@@ -751,9 +753,8 @@ void cpu_dump_statistics (CPUState *env, FILE *f, ...@@ -751,9 +753,8 @@ void cpu_dump_statistics (CPUState *env, FILE *f,
int (*cpu_fprintf)(FILE *f, const char *fmt, ...), int (*cpu_fprintf)(FILE *f, const char *fmt, ...),
int flags); int flags);
void cpu_abort(CPUState *env, const char *fmt, ...) void noreturn cpu_abort(CPUState *env, const char *fmt, ...)
__attribute__ ((__format__ (__printf__, 2, 3))) __attribute__ ((__format__ (__printf__, 2, 3)));
__attribute__ ((__noreturn__));
extern CPUState *first_cpu; extern CPUState *first_cpu;
extern CPUState *cpu_single_env; extern CPUState *cpu_single_env;
extern int64_t qemu_icount; extern int64_t qemu_icount;
......
...@@ -37,6 +37,7 @@ ...@@ -37,6 +37,7 @@
#include <signal.h> #include <signal.h>
#include "qemu.h" #include "qemu.h"
#include "qemu-common.h"
#define DEBUG_SIGNAL #define DEBUG_SIGNAL
...@@ -132,7 +133,7 @@ static inline void free_sigqueue(struct sigqueue *q) ...@@ -132,7 +133,7 @@ static inline void free_sigqueue(struct sigqueue *q)
} }
/* abort execution with signal */ /* abort execution with signal */
void __attribute((noreturn)) force_sig(int sig) void noreturn force_sig(int sig)
{ {
int host_sig; int host_sig;
host_sig = target_to_host_signal(sig); host_sig = target_to_host_signal(sig);
......
...@@ -20,6 +20,9 @@ ...@@ -20,6 +20,9 @@
#ifndef _EXEC_ALL_H_ #ifndef _EXEC_ALL_H_
#define _EXEC_ALL_H_ #define _EXEC_ALL_H_
#include "qemu-common.h"
/* allow to see translation results - the slowdown should be negligible, so we leave it */ /* allow to see translation results - the slowdown should be negligible, so we leave it */
#define DEBUG_DISAS #define DEBUG_DISAS
...@@ -82,7 +85,7 @@ TranslationBlock *tb_gen_code(CPUState *env, ...@@ -82,7 +85,7 @@ TranslationBlock *tb_gen_code(CPUState *env,
target_ulong pc, target_ulong cs_base, int flags, target_ulong pc, target_ulong cs_base, int flags,
int cflags); int cflags);
void cpu_exec_init(CPUState *env); void cpu_exec_init(CPUState *env);
void cpu_loop_exit(void); void noreturn cpu_loop_exit(void);
int page_unprotect(target_ulong address, unsigned long pc, void *puc); int page_unprotect(target_ulong address, unsigned long pc, void *puc);
void tb_invalidate_phys_page_range(target_phys_addr_t start, target_phys_addr_t end, void tb_invalidate_phys_page_range(target_phys_addr_t start, target_phys_addr_t end,
int is_cpu_write_access); int is_cpu_write_access);
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include <sys/ucontext.h> #include <sys/ucontext.h>
#include "qemu.h" #include "qemu.h"
#include "qemu-common.h"
#include "target_signal.h" #include "target_signal.h"
//#define DEBUG_SIGNAL //#define DEBUG_SIGNAL
...@@ -348,7 +349,7 @@ static inline void free_sigqueue(CPUState *env, struct sigqueue *q) ...@@ -348,7 +349,7 @@ static inline void free_sigqueue(CPUState *env, struct sigqueue *q)
} }
/* abort execution with signal */ /* abort execution with signal */
static void __attribute((noreturn)) force_sig(int sig) static void noreturn force_sig(int sig)
{ {
int host_sig; int host_sig;
host_sig = target_to_host_signal(sig); host_sig = target_to_host_signal(sig);
......
...@@ -2,6 +2,13 @@ ...@@ -2,6 +2,13 @@
#ifndef QEMU_COMMON_H #ifndef QEMU_COMMON_H
#define QEMU_COMMON_H #define QEMU_COMMON_H
#define noreturn __attribute__ ((__noreturn__))
/* Hack around the mess dyngen-exec.h causes: We need noreturn in files that
cannot include the following headers without conflicts. This condition has
to be removed once dyngen is gone. */
#ifndef __DYNGEN_EXEC_H__
/* we put basic includes here to avoid repeating them in device drivers */ /* we put basic includes here to avoid repeating them in device drivers */
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
...@@ -134,9 +141,8 @@ void *get_mmap_addr(unsigned long size); ...@@ -134,9 +141,8 @@ void *get_mmap_addr(unsigned long size);
/* Error handling. */ /* Error handling. */
void hw_error(const char *fmt, ...) void noreturn hw_error(const char *fmt, ...)
__attribute__ ((__format__ (__printf__, 1, 2))) __attribute__ ((__format__ (__printf__, 1, 2)));
__attribute__ ((__noreturn__));
/* IO callbacks. */ /* IO callbacks. */
typedef void IOReadHandler(void *opaque, const uint8_t *buf, int size); typedef void IOReadHandler(void *opaque, const uint8_t *buf, int size);
...@@ -179,4 +185,6 @@ int cpu_load(QEMUFile *f, void *opaque, int version_id); ...@@ -179,4 +185,6 @@ int cpu_load(QEMUFile *f, void *opaque, int version_id);
/* Force QEMU to stop what it's doing and service IO */ /* Force QEMU to stop what it's doing and service IO */
void qemu_service_io(void); void qemu_service_io(void);
#endif /* dyngen-exec.h hack */
#endif #endif
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
/* Default to cache=writeback as data integrity is not important for qemu-tcg. */ /* Default to cache=writeback as data integrity is not important for qemu-tcg. */
#define BRDV_O_FLAGS BDRV_O_CACHE_WB #define BRDV_O_FLAGS BDRV_O_CACHE_WB
static void __attribute__((noreturn)) error(const char *fmt, ...) static void noreturn error(const char *fmt, ...)
{ {
va_list ap; va_list ap;
va_start(ap, fmt); va_start(ap, fmt);
......
...@@ -31,6 +31,7 @@ ...@@ -31,6 +31,7 @@
register struct CPUX86State *env asm(AREG0); register struct CPUX86State *env asm(AREG0);
#include "qemu-common.h"
#include "qemu-log.h" #include "qemu-log.h"
#define EAX (env->regs[R_EAX]) #define EAX (env->regs[R_EAX])
...@@ -62,8 +63,8 @@ void do_interrupt(int intno, int is_int, int error_code, ...@@ -62,8 +63,8 @@ void do_interrupt(int intno, int is_int, int error_code,
target_ulong next_eip, int is_hw); target_ulong next_eip, int is_hw);
void do_interrupt_user(int intno, int is_int, int error_code, void do_interrupt_user(int intno, int is_int, int error_code,
target_ulong next_eip); target_ulong next_eip);
void raise_exception_err(int exception_index, int error_code); void noreturn raise_exception_err(int exception_index, int error_code);
void raise_exception(int exception_index); void noreturn raise_exception(int exception_index);
void do_smm_enter(void); void do_smm_enter(void);
/* n must be a constant to be efficient */ /* n must be a constant to be efficient */
......
...@@ -1284,8 +1284,8 @@ static int check_exception(int intno, int *error_code) ...@@ -1284,8 +1284,8 @@ static int check_exception(int intno, int *error_code)
* EIP value AFTER the interrupt instruction. It is only relevant if * EIP value AFTER the interrupt instruction. It is only relevant if
* is_int is TRUE. * is_int is TRUE.
*/ */
static void raise_interrupt(int intno, int is_int, int error_code, static void noreturn raise_interrupt(int intno, int is_int, int error_code,
int next_eip_addend) int next_eip_addend)
{ {
if (!is_int) { if (!is_int) {
helper_svm_check_intercept_param(SVM_EXIT_EXCP_BASE + intno, error_code); helper_svm_check_intercept_param(SVM_EXIT_EXCP_BASE + intno, error_code);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册