On 29.04.20 16:35, Janosch Frank wrote: > Up to now a secondary cpu could have returned from the function it was > executing and ending up somewhere in cstart64.S. This was mostly > circumvented by an endless loop in the function that it executed. > > Let's add a loop to the end of the cpu setup, so we don't have to rely > on added loops in the tests. > > Signed-off-by: Janosch Frank <frankja@xxxxxxxxxxxxx> > Reviewed-by: Cornelia Huck <cohuck@xxxxxxxxxx> > --- > s390x/cstart64.S | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/s390x/cstart64.S b/s390x/cstart64.S > index 9af6bb3..ecffbe0 100644 > --- a/s390x/cstart64.S > +++ b/s390x/cstart64.S > @@ -161,7 +161,9 @@ smp_cpu_setup_state: > lctlg %c0, %c0, GEN_LC_SW_INT_CRS > /* We should only go once through cpu setup and not for every restart */ > stg %r14, GEN_LC_RESTART_NEW_PSW + 8 > - br %r14 > + brasl %r14, %r14 > + /* If the function returns, just loop here */ > +0: j 0 > > pgm_int: > SAVE_REGS > Acked-by: David Hildenbrand <david@xxxxxxxxxx> -- Thanks, David / dhildenb