On Thu, 27 May 2021 16:52:48 +0200 Janosch Frank <frankja@xxxxxxxxxxxxx> wrote: > On 5/26/21 3:42 PM, Claudio Imbrenda wrote: > > Add a union to represent Translation-Exception Identification > > (TEID). > > > > Clear the TEID in expect_pgm_int clear_pgm_int. > > > > Signed-off-by: Claudio Imbrenda <imbrenda@xxxxxxxxxxxxx> > > Reviewed-by: Janosch Frank <frankja@xxxxxxxxxxxxx> > > > --- > > lib/s390x/asm/interrupt.h | 22 ++++++++++++++++++++++ > > lib/s390x/interrupt.c | 2 ++ > > 2 files changed, 24 insertions(+) > > > > diff --git a/lib/s390x/asm/interrupt.h b/lib/s390x/asm/interrupt.h > > index bf0eb40d..b40def65 100644 > > --- a/lib/s390x/asm/interrupt.h > > +++ b/lib/s390x/asm/interrupt.h > > @@ -13,6 +13,28 @@ > > #define EXT_IRQ_EXTERNAL_CALL 0x1202 > > #define EXT_IRQ_SERVICE_SIG 0x2401 > > > > +#define TEID_ASCE_PRIMARY 0 > > +#define TEID_ASCE_AR 1 > > +#define TEID_ASCE_SECONDARY 2 > > +#define TEID_ASCE_HOME 3 > > + > > +union teid { > > + unsigned long val; > > + struct { > > + unsigned long addr:52; > > + unsigned long fetch:1; > > + unsigned long store:1; > > + unsigned long reserved:6; > > + unsigned long acc_list_prot:1; > > + /* depending on the exception and the installed > > facilities, > > + * the m field can indicate severel different > > things, > > several fixed > > + * including whether the exception was triggered > > by a MVPG > > + * instruction, or whether the addr field is > > meaningful */ > > Could you please convert the comment style to this? > > /* > * Text > */ and fixed > > + unsigned long m:1; > > + unsigned long asce_id:2; > > + }; > > +}; > > + > > void register_pgm_cleanup_func(void (*f)(void)); > > void handle_pgm_int(struct stack_frame_int *stack); > > void handle_ext_int(struct stack_frame_int *stack); > > diff --git a/lib/s390x/interrupt.c b/lib/s390x/interrupt.c > > index ce0003de..b627942f 100644 > > --- a/lib/s390x/interrupt.c > > +++ b/lib/s390x/interrupt.c > > @@ -22,6 +22,7 @@ void expect_pgm_int(void) > > { > > pgm_int_expected = true; > > lc->pgm_int_code = 0; > > + lc->trans_exc_id = 0; > > mb(); > > } > > > > @@ -39,6 +40,7 @@ uint16_t clear_pgm_int(void) > > mb(); > > code = lc->pgm_int_code; > > lc->pgm_int_code = 0; > > + lc->trans_exc_id = 0; > > pgm_int_expected = false; > > return code; > > } > > >