Merge remote-tracking branch 'mjt/trivial-patches' into staging
# By Ed Maste (3) and others # Via Michael Tokarev * mjt/trivial-patches: do not check pointers after dereferencing them m25p80: Add Micron n25q032a qemu: fix out of tree cross compile slirp: cleanup leftovers from misc.h migration: Remove duplicate bandwidth_limit set docs: Fix typo and update file in migration configure: try pkg-config ncurses first rtc: remove rtc_set_date linux-user: Fix typo in comment configure: remove confusing file manipulation debugcon: fix compiler warning when open DEBUG_DEBUGCON debugcon: make debug message more readable debugcon: fix always print "addr=0x0, val=0x0" bug when use DEBUG_DEBUGCON Remove unnecessary break statements don't run pkg-config for features explicitly disabled Message-id: 51A9CCFB.1000109@msgid.tls.msk.ru Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
commit
7087d3df18
34
configure
vendored
34
configure
vendored
@ -546,7 +546,7 @@ Haiku)
|
|||||||
if [ "$cpu" = "i386" -o "$cpu" = "x86_64" ] ; then
|
if [ "$cpu" = "i386" -o "$cpu" = "x86_64" ] ; then
|
||||||
audio_possible_drivers="$audio_possible_drivers fmod"
|
audio_possible_drivers="$audio_possible_drivers fmod"
|
||||||
fi
|
fi
|
||||||
QEMU_INCLUDES="-I\$(SRC_PATH)/linux-headers $QEMU_INCLUDES"
|
QEMU_INCLUDES="-I\$(SRC_PATH)/linux-headers -I$(pwd)/linux-headers $QEMU_INCLUDES"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
@ -2153,13 +2153,12 @@ fi
|
|||||||
|
|
||||||
##########################################
|
##########################################
|
||||||
# curses probe
|
# curses probe
|
||||||
if test "$mingw32" = "yes" ; then
|
|
||||||
curses_list="-lpdcurses"
|
|
||||||
else
|
|
||||||
curses_list="-lncurses:-lcurses:$($pkg_config --libs ncurses 2>/dev/null)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$curses" != "no" ; then
|
if test "$curses" != "no" ; then
|
||||||
|
if test "$mingw32" = "yes" ; then
|
||||||
|
curses_list="-lpdcurses"
|
||||||
|
else
|
||||||
|
curses_list="$($pkg_config --libs ncurses 2>/dev/null):-lncurses:-lcurses"
|
||||||
|
fi
|
||||||
curses_found=no
|
curses_found=no
|
||||||
cat > $TMPC << EOF
|
cat > $TMPC << EOF
|
||||||
#include <curses.h>
|
#include <curses.h>
|
||||||
@ -2191,14 +2190,12 @@ fi
|
|||||||
|
|
||||||
##########################################
|
##########################################
|
||||||
# curl probe
|
# curl probe
|
||||||
|
|
||||||
if $pkg_config libcurl --modversion >/dev/null 2>&1; then
|
|
||||||
curlconfig="$pkg_config libcurl"
|
|
||||||
else
|
|
||||||
curlconfig=curl-config
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$curl" != "no" ; then
|
if test "$curl" != "no" ; then
|
||||||
|
if $pkg_config libcurl --modversion >/dev/null 2>&1; then
|
||||||
|
curlconfig="$pkg_config libcurl"
|
||||||
|
else
|
||||||
|
curlconfig=curl-config
|
||||||
|
fi
|
||||||
cat > $TMPC << EOF
|
cat > $TMPC << EOF
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
int main(void) { curl_easy_init(); curl_multi_setopt(0, 0, 0); return 0; }
|
int main(void) { curl_easy_init(); curl_multi_setopt(0, 0, 0); return 0; }
|
||||||
@ -4107,17 +4104,8 @@ if test "$gcov" = "yes" ; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# generate list of library paths for linker script
|
# generate list of library paths for linker script
|
||||||
|
|
||||||
$ld --verbose -v 2> /dev/null | grep SEARCH_DIR > ${config_host_ld}
|
$ld --verbose -v 2> /dev/null | grep SEARCH_DIR > ${config_host_ld}
|
||||||
|
|
||||||
if test -f ${config_host_ld}~ ; then
|
|
||||||
if cmp -s $config_host_ld ${config_host_ld}~ ; then
|
|
||||||
mv ${config_host_ld}~ $config_host_ld
|
|
||||||
else
|
|
||||||
rm ${config_host_ld}~
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# use included Linux headers
|
# use included Linux headers
|
||||||
if test "$linux" = "yes" ; then
|
if test "$linux" = "yes" ; then
|
||||||
mkdir -p linux-headers
|
mkdir -p linux-headers
|
||||||
|
@ -41,7 +41,7 @@ All these four migration protocols use the same infrastructure to
|
|||||||
save/restore state devices. This infrastructure is shared with the
|
save/restore state devices. This infrastructure is shared with the
|
||||||
savevm/loadvm functionality.
|
savevm/loadvm functionality.
|
||||||
|
|
||||||
=== State Live Migration ==
|
=== State Live Migration ===
|
||||||
|
|
||||||
This is used for RAM and block devices. It is not yet ported to vmstate.
|
This is used for RAM and block devices. It is not yet ported to vmstate.
|
||||||
<Fill more information here>
|
<Fill more information here>
|
||||||
@ -83,7 +83,7 @@ pointer that is passed to all functions.
|
|||||||
The important functions for us are put_buffer()/get_buffer() that
|
The important functions for us are put_buffer()/get_buffer() that
|
||||||
allow to write/read a buffer into the QEMUFile.
|
allow to write/read a buffer into the QEMUFile.
|
||||||
|
|
||||||
=== How to save the state of one device ==
|
=== How to save the state of one device ===
|
||||||
|
|
||||||
The state of a device is saved using intermediate buffers. There are
|
The state of a device is saved using intermediate buffers. There are
|
||||||
some helper functions to assist this saving.
|
some helper functions to assist this saving.
|
||||||
@ -97,7 +97,7 @@ associated with a series of fields saved. The save_state always saves
|
|||||||
the state as the newer version. But load_state sometimes is able to
|
the state as the newer version. But load_state sometimes is able to
|
||||||
load state from an older version.
|
load state from an older version.
|
||||||
|
|
||||||
=== Legacy way ===
|
=== Legacy way ===
|
||||||
|
|
||||||
This way is going to disappear as soon as all current users are ported to VMSTATE.
|
This way is going to disappear as soon as all current users are ported to VMSTATE.
|
||||||
|
|
||||||
@ -133,7 +133,7 @@ to interpret that definition to be able to load/save the state. As
|
|||||||
the state is declared only once, it can't go out of sync in the
|
the state is declared only once, it can't go out of sync in the
|
||||||
save/load functions.
|
save/load functions.
|
||||||
|
|
||||||
An example (from hw/pckbd.c)
|
An example (from hw/input/pckbd.c)
|
||||||
|
|
||||||
static const VMStateDescription vmstate_kbd = {
|
static const VMStateDescription vmstate_kbd = {
|
||||||
.name = "pckbd",
|
.name = "pckbd",
|
||||||
@ -158,9 +158,9 @@ We registered this with:
|
|||||||
Note: talk about how vmstate <-> qdev interact, and what the instance ids mean.
|
Note: talk about how vmstate <-> qdev interact, and what the instance ids mean.
|
||||||
|
|
||||||
You can search for VMSTATE_* macros for lots of types used in QEMU in
|
You can search for VMSTATE_* macros for lots of types used in QEMU in
|
||||||
hw/hw.h.
|
include/hw/hw.h.
|
||||||
|
|
||||||
=== More about versions ==
|
=== More about versions ===
|
||||||
|
|
||||||
You can see that there are several version fields:
|
You can see that there are several version fields:
|
||||||
|
|
||||||
@ -227,7 +227,7 @@ using a specific functionality, ....
|
|||||||
|
|
||||||
It is impossible to create a way to make migration from any version to
|
It is impossible to create a way to make migration from any version to
|
||||||
any other version to work. But we can do better than only allowing
|
any other version to work. But we can do better than only allowing
|
||||||
migration from older versions no newer ones. For that fields that are
|
migration from older versions to newer ones. For that fields that are
|
||||||
only needed sometimes, we add the idea of subsections. A subsection
|
only needed sometimes, we add the idea of subsections. A subsection
|
||||||
is "like" a device vmstate, but with a particularity, it has a Boolean
|
is "like" a device vmstate, but with a particularity, it has a Boolean
|
||||||
function that tells if that values are needed to be sent or not. If
|
function that tells if that values are needed to be sent or not. If
|
||||||
@ -247,7 +247,8 @@ static bool ide_drive_pio_state_needed(void *opaque)
|
|||||||
{
|
{
|
||||||
IDEState *s = opaque;
|
IDEState *s = opaque;
|
||||||
|
|
||||||
return (s->status & DRQ_STAT) != 0;
|
return ((s->status & DRQ_STAT) != 0)
|
||||||
|
|| (s->bus->error_status & BM_STATUS_PIO_RETRY);
|
||||||
}
|
}
|
||||||
|
|
||||||
const VMStateDescription vmstate_ide_drive_pio_state = {
|
const VMStateDescription vmstate_ide_drive_pio_state = {
|
||||||
|
@ -123,6 +123,7 @@ static const FlashPartInfo known_devices[] = {
|
|||||||
{ INFO("mx25l25655e", 0xc22619, 0, 64 << 10, 512, 0) },
|
{ INFO("mx25l25655e", 0xc22619, 0, 64 << 10, 512, 0) },
|
||||||
|
|
||||||
/* Micron */
|
/* Micron */
|
||||||
|
{ INFO("n25q032a", 0x20bb16, 0, 64 << 10, 64, ER_4K) },
|
||||||
{ INFO("n25q128a11", 0x20bb18, 0, 64 << 10, 256, 0) },
|
{ INFO("n25q128a11", 0x20bb18, 0, 64 << 10, 256, 0) },
|
||||||
{ INFO("n25q128a13", 0x20ba18, 0, 64 << 10, 256, 0) },
|
{ INFO("n25q128a13", 0x20ba18, 0, 64 << 10, 256, 0) },
|
||||||
{ INFO("n25q256a", 0x20ba19, 0, 64 << 10, 512, ER_4K) },
|
{ INFO("n25q256a", 0x20ba19, 0, 64 << 10, 512, ER_4K) },
|
||||||
|
@ -55,7 +55,7 @@ static void debugcon_ioport_write(void *opaque, hwaddr addr, uint64_t val,
|
|||||||
unsigned char ch = val;
|
unsigned char ch = val;
|
||||||
|
|
||||||
#ifdef DEBUG_DEBUGCON
|
#ifdef DEBUG_DEBUGCON
|
||||||
printf("debugcon: write addr=0x%04x val=0x%02x\n", addr, val);
|
printf(" [debugcon: write addr=0x%04" HWADDR_PRIx " val=0x%02" PRIx64 "]\n", addr, val);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
qemu_chr_fe_write(s->chr, &ch, 1);
|
qemu_chr_fe_write(s->chr, &ch, 1);
|
||||||
@ -67,7 +67,7 @@ static uint64_t debugcon_ioport_read(void *opaque, hwaddr addr, unsigned width)
|
|||||||
DebugconState *s = opaque;
|
DebugconState *s = opaque;
|
||||||
|
|
||||||
#ifdef DEBUG_DEBUGCON
|
#ifdef DEBUG_DEBUGCON
|
||||||
printf("debugcon: read addr=0x%04x\n", addr);
|
printf("debugcon: read addr=0x%04" HWADDR_PRIx "\n", addr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return s->readback;
|
return s->readback;
|
||||||
|
@ -2600,7 +2600,6 @@ static void cirrus_vga_ioport_write(void *opaque, hwaddr addr, uint64_t val,
|
|||||||
#endif
|
#endif
|
||||||
cirrus_vga_write_sr(c, val);
|
cirrus_vga_write_sr(c, val);
|
||||||
break;
|
break;
|
||||||
break;
|
|
||||||
case 0x3c6:
|
case 0x3c6:
|
||||||
cirrus_write_hidden_dac(c, val);
|
cirrus_write_hidden_dac(c, val);
|
||||||
break;
|
break;
|
||||||
|
@ -1030,7 +1030,6 @@ static uint64_t exynos4210_mct_read(void *opaque, hwaddr offset,
|
|||||||
case G_INT_ENB:
|
case G_INT_ENB:
|
||||||
value = s->g_timer.reg.int_enb;
|
value = s->g_timer.reg.int_enb;
|
||||||
break;
|
break;
|
||||||
break;
|
|
||||||
case G_WSTAT:
|
case G_WSTAT:
|
||||||
value = s->g_timer.reg.wstat;
|
value = s->g_timer.reg.wstat;
|
||||||
break;
|
break;
|
||||||
|
@ -9,6 +9,5 @@
|
|||||||
ISADevice *rtc_init(ISABus *bus, int base_year, qemu_irq intercept_irq);
|
ISADevice *rtc_init(ISABus *bus, int base_year, qemu_irq intercept_irq);
|
||||||
void rtc_set_memory(ISADevice *dev, int addr, int val);
|
void rtc_set_memory(ISADevice *dev, int addr, int val);
|
||||||
int rtc_get_memory(ISADevice *dev, int addr);
|
int rtc_get_memory(ISADevice *dev, int addr);
|
||||||
void rtc_set_date(ISADevice *dev, const struct tm *tm);
|
|
||||||
|
|
||||||
#endif /* !MC146818RTC_H */
|
#endif /* !MC146818RTC_H */
|
||||||
|
@ -8236,7 +8236,7 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|||||||
#ifdef TARGET_NR_madvise
|
#ifdef TARGET_NR_madvise
|
||||||
case TARGET_NR_madvise:
|
case TARGET_NR_madvise:
|
||||||
/* A straight passthrough may not be safe because qemu sometimes
|
/* A straight passthrough may not be safe because qemu sometimes
|
||||||
turns private flie-backed mappings into anonymous mappings.
|
turns private file-backed mappings into anonymous mappings.
|
||||||
This will break MADV_DONTNEED.
|
This will break MADV_DONTNEED.
|
||||||
This is a hint, so ignoring and returning success is ok. */
|
This is a hint, so ignoring and returning success is ok. */
|
||||||
ret = get_errno(0);
|
ret = get_errno(0);
|
||||||
|
@ -349,7 +349,6 @@ static MigrationState *migrate_init(const MigrationParams *params)
|
|||||||
sizeof(enabled_capabilities));
|
sizeof(enabled_capabilities));
|
||||||
|
|
||||||
memset(s, 0, sizeof(*s));
|
memset(s, 0, sizeof(*s));
|
||||||
s->bandwidth_limit = bandwidth_limit;
|
|
||||||
s->params = *params;
|
s->params = *params;
|
||||||
memcpy(s->enabled_capabilities, enabled_capabilities,
|
memcpy(s->enabled_capabilities, enabled_capabilities,
|
||||||
sizeof(enabled_capabilities));
|
sizeof(enabled_capabilities));
|
||||||
|
@ -280,7 +280,7 @@ void monitor_flush(Monitor *mon)
|
|||||||
buf = qstring_get_str(mon->outbuf);
|
buf = qstring_get_str(mon->outbuf);
|
||||||
len = qstring_get_length(mon->outbuf);
|
len = qstring_get_length(mon->outbuf);
|
||||||
|
|
||||||
if (mon && len && !mon->mux_out) {
|
if (len && !mon->mux_out) {
|
||||||
rc = qemu_chr_fe_write(mon->chr, (const uint8_t *) buf, len);
|
rc = qemu_chr_fe_write(mon->chr, (const uint8_t *) buf, len);
|
||||||
if (rc == len) {
|
if (rc == len) {
|
||||||
/* all flushed */
|
/* all flushed */
|
||||||
|
8
savevm.c
8
savevm.c
@ -322,13 +322,13 @@ QEMUFile *qemu_popen_cmd(const char *command, const char *mode)
|
|||||||
FILE *stdio_file;
|
FILE *stdio_file;
|
||||||
QEMUFileStdio *s;
|
QEMUFileStdio *s;
|
||||||
|
|
||||||
stdio_file = popen(command, mode);
|
if (mode == NULL || (mode[0] != 'r' && mode[0] != 'w') || mode[1] != 0) {
|
||||||
if (stdio_file == NULL) {
|
fprintf(stderr, "qemu_popen: Argument validity check failed\n");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mode == NULL || (mode[0] != 'r' && mode[0] != 'w') || mode[1] != 0) {
|
stdio_file = popen(command, mode);
|
||||||
fprintf(stderr, "qemu_popen: Argument validity check failed\n");
|
if (stdio_file == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
14
slirp/misc.h
14
slirp/misc.h
@ -20,8 +20,6 @@ struct ex_list {
|
|||||||
char *strdup(const char *);
|
char *strdup(const char *);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void do_wait(int);
|
|
||||||
|
|
||||||
#define EMU_NONE 0x0
|
#define EMU_NONE 0x0
|
||||||
|
|
||||||
/* TCP emulations */
|
/* TCP emulations */
|
||||||
@ -51,21 +49,9 @@ struct emu_t {
|
|||||||
struct emu_t *next;
|
struct emu_t *next;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern int x_port, x_server, x_display;
|
|
||||||
|
|
||||||
int show_x(char *, struct socket *);
|
|
||||||
void redir_x(uint32_t, int, int, int);
|
|
||||||
void slirp_insque(void *, void *);
|
void slirp_insque(void *, void *);
|
||||||
void slirp_remque(void *);
|
void slirp_remque(void *);
|
||||||
int add_exec(struct ex_list **, int, char *, struct in_addr, int);
|
int add_exec(struct ex_list **, int, char *, struct in_addr, int);
|
||||||
int slirp_openpty(int *, int *);
|
|
||||||
int fork_exec(struct socket *so, const char *ex, int do_pty);
|
int fork_exec(struct socket *so, const char *ex, int do_pty);
|
||||||
void snooze_hup(int);
|
|
||||||
void snooze(void);
|
|
||||||
void relay(int);
|
|
||||||
void add_emu(char *);
|
|
||||||
void fd_nonblock(int);
|
|
||||||
void fd_block(int);
|
|
||||||
int rsh_exec(struct socket *, struct socket *, char *, char *, char *);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -9916,7 +9916,6 @@ static inline void gen_intermediate_code_internal(CPUARMState *env,
|
|||||||
invalidate this TB. */
|
invalidate this TB. */
|
||||||
dc->pc += 2;
|
dc->pc += 2;
|
||||||
goto done_generating;
|
goto done_generating;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -515,7 +515,6 @@ uint32_t HELPER(ex)(CPUS390XState *env, uint32_t cc, uint64_t v1,
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
goto abort;
|
goto abort;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
} else if ((insn & 0xff00) == 0x0a00) {
|
} else if ((insn & 0xff00) == 0x0a00) {
|
||||||
/* supervisor call */
|
/* supervisor call */
|
||||||
|
@ -1933,7 +1933,6 @@ static inline void gen_intermediate_code_internal(CPUUniCore32State *env,
|
|||||||
invalidate this TB. */
|
invalidate this TB. */
|
||||||
dc->pc += 2; /* FIXME */
|
dc->pc += 2; /* FIXME */
|
||||||
goto done_generating;
|
goto done_generating;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user