Hi ,
for ARMv7-A15, when an exception is issued, such like a "smc #0" instruction in supervisor mode, ARM hardware will jump into the vector and CPSR will be changed in monitor mode.
my question is, what value will be written into CPSR by ARM hardware?
the genernal descriptor is the M[4:0] will be changed to 10110, which means monitor mode; but how about other bits, I mean for example the CPSR.E bit.
I jsut do a test, when I enter the monitor mode at the 1st time, I set the CPSR.E bit. but when I enter it again, the CPSR.E bit is cleared. is only default value saved?
any comment is very appreciative.
thank you very much!
Haven't tried this but I believe the CPSR is reset using SCTLR on anything like that so you'd have to set that.
On taking an exception the CPSR E and T bits take the value of the SCTLR EE and TE bits. The CPSR I bit gets set on taking any kind of exception, the F bit gets set on taking a FIQ or reset.
REmember that for Monitor mode it's the secure copy of SCTLR that is used when entering Monitor mode.