trivial patches for 2014-09-26
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.12 (GNU/Linux) iQEcBAABAgAGBQJUJaOBAAoJEL7lnXSkw9fb0zUH/iVEASkCgiSYKhrIZsI1Lejk p+rrNe/XEv1NpU1cexTE6wl7mVMjrd35avv0pJKBRDiUx/mJSVmNJuXIK66S9dMj eXILmcpb1UnvlypbTj12aeEdkTBU0wxkRXyW536NTkI9h1gPj0lsXh3Qh0XLJgBs OueBF3e5NGZprrV1R33QTQnjD8HoxrYOIkTUoUTxVhLAuijE5FRo63kdMrl6j41A JsnlBeuYxa+QWW+N7+DTH8z2LD798nw5TpNKSuoEyZGAreV8Nhi8yKOvBBjsY8DA xPKxS+L3N7mHe4QOfb4ZaBvSLch+KCVppXoOY8/8O3n4+0wsfc4DFFFZcW//iVg= =z0Wg -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/mjt/tags/trivial-patches-2014-09-26' into staging trivial patches for 2014-09-26 # gpg: Signature made Fri 26 Sep 2014 18:33:53 BST using RSA key ID A4C3D7DB # gpg: Good signature from "Michael Tokarev <mjt@tls.msk.ru>" # gpg: aka "Michael Tokarev <mjt@corpit.ru>" # gpg: aka "Michael Tokarev <mjt@debian.org>" # gpg: WARNING: This key is not certified with a trusted signature! # gpg: There is no indication that the signature belongs to the owner. # Primary key fingerprint: 6EE1 95D1 886E 8FFB 810D 4324 457C E0A0 8044 65C5 # Subkey fingerprint: 6F67 E18E 7C91 C5B1 5514 66A7 BEE5 9D74 A4C3 D7DB * remotes/mjt/tags/trivial-patches-2014-09-26: os-posix: report error message when lock file failed os-posix: remove confused errno os-posix: change tab to space avoid violating coding style qapi: Update docs given recent event, spacing fixes qapi: Ignore files created during make check qapi: Consistent whitespace in tests/Makefile vmxcap: Update according to SDM of September 2014 .travis.yml: remove "make check" from main matrix .travis.yml: pre-seed sub-modules for speed .travis.yml: make the make slightly more parallel .travis.yml: add more linux-user to the build matrix tests: avoid running duplicate qom-tests Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
e80084d352
55
.travis.yml
55
.travis.yml
|
@ -12,7 +12,7 @@ notifications:
|
||||||
on_failure: always
|
on_failure: always
|
||||||
env:
|
env:
|
||||||
global:
|
global:
|
||||||
- TEST_CMD="make check"
|
- TEST_CMD=""
|
||||||
- EXTRA_CONFIG=""
|
- EXTRA_CONFIG=""
|
||||||
# Development packages, EXTRA_PKGS saved for additional builds
|
# Development packages, EXTRA_PKGS saved for additional builds
|
||||||
- CORE_PKGS="libusb-1.0-0-dev libiscsi-dev librados-dev libncurses5-dev"
|
- CORE_PKGS="libusb-1.0-0-dev libiscsi-dev librados-dev libncurses5-dev"
|
||||||
|
@ -20,31 +20,51 @@ env:
|
||||||
- GUI_PKGS="libgtk-3-dev libvte-2.90-dev libsdl1.2-dev libpng12-dev libpixman-1-dev"
|
- GUI_PKGS="libgtk-3-dev libvte-2.90-dev libsdl1.2-dev libpng12-dev libpixman-1-dev"
|
||||||
- EXTRA_PKGS=""
|
- EXTRA_PKGS=""
|
||||||
matrix:
|
matrix:
|
||||||
|
# Group major targets together with their linux-user counterparts
|
||||||
- TARGETS=alpha-softmmu,alpha-linux-user
|
- TARGETS=alpha-softmmu,alpha-linux-user
|
||||||
- TARGETS=arm-softmmu,arm-linux-user
|
- TARGETS=arm-softmmu,arm-linux-user,armeb-linux-user,aarch64-softmmu,aarch64-linux-user
|
||||||
- TARGETS=aarch64-softmmu,aarch64-linux-user
|
- TARGETS=cris-softmmu,cris-linux-user
|
||||||
- TARGETS=cris-softmmu
|
- TARGETS=i386-softmmu,i386-linux-user,x86_64-softmmu,x86_64-linux-user
|
||||||
- TARGETS=i386-softmmu,x86_64-softmmu
|
- TARGETS=m68k-softmmu,m68k-linux-user
|
||||||
- TARGETS=lm32-softmmu
|
- TARGETS=microblaze-softmmu,microblazeel-softmmu,microblaze-linux-user,microblazeel-linux-user
|
||||||
- TARGETS=m68k-softmmu
|
|
||||||
- TARGETS=microblaze-softmmu,microblazeel-softmmu
|
|
||||||
- TARGETS=mips-softmmu,mips64-softmmu,mips64el-softmmu,mipsel-softmmu
|
- TARGETS=mips-softmmu,mips64-softmmu,mips64el-softmmu,mipsel-softmmu
|
||||||
- TARGETS=moxie-softmmu
|
- TARGETS=mips-linux-user,mips64-linux-user,mips64el-linux-user,mipsel-linux-user,mipsn32-linux-user,mipsn32el-linux-user
|
||||||
- TARGETS=or32-softmmu,
|
- TARGETS=or32-softmmu,or32-linux-user
|
||||||
- TARGETS=ppc-softmmu,ppc64-softmmu,ppcemb-softmmu
|
- TARGETS=ppc-softmmu,ppc64-softmmu,ppcemb-softmmu,ppc-linux-user,ppc64-linux-user,ppc64abi32-linux-user,ppc64le-linux-user
|
||||||
- TARGETS=s390x-softmmu
|
- TARGETS=s390x-softmmu,s390x-linux-user
|
||||||
- TARGETS=sh4-softmmu,sh4eb-softmmu
|
- TARGETS=sh4-softmmu,sh4eb-softmmu,sh4-linux-user sh4eb-linux-user
|
||||||
- TARGETS=sparc-softmmu,sparc64-softmmu
|
- TARGETS=sparc-softmmu,sparc64-softmmu,sparc-linux-user,sparc32plus-linux-user,sparc64-linux-user
|
||||||
- TARGETS=unicore32-softmmu
|
- TARGETS=unicore32-softmmu,unicore32-linux-user
|
||||||
- TARGETS=xtensa-softmmu,xtensaeb-softmmu
|
# Group remaining softmmu only targets into one build
|
||||||
|
- TARGETS=lm32-softmmu,moxie-softmmu,tricore-softmmu,xtensa-softmmu,xtensaeb-softmmu
|
||||||
|
git:
|
||||||
|
# we want to do this ourselves
|
||||||
|
submodules: false
|
||||||
before_install:
|
before_install:
|
||||||
|
- wget -O - http://people.linaro.org/~alex.bennee/qemu-submodule-git-seed.tar.xz | tar -xvJ
|
||||||
- git submodule update --init --recursive
|
- git submodule update --init --recursive
|
||||||
- sudo apt-get update -qq
|
- sudo apt-get update -qq
|
||||||
- sudo apt-get install -qq ${CORE_PKGS} ${NET_PKGS} ${GUI_PKGS} ${EXTRA_PKGS}
|
- sudo apt-get install -qq ${CORE_PKGS} ${NET_PKGS} ${GUI_PKGS} ${EXTRA_PKGS}
|
||||||
script: "./configure --target-list=${TARGETS} ${EXTRA_CONFIG} && make && ${TEST_CMD}"
|
before_script:
|
||||||
|
- ./configure --target-list=${TARGETS} --enable-debug-tcg ${EXTRA_CONFIG}
|
||||||
|
script:
|
||||||
|
- make -j2 && ${TEST_CMD}
|
||||||
matrix:
|
matrix:
|
||||||
# We manually include a number of additional build for non-standard bits
|
# We manually include a number of additional build for non-standard bits
|
||||||
include:
|
include:
|
||||||
|
# Make check target (we only do this once)
|
||||||
|
- env:
|
||||||
|
- TARGETS=alpha-softmmu,arm-softmmu,aarch64-softmmu,cris-softmmu,
|
||||||
|
i386-softmmu,x86_64-softmmu,m68k-softmmu,microblaze-softmmu,
|
||||||
|
microblazeel-softmmu,mips-softmmu,mips64-softmmu,
|
||||||
|
mips64el-softmmu,mipsel-softmmu,or32-softmmu,ppc-softmmu,
|
||||||
|
ppc64-softmmu,ppcemb-softmmu,s390x-softmmu,sh4-softmmu,
|
||||||
|
sh4eb-softmmu,sparc-softmmu,sparc64-softmmu,
|
||||||
|
unicore32-softmmu,unicore32-linux-user,
|
||||||
|
lm32-softmmu,moxie-softmmu,tricore-softmmu,xtensa-softmmu,
|
||||||
|
xtensaeb-softmmu
|
||||||
|
TEST_CMD="make check"
|
||||||
|
compiler: gcc
|
||||||
# Debug related options
|
# Debug related options
|
||||||
- env: TARGETS=i386-softmmu,x86_64-softmmu
|
- env: TARGETS=i386-softmmu,x86_64-softmmu
|
||||||
EXTRA_CONFIG="--enable-debug"
|
EXTRA_CONFIG="--enable-debug"
|
||||||
|
@ -73,7 +93,6 @@ matrix:
|
||||||
compiler: gcc
|
compiler: gcc
|
||||||
- env: TARGETS=i386-softmmu,x86_64-softmmu
|
- env: TARGETS=i386-softmmu,x86_64-softmmu
|
||||||
EXTRA_CONFIG="--enable-trace-backends=ftrace"
|
EXTRA_CONFIG="--enable-trace-backends=ftrace"
|
||||||
TEST_CMD=""
|
|
||||||
compiler: gcc
|
compiler: gcc
|
||||||
- env: TARGETS=i386-softmmu,x86_64-softmmu
|
- env: TARGETS=i386-softmmu,x86_64-softmmu
|
||||||
EXTRA_PKGS="liblttng-ust-dev liburcu-dev"
|
EXTRA_PKGS="liblttng-ust-dev liburcu-dev"
|
||||||
|
|
|
@ -1,10 +1,5 @@
|
||||||
= How to use the QAPI code generator =
|
= How to use the QAPI code generator =
|
||||||
|
|
||||||
* Note: as of this writing, QMP does not use QAPI. Eventually QMP
|
|
||||||
commands will be converted to use QAPI internally. The following
|
|
||||||
information describes QMP/QAPI as it will exist after the
|
|
||||||
conversion.
|
|
||||||
|
|
||||||
QAPI is a native C API within QEMU which provides management-level
|
QAPI is a native C API within QEMU which provides management-level
|
||||||
functionality to internal/external users. For external
|
functionality to internal/external users. For external
|
||||||
users/processes, this interface is made available by a JSON-based
|
users/processes, this interface is made available by a JSON-based
|
||||||
|
@ -19,7 +14,7 @@ marshaling/dispatch code for the guest agent server running in the
|
||||||
guest.
|
guest.
|
||||||
|
|
||||||
This document will describe how the schemas, scripts, and resulting
|
This document will describe how the schemas, scripts, and resulting
|
||||||
code is used.
|
code are used.
|
||||||
|
|
||||||
|
|
||||||
== QMP/Guest agent schema ==
|
== QMP/Guest agent schema ==
|
||||||
|
@ -234,6 +229,7 @@ Resulting in this JSON object:
|
||||||
"data": { "b": "test string" },
|
"data": { "b": "test string" },
|
||||||
"timestamp": { "seconds": 1267020223, "microseconds": 435656 } }
|
"timestamp": { "seconds": 1267020223, "microseconds": 435656 } }
|
||||||
|
|
||||||
|
|
||||||
== Code generation ==
|
== Code generation ==
|
||||||
|
|
||||||
Schemas are fed into 3 scripts to generate all the code/files that, paired
|
Schemas are fed into 3 scripts to generate all the code/files that, paired
|
||||||
|
@ -256,6 +252,8 @@ command which takes that type as a parameter and returns the same type:
|
||||||
'data': {'arg1': 'UserDefOne'},
|
'data': {'arg1': 'UserDefOne'},
|
||||||
'returns': 'UserDefOne' }
|
'returns': 'UserDefOne' }
|
||||||
|
|
||||||
|
{ 'event': 'MY_EVENT' }
|
||||||
|
|
||||||
=== scripts/qapi-types.py ===
|
=== scripts/qapi-types.py ===
|
||||||
|
|
||||||
Used to generate the C types defined by a schema. The following files are
|
Used to generate the C types defined by a schema. The following files are
|
||||||
|
@ -277,7 +275,7 @@ Example:
|
||||||
$ cat qapi-generated/example-qapi-types.c
|
$ cat qapi-generated/example-qapi-types.c
|
||||||
[Uninteresting stuff omitted...]
|
[Uninteresting stuff omitted...]
|
||||||
|
|
||||||
void qapi_free_UserDefOneList(UserDefOneList * obj)
|
void qapi_free_UserDefOneList(UserDefOneList *obj)
|
||||||
{
|
{
|
||||||
QapiDeallocVisitor *md;
|
QapiDeallocVisitor *md;
|
||||||
Visitor *v;
|
Visitor *v;
|
||||||
|
@ -292,7 +290,7 @@ Example:
|
||||||
qapi_dealloc_visitor_cleanup(md);
|
qapi_dealloc_visitor_cleanup(md);
|
||||||
}
|
}
|
||||||
|
|
||||||
void qapi_free_UserDefOne(UserDefOne * obj)
|
void qapi_free_UserDefOne(UserDefOne *obj)
|
||||||
{
|
{
|
||||||
QapiDeallocVisitor *md;
|
QapiDeallocVisitor *md;
|
||||||
Visitor *v;
|
Visitor *v;
|
||||||
|
@ -331,11 +329,11 @@ Example:
|
||||||
struct UserDefOne
|
struct UserDefOne
|
||||||
{
|
{
|
||||||
int64_t integer;
|
int64_t integer;
|
||||||
char * string;
|
char *string;
|
||||||
};
|
};
|
||||||
|
|
||||||
void qapi_free_UserDefOneList(UserDefOneList * obj);
|
void qapi_free_UserDefOneList(UserDefOneList *obj);
|
||||||
void qapi_free_UserDefOne(UserDefOne * obj);
|
void qapi_free_UserDefOne(UserDefOne *obj);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -364,7 +362,7 @@ Example:
|
||||||
$ cat qapi-generated/example-qapi-visit.c
|
$ cat qapi-generated/example-qapi-visit.c
|
||||||
[Uninteresting stuff omitted...]
|
[Uninteresting stuff omitted...]
|
||||||
|
|
||||||
static void visit_type_UserDefOne_fields(Visitor *m, UserDefOne ** obj, Error **errp)
|
static void visit_type_UserDefOne_fields(Visitor *m, UserDefOne **obj, Error **errp)
|
||||||
{
|
{
|
||||||
Error *err = NULL;
|
Error *err = NULL;
|
||||||
visit_type_int(m, &(*obj)->integer, "integer", &err);
|
visit_type_int(m, &(*obj)->integer, "integer", &err);
|
||||||
|
@ -380,7 +378,7 @@ Example:
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
}
|
}
|
||||||
|
|
||||||
void visit_type_UserDefOne(Visitor *m, UserDefOne ** obj, const char *name, Error **errp)
|
void visit_type_UserDefOne(Visitor *m, UserDefOne **obj, const char *name, Error **errp)
|
||||||
{
|
{
|
||||||
Error *err = NULL;
|
Error *err = NULL;
|
||||||
|
|
||||||
|
@ -394,7 +392,7 @@ Example:
|
||||||
error_propagate(errp, err);
|
error_propagate(errp, err);
|
||||||
}
|
}
|
||||||
|
|
||||||
void visit_type_UserDefOneList(Visitor *m, UserDefOneList ** obj, const char *name, Error **errp)
|
void visit_type_UserDefOneList(Visitor *m, UserDefOneList **obj, const char *name, Error **errp)
|
||||||
{
|
{
|
||||||
Error *err = NULL;
|
Error *err = NULL;
|
||||||
GenericList *i, **prev;
|
GenericList *i, **prev;
|
||||||
|
@ -427,8 +425,8 @@ Example:
|
||||||
|
|
||||||
[Visitors for builtin types omitted...]
|
[Visitors for builtin types omitted...]
|
||||||
|
|
||||||
void visit_type_UserDefOne(Visitor *m, UserDefOne ** obj, const char *name, Error **errp);
|
void visit_type_UserDefOne(Visitor *m, UserDefOne **obj, const char *name, Error **errp);
|
||||||
void visit_type_UserDefOneList(Visitor *m, UserDefOneList ** obj, const char *name, Error **errp);
|
void visit_type_UserDefOneList(Visitor *m, UserDefOneList **obj, const char *name, Error **errp);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -451,10 +449,12 @@ $(prefix)qmp-commands.h: Function prototypes for the QMP commands
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
$ python scripts/qapi-commands.py --output-dir="qapi-generated"
|
||||||
|
--prefix="example-" --input-file=example-schema.json
|
||||||
$ cat qapi-generated/example-qmp-marshal.c
|
$ cat qapi-generated/example-qmp-marshal.c
|
||||||
[Uninteresting stuff omitted...]
|
[Uninteresting stuff omitted...]
|
||||||
|
|
||||||
static void qmp_marshal_output_my_command(UserDefOne * ret_in, QObject **ret_out, Error **errp)
|
static void qmp_marshal_output_my_command(UserDefOne *ret_in, QObject **ret_out, Error **errp)
|
||||||
{
|
{
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
QmpOutputVisitor *mo = qmp_output_visitor_new();
|
QmpOutputVisitor *mo = qmp_output_visitor_new();
|
||||||
|
@ -480,11 +480,11 @@ Example:
|
||||||
static void qmp_marshal_input_my_command(QDict *args, QObject **ret, Error **errp)
|
static void qmp_marshal_input_my_command(QDict *args, QObject **ret, Error **errp)
|
||||||
{
|
{
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
UserDefOne * retval = NULL;
|
UserDefOne *retval = NULL;
|
||||||
QmpInputVisitor *mi = qmp_input_visitor_new_strict(QOBJECT(args));
|
QmpInputVisitor *mi = qmp_input_visitor_new_strict(QOBJECT(args));
|
||||||
QapiDeallocVisitor *md;
|
QapiDeallocVisitor *md;
|
||||||
Visitor *v;
|
Visitor *v;
|
||||||
UserDefOne * arg1 = NULL;
|
UserDefOne *arg1 = NULL;
|
||||||
|
|
||||||
v = qmp_input_get_visitor(mi);
|
v = qmp_input_get_visitor(mi);
|
||||||
visit_type_UserDefOne(v, &arg1, "arg1", &local_err);
|
visit_type_UserDefOne(v, &arg1, "arg1", &local_err);
|
||||||
|
@ -525,6 +525,66 @@ Example:
|
||||||
#include "qapi/qmp/qdict.h"
|
#include "qapi/qmp/qdict.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
|
|
||||||
UserDefOne * qmp_my_command(UserDefOne * arg1, Error **errp);
|
UserDefOne *qmp_my_command(UserDefOne *arg1, Error **errp);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
=== scripts/qapi-event.py ===
|
||||||
|
|
||||||
|
Used to generate the event-related C code defined by a schema. The
|
||||||
|
following files are created:
|
||||||
|
|
||||||
|
$(prefix)qapi-event.h - Function prototypes for each event type, plus an
|
||||||
|
enumeration of all event names
|
||||||
|
$(prefix)qapi-event.c - Implementation of functions to send an event
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
$ python scripts/qapi-event.py --output-dir="qapi-generated"
|
||||||
|
--prefix="example-" --input-file=example-schema.json
|
||||||
|
$ cat qapi-generated/example-qapi-event.c
|
||||||
|
[Uninteresting stuff omitted...]
|
||||||
|
|
||||||
|
void qapi_event_send_my_event(Error **errp)
|
||||||
|
{
|
||||||
|
QDict *qmp;
|
||||||
|
Error *local_err = NULL;
|
||||||
|
QMPEventFuncEmit emit;
|
||||||
|
emit = qmp_event_get_func_emit();
|
||||||
|
if (!emit) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
qmp = qmp_event_build_dict("MY_EVENT");
|
||||||
|
|
||||||
|
emit(EXAMPLE_QAPI_EVENT_MY_EVENT, qmp, &local_err);
|
||||||
|
|
||||||
|
error_propagate(errp, local_err);
|
||||||
|
QDECREF(qmp);
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *EXAMPLE_QAPIEvent_lookup[] = {
|
||||||
|
"MY_EVENT",
|
||||||
|
NULL,
|
||||||
|
};
|
||||||
|
$ cat qapi-generated/example-qapi-event.h
|
||||||
|
[Uninteresting stuff omitted...]
|
||||||
|
|
||||||
|
#ifndef EXAMPLE_QAPI_EVENT_H
|
||||||
|
#define EXAMPLE_QAPI_EVENT_H
|
||||||
|
|
||||||
|
#include "qapi/error.h"
|
||||||
|
#include "qapi/qmp/qdict.h"
|
||||||
|
#include "example-qapi-types.h"
|
||||||
|
|
||||||
|
|
||||||
|
void qapi_event_send_my_event(Error **errp);
|
||||||
|
|
||||||
|
extern const char *EXAMPLE_QAPIEvent_lookup[];
|
||||||
|
typedef enum EXAMPLE_QAPIEvent
|
||||||
|
{
|
||||||
|
EXAMPLE_QAPI_EVENT_MY_EVENT = 0,
|
||||||
|
EXAMPLE_QAPI_EVENT_MAX = 1,
|
||||||
|
} EXAMPLE_QAPIEvent;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
37
os-posix.c
37
os-posix.c
|
@ -206,8 +206,9 @@ void os_daemonize(void)
|
||||||
if (daemonize) {
|
if (daemonize) {
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
|
|
||||||
if (pipe(fds) == -1)
|
if (pipe(fds) == -1) {
|
||||||
exit(1);
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
pid = fork();
|
pid = fork();
|
||||||
if (pid > 0) {
|
if (pid > 0) {
|
||||||
|
@ -218,18 +219,21 @@ void os_daemonize(void)
|
||||||
|
|
||||||
again:
|
again:
|
||||||
len = read(fds[0], &status, 1);
|
len = read(fds[0], &status, 1);
|
||||||
if (len == -1 && (errno == EINTR))
|
if (len == -1 && (errno == EINTR)) {
|
||||||
goto again;
|
goto again;
|
||||||
|
}
|
||||||
if (len != 1)
|
if (len != 1) {
|
||||||
exit(1);
|
exit(1);
|
||||||
|
}
|
||||||
else if (status == 1) {
|
else if (status == 1) {
|
||||||
fprintf(stderr, "Could not acquire pidfile: %s\n", strerror(errno));
|
fprintf(stderr, "Could not acquire pidfile\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
} else
|
} else {
|
||||||
exit(0);
|
exit(0);
|
||||||
} else if (pid < 0)
|
}
|
||||||
|
} else if (pid < 0) {
|
||||||
exit(1);
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
close(fds[0]);
|
close(fds[0]);
|
||||||
qemu_set_cloexec(fds[1]);
|
qemu_set_cloexec(fds[1]);
|
||||||
|
@ -237,11 +241,11 @@ void os_daemonize(void)
|
||||||
setsid();
|
setsid();
|
||||||
|
|
||||||
pid = fork();
|
pid = fork();
|
||||||
if (pid > 0)
|
if (pid > 0) {
|
||||||
exit(0);
|
exit(0);
|
||||||
else if (pid < 0)
|
} else if (pid < 0) {
|
||||||
exit(1);
|
exit(1);
|
||||||
|
}
|
||||||
umask(027);
|
umask(027);
|
||||||
|
|
||||||
signal(SIGTSTP, SIG_IGN);
|
signal(SIGTSTP, SIG_IGN);
|
||||||
|
@ -260,20 +264,21 @@ void os_setup_post(void)
|
||||||
|
|
||||||
again1:
|
again1:
|
||||||
len = write(fds[1], &status, 1);
|
len = write(fds[1], &status, 1);
|
||||||
if (len == -1 && (errno == EINTR))
|
if (len == -1 && (errno == EINTR)) {
|
||||||
goto again1;
|
goto again1;
|
||||||
|
}
|
||||||
if (len != 1)
|
if (len != 1) {
|
||||||
exit(1);
|
exit(1);
|
||||||
|
}
|
||||||
if (chdir("/")) {
|
if (chdir("/")) {
|
||||||
perror("not able to chdir to /");
|
perror("not able to chdir to /");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
TFR(fd = qemu_open("/dev/null", O_RDWR));
|
TFR(fd = qemu_open("/dev/null", O_RDWR));
|
||||||
if (fd == -1)
|
if (fd == -1) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
change_root();
|
change_root();
|
||||||
change_process_uid();
|
change_process_uid();
|
||||||
|
@ -314,6 +319,8 @@ int qemu_create_pidfile(const char *filename)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (lockf(fd, F_TLOCK, 0) == -1) {
|
if (lockf(fd, F_TLOCK, 0) == -1) {
|
||||||
|
fprintf(stderr, "lock file '%s' failed: %s\n",
|
||||||
|
filename, strerror(errno));
|
||||||
close(fd);
|
close(fd);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -99,7 +99,7 @@ controls = [
|
||||||
Misc(
|
Misc(
|
||||||
name = 'Basic VMX Information',
|
name = 'Basic VMX Information',
|
||||||
bits = {
|
bits = {
|
||||||
(0, 31): 'Revision',
|
(0, 30): 'Revision',
|
||||||
(32,44): 'VMCS size',
|
(32,44): 'VMCS size',
|
||||||
48: 'VMCS restricted to 32 bit addresses',
|
48: 'VMCS restricted to 32 bit addresses',
|
||||||
49: 'Dual-monitor support',
|
49: 'Dual-monitor support',
|
||||||
|
@ -169,7 +169,9 @@ controls = [
|
||||||
12: 'Enable INVPCID',
|
12: 'Enable INVPCID',
|
||||||
13: 'Enable VM functions',
|
13: 'Enable VM functions',
|
||||||
14: 'VMCS shadowing',
|
14: 'VMCS shadowing',
|
||||||
18: 'EPT-violation #VE'
|
16: 'RDSEED exiting',
|
||||||
|
18: 'EPT-violation #VE',
|
||||||
|
20: 'Enable XSAVES/XRSTORS',
|
||||||
},
|
},
|
||||||
cap_msr = MSR_IA32_VMX_PROCBASED_CTLS2,
|
cap_msr = MSR_IA32_VMX_PROCBASED_CTLS2,
|
||||||
),
|
),
|
||||||
|
@ -195,7 +197,7 @@ controls = [
|
||||||
name = 'VM-Entry controls',
|
name = 'VM-Entry controls',
|
||||||
bits = {
|
bits = {
|
||||||
2: 'Load debug controls',
|
2: 'Load debug controls',
|
||||||
9: 'IA-64 mode guest',
|
9: 'IA-32e mode guest',
|
||||||
10: 'Entry to SMM',
|
10: 'Entry to SMM',
|
||||||
11: 'Deactivate dual-monitor treatment',
|
11: 'Deactivate dual-monitor treatment',
|
||||||
13: 'Load IA32_PERF_GLOBAL_CTRL',
|
13: 'Load IA32_PERF_GLOBAL_CTRL',
|
||||||
|
@ -216,7 +218,7 @@ controls = [
|
||||||
8: 'Wait-for-SIPI activity state',
|
8: 'Wait-for-SIPI activity state',
|
||||||
15: 'IA32_SMBASE support',
|
15: 'IA32_SMBASE support',
|
||||||
(16,24): 'Number of CR3-target values',
|
(16,24): 'Number of CR3-target values',
|
||||||
(25,27): 'MSR-load/store count recommenation',
|
(25,27): 'MSR-load/store count recommendation',
|
||||||
28: 'IA32_SMM_MONITOR_CTL[2] can be set to 1',
|
28: 'IA32_SMM_MONITOR_CTL[2] can be set to 1',
|
||||||
29: 'VMWRITE to VM-exit information fields',
|
29: 'VMWRITE to VM-exit information fields',
|
||||||
(32,63): 'MSEG revision identifier',
|
(32,63): 'MSEG revision identifier',
|
||||||
|
|
|
@ -14,11 +14,14 @@ test-int128
|
||||||
test-iov
|
test-iov
|
||||||
test-mul64
|
test-mul64
|
||||||
test-opts-visitor
|
test-opts-visitor
|
||||||
|
test-qapi-event.[ch]
|
||||||
test-qapi-types.[ch]
|
test-qapi-types.[ch]
|
||||||
test-qapi-visit.[ch]
|
test-qapi-visit.[ch]
|
||||||
test-qdev-global-props
|
test-qdev-global-props
|
||||||
|
test-qemu-opts
|
||||||
test-qmp-commands
|
test-qmp-commands
|
||||||
test-qmp-commands.h
|
test-qmp-commands.h
|
||||||
|
test-qmp-event
|
||||||
test-qmp-input-strict
|
test-qmp-input-strict
|
||||||
test-qmp-input-visitor
|
test-qmp-input-visitor
|
||||||
test-qmp-marshal.c
|
test-qmp-marshal.c
|
||||||
|
|
|
@ -193,7 +193,8 @@ check-qtest-xtensaeb-y = $(check-qtest-xtensa-y)
|
||||||
|
|
||||||
# qom-test works for all sysemu architectures:
|
# qom-test works for all sysemu architectures:
|
||||||
$(foreach target,$(SYSEMU_TARGET_LIST), \
|
$(foreach target,$(SYSEMU_TARGET_LIST), \
|
||||||
$(eval check-qtest-$(target)-y += tests/qom-test$(EXESUF)))
|
$(if $(findstring tests/qom-test$(EXESUF), $(check-qtest-$(target)-y)),, \
|
||||||
|
$(eval check-qtest-$(target)-y += tests/qom-test$(EXESUF))))
|
||||||
|
|
||||||
check-qapi-schema-y := $(addprefix tests/qapi-schema/, \
|
check-qapi-schema-y := $(addprefix tests/qapi-schema/, \
|
||||||
comments.json empty.json funny-char.json indented-expr.json \
|
comments.json empty.json funny-char.json indented-expr.json \
|
||||||
|
|
Loading…
Reference in New Issue