* Bugfixes
* Code of conduct and conflict resolution policy -----BEGIN PGP SIGNATURE----- iQFIBAABCAAyFiEE8TM4V0tmI4mGbHaCv/vSX3jHroMFAmBlrKYUHHBib256aW5p QHJlZGhhdC5jb20ACgkQv/vSX3jHroPRzQgAon5iI9jdGTgdJHow2ajn0rCxDEgp G97a+hXYtKOnp2bhq5XxlQNW8Tw6fKolfA/ISnOMCix1hQe6eqNxCevwdAdKJgSg UkV2c08CR3dR28olqSPDzTQd6COpqKfL9V9dApLn8FtbyPbIX0IlvS/mQaHbtvvK lAe+fRqn+UZe4xTiE4FTGUD35PmtgYW5TzX1QWF6R6S6BCfJ07s7S/L99zP8d1UU fQQzaKTIOtVWv5765oxU0R1LpRtPxfBqlxDFVbzx9B0s+Grp4wyn7h2gplkwK2Rs YXElsRjARlSW3VfASaX+yjCxX4hQ9HjFvi0iH5vYHprX6lnm/27gSjNFxQ== =P9vW -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/bonzini-gitlab/tags/for-upstream' into staging * Bugfixes * Code of conduct and conflict resolution policy # gpg: Signature made Thu 01 Apr 2021 12:21:10 BST # gpg: using RSA key F13338574B662389866C7682BFFBD25F78C7AE83 # gpg: issuer "pbonzini@redhat.com" # gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" [full] # gpg: aka "Paolo Bonzini <pbonzini@redhat.com>" [full] # Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4 E2F7 7E15 100C CD36 69B1 # Subkey fingerprint: F133 3857 4B66 2389 866C 7682 BFFB D25F 78C7 AE83 * remotes/bonzini-gitlab/tags/for-upstream: docs: Add a QEMU Code of Conduct and Conflict Resolution Policy document hexagon: do not specify Python scripts as inputs hexagon: do not specify executables as inputs configure: Do not use default_feature for EXESUF target/openrisc: fix icount handling for timer instructions replay: notify CPU on event icount: get rid of static variable Revert "qom: use qemu_printf to print help for user-creatable objects" replay: fix recursive checkpoints qapi: qom: do not use target-specific conditionals target/i386: Verify memory operand for lcall and ljmp meson: Propagate gnutls dependency to migration Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
00084bab87
|
@ -365,7 +365,7 @@ tcg_interpreter="false"
|
||||||
bigendian="no"
|
bigendian="no"
|
||||||
mingw32="no"
|
mingw32="no"
|
||||||
gcov="no"
|
gcov="no"
|
||||||
EXESUF="$default_feature"
|
EXESUF=""
|
||||||
HOST_DSOSUF=".so"
|
HOST_DSOSUF=".so"
|
||||||
modules="no"
|
modules="no"
|
||||||
module_upgrades="no"
|
module_upgrades="no"
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
Code of Conduct
|
||||||
|
===============
|
||||||
|
|
||||||
|
The QEMU community is made up of a mixture of professionals and
|
||||||
|
volunteers from all over the world. Diversity is one of our strengths,
|
||||||
|
but it can also lead to communication issues and unhappiness.
|
||||||
|
To that end, we have a few ground rules that we ask people to adhere to.
|
||||||
|
|
||||||
|
* Be welcoming. We are committed to making participation in this project
|
||||||
|
a harassment-free experience for everyone, regardless of level of
|
||||||
|
experience, gender, gender identity and expression, sexual orientation,
|
||||||
|
disability, personal appearance, body size, race, ethnicity, age, religion,
|
||||||
|
or nationality.
|
||||||
|
|
||||||
|
* Be respectful. Not all of us will agree all the time. Disagreements, both
|
||||||
|
social and technical, happen all the time and the QEMU community is no
|
||||||
|
exception. When we disagree, we try to understand why. It is important that
|
||||||
|
we resolve disagreements and differing views constructively. Members of the
|
||||||
|
QEMU community should be respectful when dealing with other contributors as
|
||||||
|
well as with people outside the QEMU community and with users of QEMU.
|
||||||
|
|
||||||
|
Harassment and other exclusionary behavior are not acceptable. A community
|
||||||
|
where people feel uncomfortable or threatened is neither welcoming nor
|
||||||
|
respectful. Examples of unacceptable behavior by participants include:
|
||||||
|
|
||||||
|
* The use of sexualized language or imagery
|
||||||
|
|
||||||
|
* Personal attacks
|
||||||
|
|
||||||
|
* Trolling or insulting/derogatory comments
|
||||||
|
|
||||||
|
* Public or private harassment
|
||||||
|
|
||||||
|
* Publishing other's private information, such as physical or electronic
|
||||||
|
addresses, without explicit permission
|
||||||
|
|
||||||
|
This isn't an exhaustive list of things that you can't do. Rather, take
|
||||||
|
it in the spirit in which it's intended: a guide to make it easier to
|
||||||
|
be excellent to each other.
|
||||||
|
|
||||||
|
This code of conduct applies to all spaces managed by the QEMU project.
|
||||||
|
This includes IRC, the mailing lists, the issue tracker, community
|
||||||
|
events, and any other forums created by the project team which the
|
||||||
|
community uses for communication. This code of conduct also applies
|
||||||
|
outside these spaces, when an individual acts as a representative or a
|
||||||
|
member of the project or its community.
|
||||||
|
|
||||||
|
By adopting this code of conduct, project maintainers commit themselves
|
||||||
|
to fairly and consistently applying these principles to every aspect of
|
||||||
|
managing this project. If you believe someone is violating the code of
|
||||||
|
conduct, please read the :ref:`conflict-resolution` document for
|
||||||
|
information about how to proceed.
|
||||||
|
|
||||||
|
Sources
|
||||||
|
-------
|
||||||
|
|
||||||
|
This document is based on the `Fedora Code of Conduct
|
||||||
|
<https://fedoraproject.org/code-of-conduct>`__ and the
|
||||||
|
`Contributor Covenant version 1.3.0
|
||||||
|
<https://www.contributor-covenant.org/version/1/3/0/code-of-conduct/>`__.
|
|
@ -0,0 +1,80 @@
|
||||||
|
.. _conflict-resolution:
|
||||||
|
|
||||||
|
Conflict Resolution Policy
|
||||||
|
==========================
|
||||||
|
|
||||||
|
Conflicts in the community can take many forms, from someone having a
|
||||||
|
bad day and using harsh and hurtful language on the mailing list to more
|
||||||
|
serious code of conduct violations (including sexist/racist statements
|
||||||
|
or threats of violence), and everything in between.
|
||||||
|
|
||||||
|
For the vast majority of issues, we aim to empower individuals to first
|
||||||
|
resolve conflicts themselves, asking for help when needed, and only
|
||||||
|
after that fails to escalate further. This approach gives people more
|
||||||
|
control over the outcome of their dispute.
|
||||||
|
|
||||||
|
How we resolve conflicts
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
If you are experiencing conflict, please consider first addressing the
|
||||||
|
perceived conflict directly with other involved parties, preferably through
|
||||||
|
a real-time medium such as IRC. You could also try to get a third-party (e.g.
|
||||||
|
a mutual friend, and/or someone with background on the issue, but not
|
||||||
|
involved in the conflict) to intercede or mediate.
|
||||||
|
|
||||||
|
If this fails or if you do not feel comfortable proceeding this way, or
|
||||||
|
if the problem requires immediate escalation, report the issue to the QEMU
|
||||||
|
leadership committee by sending an email to qemu@sfconservancy.org, providing
|
||||||
|
references to the misconduct.
|
||||||
|
For very urgent topics, you can also inform one or more members through IRC.
|
||||||
|
The up-to-date list of members is `available on the QEMU wiki
|
||||||
|
<https://wiki.qemu.org/Conservancy>`__.
|
||||||
|
|
||||||
|
Your report will be treated confidentially by the leadership committee and
|
||||||
|
not be published without your agreement. The QEMU leadership committee will
|
||||||
|
then do its best to review the incident in a timely manner, and will either
|
||||||
|
seek further information, or will make a determination on next steps.
|
||||||
|
|
||||||
|
Remedies
|
||||||
|
--------
|
||||||
|
|
||||||
|
Escalating an issue to the QEMU leadership committee may result in actions
|
||||||
|
impacting one or more involved parties. In the event the leadership
|
||||||
|
committee has to intervene, here are some of the ways they might respond:
|
||||||
|
|
||||||
|
1. Take no action. For example, if the leadership committee determines
|
||||||
|
the complaint has not been substantiated or is being made in bad faith,
|
||||||
|
or if it is deemed to be outside its purview.
|
||||||
|
|
||||||
|
2. A private reprimand, explaining the consequences of continued behavior,
|
||||||
|
to one or more involved individuals.
|
||||||
|
|
||||||
|
3. A private reprimand and request for a private or public apology
|
||||||
|
|
||||||
|
4. A public reprimand and request for a public apology
|
||||||
|
|
||||||
|
5. A public reprimand plus a mandatory cooling off period. The cooling
|
||||||
|
off period may require, for example, one or more of the following:
|
||||||
|
abstaining from maintainer duties; not interacting with people involved,
|
||||||
|
including unsolicited interaction with those enforcing the guidelines
|
||||||
|
and interaction on social media; being denied participation to in-person
|
||||||
|
events. The cooling off period is voluntary but may escalate to a
|
||||||
|
temporary ban in order to enforce it.
|
||||||
|
|
||||||
|
6. A temporary or permanent ban from some or all current and future QEMU
|
||||||
|
spaces (mailing lists, IRC, wiki, etc.), possibly including in-person
|
||||||
|
events.
|
||||||
|
|
||||||
|
In the event of severe harassment, the leadership committee may advise that
|
||||||
|
the matter be escalated to the relevant local law enforcement agency. It
|
||||||
|
is however not the role of the leadership committee to initiate contact
|
||||||
|
with law enforcement on behalf of any of the community members involved
|
||||||
|
in an incident.
|
||||||
|
|
||||||
|
Sources
|
||||||
|
-------
|
||||||
|
|
||||||
|
This document was developed based on the `Drupal Conflict Resolution
|
||||||
|
Policy and Process <https://www.drupal.org/conflict-resolution>`__
|
||||||
|
and the `Mozilla Consequence Ladder
|
||||||
|
<https://github.com/mozilla/diversity/blob/master/code-of-conduct-enforcement/consequence-ladder.md>`__
|
|
@ -14,6 +14,8 @@ Contents:
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
:includehidden:
|
:includehidden:
|
||||||
|
|
||||||
|
code-of-conduct
|
||||||
|
conflict-resolution
|
||||||
build-system
|
build-system
|
||||||
style
|
style
|
||||||
kconfig
|
kconfig
|
||||||
|
|
|
@ -24,7 +24,7 @@ softmmu_ss.add(files(
|
||||||
'savevm.c',
|
'savevm.c',
|
||||||
'socket.c',
|
'socket.c',
|
||||||
'tls.c',
|
'tls.c',
|
||||||
))
|
), gnutls)
|
||||||
|
|
||||||
softmmu_ss.add(when: ['CONFIG_RDMA', rdma], if_true: files('rdma.c'))
|
softmmu_ss.add(when: ['CONFIG_RDMA', rdma], if_true: files('rdma.c'))
|
||||||
softmmu_ss.add(when: 'CONFIG_LIVE_BLOCK_MIGRATION', if_true: files('block.c'))
|
softmmu_ss.add(when: 'CONFIG_LIVE_BLOCK_MIGRATION', if_true: files('block.c'))
|
||||||
|
|
|
@ -733,8 +733,7 @@
|
||||||
'*policy': 'uint32',
|
'*policy': 'uint32',
|
||||||
'*handle': 'uint32',
|
'*handle': 'uint32',
|
||||||
'*cbitpos': 'uint32',
|
'*cbitpos': 'uint32',
|
||||||
'reduced-phys-bits': 'uint32' },
|
'reduced-phys-bits': 'uint32' } }
|
||||||
'if': 'defined(CONFIG_SEV)' }
|
|
||||||
|
|
||||||
##
|
##
|
||||||
# @ObjectType:
|
# @ObjectType:
|
||||||
|
@ -768,14 +767,14 @@
|
||||||
{ 'name': 'memory-backend-memfd',
|
{ 'name': 'memory-backend-memfd',
|
||||||
'if': 'defined(CONFIG_LINUX)' },
|
'if': 'defined(CONFIG_LINUX)' },
|
||||||
'memory-backend-ram',
|
'memory-backend-ram',
|
||||||
{'name': 'pef-guest', 'if': 'defined(CONFIG_PSERIES)' },
|
'pef-guest',
|
||||||
'pr-manager-helper',
|
'pr-manager-helper',
|
||||||
'rng-builtin',
|
'rng-builtin',
|
||||||
'rng-egd',
|
'rng-egd',
|
||||||
'rng-random',
|
'rng-random',
|
||||||
'secret',
|
'secret',
|
||||||
'secret_keyring',
|
'secret_keyring',
|
||||||
{'name': 'sev-guest', 'if': 'defined(CONFIG_SEV)' },
|
'sev-guest',
|
||||||
's390-pv-guest',
|
's390-pv-guest',
|
||||||
'throttle-group',
|
'throttle-group',
|
||||||
'tls-creds-anon',
|
'tls-creds-anon',
|
||||||
|
@ -831,8 +830,7 @@
|
||||||
'rng-random': 'RngRandomProperties',
|
'rng-random': 'RngRandomProperties',
|
||||||
'secret': 'SecretProperties',
|
'secret': 'SecretProperties',
|
||||||
'secret_keyring': 'SecretKeyringProperties',
|
'secret_keyring': 'SecretKeyringProperties',
|
||||||
'sev-guest': { 'type': 'SevGuestProperties',
|
'sev-guest': 'SevGuestProperties',
|
||||||
'if': 'defined(CONFIG_SEV)' },
|
|
||||||
'throttle-group': 'ThrottleGroupProperties',
|
'throttle-group': 'ThrottleGroupProperties',
|
||||||
'tls-creds-anon': 'TlsCredsAnonProperties',
|
'tls-creds-anon': 'TlsCredsAnonProperties',
|
||||||
'tls-creds-psk': 'TlsCredsPskProperties',
|
'tls-creds-psk': 'TlsCredsPskProperties',
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
#include "qemu/qemu-print.h"
|
#include "qemu/qemu-print.h"
|
||||||
#include "qapi/opts-visitor.h"
|
#include "qapi/opts-visitor.h"
|
||||||
#include "qemu/config-file.h"
|
#include "qemu/config-file.h"
|
||||||
#include "qemu/qemu-print.h"
|
|
||||||
|
|
||||||
bool user_creatable_complete(UserCreatable *uc, Error **errp)
|
bool user_creatable_complete(UserCreatable *uc, Error **errp)
|
||||||
{
|
{
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include "replay-internal.h"
|
#include "replay-internal.h"
|
||||||
#include "block/aio.h"
|
#include "block/aio.h"
|
||||||
#include "ui/input.h"
|
#include "ui/input.h"
|
||||||
|
#include "hw/core/cpu.h"
|
||||||
|
|
||||||
typedef struct Event {
|
typedef struct Event {
|
||||||
ReplayAsyncEventKind event_kind;
|
ReplayAsyncEventKind event_kind;
|
||||||
|
@ -126,6 +127,7 @@ void replay_add_event(ReplayAsyncEventKind event_kind,
|
||||||
|
|
||||||
g_assert(replay_mutex_locked());
|
g_assert(replay_mutex_locked());
|
||||||
QTAILQ_INSERT_TAIL(&events_list, event, events);
|
QTAILQ_INSERT_TAIL(&events_list, event, events);
|
||||||
|
qemu_cpu_kick(first_cpu);
|
||||||
}
|
}
|
||||||
|
|
||||||
void replay_bh_schedule_event(QEMUBH *bh)
|
void replay_bh_schedule_event(QEMUBH *bh)
|
||||||
|
|
|
@ -180,12 +180,13 @@ bool replay_checkpoint(ReplayCheckpoint checkpoint)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (in_checkpoint) {
|
if (in_checkpoint) {
|
||||||
/* If we are already in checkpoint, then there is no need
|
/*
|
||||||
for additional synchronization.
|
|
||||||
Recursion occurs when HW event modifies timers.
|
Recursion occurs when HW event modifies timers.
|
||||||
Timer modification may invoke the checkpoint and
|
Prevent performing icount warp in this case and
|
||||||
proceed to recursion. */
|
wait for another invocation of the checkpoint.
|
||||||
return true;
|
*/
|
||||||
|
g_assert(replay_mode == REPLAY_MODE_PLAY);
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
in_checkpoint = true;
|
in_checkpoint = true;
|
||||||
|
|
||||||
|
|
|
@ -188,11 +188,12 @@ static const VMStateDescription icount_vmstate_adjust_timers = {
|
||||||
|
|
||||||
static const VMStateDescription icount_vmstate_shift = {
|
static const VMStateDescription icount_vmstate_shift = {
|
||||||
.name = "timer/icount/shift",
|
.name = "timer/icount/shift",
|
||||||
.version_id = 1,
|
.version_id = 2,
|
||||||
.minimum_version_id = 1,
|
.minimum_version_id = 2,
|
||||||
.needed = icount_shift_state_needed,
|
.needed = icount_shift_state_needed,
|
||||||
.fields = (VMStateField[]) {
|
.fields = (VMStateField[]) {
|
||||||
VMSTATE_INT16(icount_time_shift, TimersState),
|
VMSTATE_INT16(icount_time_shift, TimersState),
|
||||||
|
VMSTATE_INT64(last_delta, TimersState),
|
||||||
VMSTATE_END_OF_LIST()
|
VMSTATE_END_OF_LIST()
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -176,9 +176,6 @@ static void icount_adjust(void)
|
||||||
int64_t cur_icount;
|
int64_t cur_icount;
|
||||||
int64_t delta;
|
int64_t delta;
|
||||||
|
|
||||||
/* Protected by TimersState mutex. */
|
|
||||||
static int64_t last_delta;
|
|
||||||
|
|
||||||
/* If the VM is not running, then do nothing. */
|
/* If the VM is not running, then do nothing. */
|
||||||
if (!runstate_is_running()) {
|
if (!runstate_is_running()) {
|
||||||
return;
|
return;
|
||||||
|
@ -193,20 +190,20 @@ static void icount_adjust(void)
|
||||||
delta = cur_icount - cur_time;
|
delta = cur_icount - cur_time;
|
||||||
/* FIXME: This is a very crude algorithm, somewhat prone to oscillation. */
|
/* FIXME: This is a very crude algorithm, somewhat prone to oscillation. */
|
||||||
if (delta > 0
|
if (delta > 0
|
||||||
&& last_delta + ICOUNT_WOBBLE < delta * 2
|
&& timers_state.last_delta + ICOUNT_WOBBLE < delta * 2
|
||||||
&& timers_state.icount_time_shift > 0) {
|
&& timers_state.icount_time_shift > 0) {
|
||||||
/* The guest is getting too far ahead. Slow time down. */
|
/* The guest is getting too far ahead. Slow time down. */
|
||||||
qatomic_set(&timers_state.icount_time_shift,
|
qatomic_set(&timers_state.icount_time_shift,
|
||||||
timers_state.icount_time_shift - 1);
|
timers_state.icount_time_shift - 1);
|
||||||
}
|
}
|
||||||
if (delta < 0
|
if (delta < 0
|
||||||
&& last_delta - ICOUNT_WOBBLE > delta * 2
|
&& timers_state.last_delta - ICOUNT_WOBBLE > delta * 2
|
||||||
&& timers_state.icount_time_shift < MAX_ICOUNT_SHIFT) {
|
&& timers_state.icount_time_shift < MAX_ICOUNT_SHIFT) {
|
||||||
/* The guest is getting too far behind. Speed time up. */
|
/* The guest is getting too far behind. Speed time up. */
|
||||||
qatomic_set(&timers_state.icount_time_shift,
|
qatomic_set(&timers_state.icount_time_shift,
|
||||||
timers_state.icount_time_shift + 1);
|
timers_state.icount_time_shift + 1);
|
||||||
}
|
}
|
||||||
last_delta = delta;
|
timers_state.last_delta = delta;
|
||||||
qatomic_set_i64(&timers_state.qemu_icount_bias,
|
qatomic_set_i64(&timers_state.qemu_icount_bias,
|
||||||
cur_icount - (timers_state.qemu_icount
|
cur_icount - (timers_state.qemu_icount
|
||||||
<< timers_state.icount_time_shift));
|
<< timers_state.icount_time_shift));
|
||||||
|
|
|
@ -43,6 +43,8 @@ typedef struct TimersState {
|
||||||
|
|
||||||
/* Conversion factor from emulated instructions to virtual clock ticks. */
|
/* Conversion factor from emulated instructions to virtual clock ticks. */
|
||||||
int16_t icount_time_shift;
|
int16_t icount_time_shift;
|
||||||
|
/* Icount delta used for shift auto adjust. */
|
||||||
|
int64_t last_delta;
|
||||||
|
|
||||||
/* Compensate for varying guest execution speed. */
|
/* Compensate for varying guest execution speed. */
|
||||||
int64_t qemu_icount_bias;
|
int64_t qemu_icount_bias;
|
||||||
|
|
|
@ -33,8 +33,7 @@ gen_semantics = executable(
|
||||||
semantics_generated = custom_target(
|
semantics_generated = custom_target(
|
||||||
'semantics_generated.pyinc',
|
'semantics_generated.pyinc',
|
||||||
output: 'semantics_generated.pyinc',
|
output: 'semantics_generated.pyinc',
|
||||||
input: gen_semantics,
|
command: [gen_semantics, '@OUTPUT@'],
|
||||||
command: ['@INPUT@', '@OUTPUT@'],
|
|
||||||
)
|
)
|
||||||
hexagon_ss.add(semantics_generated)
|
hexagon_ss.add(semantics_generated)
|
||||||
|
|
||||||
|
@ -54,90 +53,81 @@ hexagon_ss.add(semantics_generated)
|
||||||
shortcode_generated = custom_target(
|
shortcode_generated = custom_target(
|
||||||
'shortcode_generated.h.inc',
|
'shortcode_generated.h.inc',
|
||||||
output: 'shortcode_generated.h.inc',
|
output: 'shortcode_generated.h.inc',
|
||||||
input: 'gen_shortcode.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def],
|
depend_files: [hex_common_py, attribs_def],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, '@OUTPUT@'],
|
command: [python, files('gen_shortcode.py'), semantics_generated, attribs_def, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(shortcode_generated)
|
hexagon_ss.add(shortcode_generated)
|
||||||
|
|
||||||
helper_protos_generated = custom_target(
|
helper_protos_generated = custom_target(
|
||||||
'helper_protos_generated.h.inc',
|
'helper_protos_generated.h.inc',
|
||||||
output: 'helper_protos_generated.h.inc',
|
output: 'helper_protos_generated.h.inc',
|
||||||
input: 'gen_helper_protos.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def, gen_tcg_h],
|
depend_files: [hex_common_py, attribs_def, gen_tcg_h],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, gen_tcg_h, '@OUTPUT@'],
|
command: [python, files('gen_helper_protos.py'), semantics_generated, attribs_def, gen_tcg_h, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(helper_protos_generated)
|
hexagon_ss.add(helper_protos_generated)
|
||||||
|
|
||||||
tcg_funcs_generated = custom_target(
|
tcg_funcs_generated = custom_target(
|
||||||
'tcg_funcs_generated.c.inc',
|
'tcg_funcs_generated.c.inc',
|
||||||
output: 'tcg_funcs_generated.c.inc',
|
output: 'tcg_funcs_generated.c.inc',
|
||||||
input: 'gen_tcg_funcs.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def, gen_tcg_h],
|
depend_files: [hex_common_py, attribs_def, gen_tcg_h],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, gen_tcg_h, '@OUTPUT@'],
|
command: [python, files('gen_tcg_funcs.py'), semantics_generated, attribs_def, gen_tcg_h, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(tcg_funcs_generated)
|
hexagon_ss.add(tcg_funcs_generated)
|
||||||
|
|
||||||
tcg_func_table_generated = custom_target(
|
tcg_func_table_generated = custom_target(
|
||||||
'tcg_func_table_generated.c.inc',
|
'tcg_func_table_generated.c.inc',
|
||||||
output: 'tcg_func_table_generated.c.inc',
|
output: 'tcg_func_table_generated.c.inc',
|
||||||
input: 'gen_tcg_func_table.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def],
|
depend_files: [hex_common_py, attribs_def],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, '@OUTPUT@'],
|
command: [python, files('gen_tcg_func_table.py'), semantics_generated, attribs_def, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(tcg_func_table_generated)
|
hexagon_ss.add(tcg_func_table_generated)
|
||||||
|
|
||||||
helper_funcs_generated = custom_target(
|
helper_funcs_generated = custom_target(
|
||||||
'helper_funcs_generated.c.inc',
|
'helper_funcs_generated.c.inc',
|
||||||
output: 'helper_funcs_generated.c.inc',
|
output: 'helper_funcs_generated.c.inc',
|
||||||
input: 'gen_helper_funcs.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def, gen_tcg_h],
|
depend_files: [hex_common_py, attribs_def, gen_tcg_h],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, gen_tcg_h, '@OUTPUT@'],
|
command: [python, files('gen_helper_funcs.py'), semantics_generated, attribs_def, gen_tcg_h, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(helper_funcs_generated)
|
hexagon_ss.add(helper_funcs_generated)
|
||||||
|
|
||||||
printinsn_generated = custom_target(
|
printinsn_generated = custom_target(
|
||||||
'printinsn_generated.h.inc',
|
'printinsn_generated.h.inc',
|
||||||
output: 'printinsn_generated.h.inc',
|
output: 'printinsn_generated.h.inc',
|
||||||
input: 'gen_printinsn.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def],
|
depend_files: [hex_common_py, attribs_def],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, '@OUTPUT@'],
|
command: [python, files('gen_printinsn.py'), semantics_generated, attribs_def, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(printinsn_generated)
|
hexagon_ss.add(printinsn_generated)
|
||||||
|
|
||||||
op_regs_generated = custom_target(
|
op_regs_generated = custom_target(
|
||||||
'op_regs_generated.h.inc',
|
'op_regs_generated.h.inc',
|
||||||
output: 'op_regs_generated.h.inc',
|
output: 'op_regs_generated.h.inc',
|
||||||
input: 'gen_op_regs.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def],
|
depend_files: [hex_common_py, attribs_def],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, '@OUTPUT@'],
|
command: [python, files('gen_op_regs.py'), semantics_generated, attribs_def, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(op_regs_generated)
|
hexagon_ss.add(op_regs_generated)
|
||||||
|
|
||||||
op_attribs_generated = custom_target(
|
op_attribs_generated = custom_target(
|
||||||
'op_attribs_generated.h.inc',
|
'op_attribs_generated.h.inc',
|
||||||
output: 'op_attribs_generated.h.inc',
|
output: 'op_attribs_generated.h.inc',
|
||||||
input: 'gen_op_attribs.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def],
|
depend_files: [hex_common_py, attribs_def],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, '@OUTPUT@'],
|
command: [python, files('gen_op_attribs.py'), semantics_generated, attribs_def, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(op_attribs_generated)
|
hexagon_ss.add(op_attribs_generated)
|
||||||
|
|
||||||
opcodes_def_generated = custom_target(
|
opcodes_def_generated = custom_target(
|
||||||
'opcodes_def_generated.h.inc',
|
'opcodes_def_generated.h.inc',
|
||||||
output: 'opcodes_def_generated.h.inc',
|
output: 'opcodes_def_generated.h.inc',
|
||||||
input: 'gen_opcodes_def.py',
|
|
||||||
depends: [semantics_generated],
|
depends: [semantics_generated],
|
||||||
depend_files: [hex_common_py, attribs_def],
|
depend_files: [hex_common_py, attribs_def],
|
||||||
command: [python, '@INPUT@', semantics_generated, attribs_def, '@OUTPUT@'],
|
command: [python, files('gen_opcodes_def.py'), semantics_generated, attribs_def, '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(opcodes_def_generated)
|
hexagon_ss.add(opcodes_def_generated)
|
||||||
|
|
||||||
|
@ -154,8 +144,7 @@ gen_dectree_import = executable(
|
||||||
iset_py = custom_target(
|
iset_py = custom_target(
|
||||||
'iset.py',
|
'iset.py',
|
||||||
output: 'iset.py',
|
output: 'iset.py',
|
||||||
input: gen_dectree_import,
|
command: [gen_dectree_import, '@OUTPUT@'],
|
||||||
command: ['@INPUT@', '@OUTPUT@'],
|
|
||||||
)
|
)
|
||||||
hexagon_ss.add(iset_py)
|
hexagon_ss.add(iset_py)
|
||||||
|
|
||||||
|
@ -166,9 +155,8 @@ hexagon_ss.add(iset_py)
|
||||||
dectree_generated = custom_target(
|
dectree_generated = custom_target(
|
||||||
'dectree_generated.h.inc',
|
'dectree_generated.h.inc',
|
||||||
output: 'dectree_generated.h.inc',
|
output: 'dectree_generated.h.inc',
|
||||||
input: 'dectree.py',
|
|
||||||
depends: [iset_py],
|
depends: [iset_py],
|
||||||
command: ['PYTHONPATH=' + meson.current_build_dir(), '@INPUT@', '@OUTPUT@'],
|
command: ['env', 'PYTHONPATH=' + meson.current_build_dir(), files('dectree.py'), '@OUTPUT@'],
|
||||||
)
|
)
|
||||||
hexagon_ss.add(dectree_generated)
|
hexagon_ss.add(dectree_generated)
|
||||||
|
|
||||||
|
|
|
@ -5061,6 +5061,9 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||||
gen_jr(s, s->T0);
|
gen_jr(s, s->T0);
|
||||||
break;
|
break;
|
||||||
case 3: /* lcall Ev */
|
case 3: /* lcall Ev */
|
||||||
|
if (mod == 3) {
|
||||||
|
goto illegal_op;
|
||||||
|
}
|
||||||
gen_op_ld_v(s, ot, s->T1, s->A0);
|
gen_op_ld_v(s, ot, s->T1, s->A0);
|
||||||
gen_add_A0_im(s, 1 << ot);
|
gen_add_A0_im(s, 1 << ot);
|
||||||
gen_op_ld_v(s, MO_16, s->T0, s->A0);
|
gen_op_ld_v(s, MO_16, s->T0, s->A0);
|
||||||
|
@ -5088,6 +5091,9 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||||
gen_jr(s, s->T0);
|
gen_jr(s, s->T0);
|
||||||
break;
|
break;
|
||||||
case 5: /* ljmp Ev */
|
case 5: /* ljmp Ev */
|
||||||
|
if (mod == 3) {
|
||||||
|
goto illegal_op;
|
||||||
|
}
|
||||||
gen_op_ld_v(s, ot, s->T1, s->A0);
|
gen_op_ld_v(s, ot, s->T1, s->A0);
|
||||||
gen_add_A0_im(s, 1 << ot);
|
gen_add_A0_im(s, 1 << ot);
|
||||||
gen_op_ld_v(s, MO_16, s->T0, s->A0);
|
gen_op_ld_v(s, MO_16, s->T0, s->A0);
|
||||||
|
|
|
@ -884,6 +884,18 @@ static bool trans_l_mfspr(DisasContext *dc, arg_l_mfspr *a)
|
||||||
gen_illegal_exception(dc);
|
gen_illegal_exception(dc);
|
||||||
} else {
|
} else {
|
||||||
TCGv spr = tcg_temp_new();
|
TCGv spr = tcg_temp_new();
|
||||||
|
|
||||||
|
if (tb_cflags(dc->base.tb) & CF_USE_ICOUNT) {
|
||||||
|
gen_io_start();
|
||||||
|
if (dc->delayed_branch) {
|
||||||
|
tcg_gen_mov_tl(cpu_pc, jmp_pc);
|
||||||
|
tcg_gen_discard_tl(jmp_pc);
|
||||||
|
} else {
|
||||||
|
tcg_gen_movi_tl(cpu_pc, dc->base.pc_next + 4);
|
||||||
|
}
|
||||||
|
dc->base.is_jmp = DISAS_EXIT;
|
||||||
|
}
|
||||||
|
|
||||||
tcg_gen_ori_tl(spr, cpu_R(dc, a->a), a->k);
|
tcg_gen_ori_tl(spr, cpu_R(dc, a->a), a->k);
|
||||||
gen_helper_mfspr(cpu_R(dc, a->d), cpu_env, cpu_R(dc, a->d), spr);
|
gen_helper_mfspr(cpu_R(dc, a->d), cpu_env, cpu_R(dc, a->d), spr);
|
||||||
tcg_temp_free(spr);
|
tcg_temp_free(spr);
|
||||||
|
@ -898,6 +910,9 @@ static bool trans_l_mtspr(DisasContext *dc, arg_l_mtspr *a)
|
||||||
} else {
|
} else {
|
||||||
TCGv spr;
|
TCGv spr;
|
||||||
|
|
||||||
|
if (tb_cflags(dc->base.tb) & CF_USE_ICOUNT) {
|
||||||
|
gen_io_start();
|
||||||
|
}
|
||||||
/* For SR, we will need to exit the TB to recognize the new
|
/* For SR, we will need to exit the TB to recognize the new
|
||||||
* exception state. For NPC, in theory this counts as a branch
|
* exception state. For NPC, in theory this counts as a branch
|
||||||
* (although the SPR only exists for use by an ICE). Save all
|
* (although the SPR only exists for use by an ICE). Save all
|
||||||
|
|
Loading…
Reference in New Issue