mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-06 01:03:55 -06:00
s390x/flic: cache the common flic class in a central function
This avoids tons of conversions when handling interrupts. Signed-off-by: David Hildenbrand <david@redhat.com> Message-Id: <20180129125623.21729-19-david@redhat.com> Signed-off-by: Cornelia Huck <cohuck@redhat.com>
This commit is contained in:
parent
c21a6106c1
commit
6762808fda
5 changed files with 23 additions and 11 deletions
|
@ -439,7 +439,7 @@ static int s390_io_adapter_map(AdapterInfo *adapter, uint64_t map_addr,
|
|||
bool do_map)
|
||||
{
|
||||
S390FLICState *fs = s390_get_flic();
|
||||
S390FLICStateClass *fsc = S390_FLIC_COMMON_GET_CLASS(fs);
|
||||
S390FLICStateClass *fsc = s390_get_flic_class(fs);
|
||||
|
||||
return fsc->io_adapter_map(fs, adapter->adapter_id, map_addr, do_map);
|
||||
}
|
||||
|
@ -520,7 +520,7 @@ void css_register_io_adapters(CssIoAdapterType type, bool swap, bool maskable,
|
|||
int ret, isc;
|
||||
IoAdapter *adapter;
|
||||
S390FLICState *fs = s390_get_flic();
|
||||
S390FLICStateClass *fsc = S390_FLIC_COMMON_GET_CLASS(fs);
|
||||
S390FLICStateClass *fsc = s390_get_flic_class(fs);
|
||||
|
||||
/*
|
||||
* Disallow multiple registrations for the same device type.
|
||||
|
@ -566,7 +566,7 @@ static void css_clear_io_interrupt(uint16_t subchannel_id,
|
|||
Error *err = NULL;
|
||||
static bool no_clear_irq;
|
||||
S390FLICState *fs = s390_get_flic();
|
||||
S390FLICStateClass *fsc = S390_FLIC_COMMON_GET_CLASS(fs);
|
||||
S390FLICStateClass *fsc = s390_get_flic_class(fs);
|
||||
int r;
|
||||
|
||||
if (unlikely(no_clear_irq)) {
|
||||
|
@ -640,7 +640,7 @@ void css_conditional_io_interrupt(SubchDev *sch)
|
|||
int css_do_sic(CPUS390XState *env, uint8_t isc, uint16_t mode)
|
||||
{
|
||||
S390FLICState *fs = s390_get_flic();
|
||||
S390FLICStateClass *fsc = S390_FLIC_COMMON_GET_CLASS(fs);
|
||||
S390FLICStateClass *fsc = s390_get_flic_class(fs);
|
||||
int r;
|
||||
|
||||
if (env->psw.mask & PSW_MASK_PSTATE) {
|
||||
|
@ -666,7 +666,7 @@ out:
|
|||
void css_adapter_interrupt(CssIoAdapterType type, uint8_t isc)
|
||||
{
|
||||
S390FLICState *fs = s390_get_flic();
|
||||
S390FLICStateClass *fsc = S390_FLIC_COMMON_GET_CLASS(fs);
|
||||
S390FLICStateClass *fsc = s390_get_flic_class(fs);
|
||||
uint32_t io_int_word = (isc << 27) | IO_INT_WORD_AI;
|
||||
IoAdapter *adapter = channel_subsys.io_adapters[type][isc];
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue