[OpenBIOS] SOLVED: the mystery of Solaris on SPARC32 and the missing Forth arguments
Mark Cave-Ayland
mark.cave-ayland at siriusit.co.uk
Sat Oct 30 10:38:48 CEST 2010
Blue Swirl wrote:
>>>> None. It probably tries to access something which is not mapped.
>>> This could be verified by changing a line in helper.c:
>>> *physical = 0xffffffffffff0000ULL;
>>> to for example
>>> *physical = 0xfef1f0fef1ff0000ULL;
>>> and see if the address changes.
>> It changes for me here:
>>
>> Unassigned mem write access of 4 bytes to fef1f0fef1ff0ecc from f004127c
>
> Then it must be no-fault access. But I wonder why there is a fault, in
> no-fault mode there should be no faults. And when MMU is switched back
> to normal mode, the fake TLB mappings should be flushed.
>
>> But then again I'm not sure whether this comment was aimed at me or Artyom?
>> Does Tarl's suggestion of just ignoring write accesses to the ROM area sound
>> feasible?
>
> I don't think ROM area is in play, but no-fault mode.
Is this the relevant section from the SPARC v8 manual here?
NF
NF is the “No Fault” bit. When NF = 0, any fault detected by the MMU
causes FSR and FAR to be updated and causes a fault to be generated to
the processor. When NF = 1, a fault on an access to ASI 9 is handled as
when NF = 0; a fault on an access to any other ASI causes FSR and FAR to
be updated but no fault is generated to the processor.
If a fault on access to an ASI other than 9 occurs while NF = 1, subse-
quently resetting NF from 1 to 0 does not cause a fault to the processor
(even though FSR.FT ≠ 0 at that time). A change in value of the NF bit
takes effect as soon as the bit is written; a subsequent access to ASI 9
will be evaluated according to the new value of the NF bit.
ATB,
Mark.
--
Mark Cave-Ayland - Senior Technical Architect
PostgreSQL - PostGIS
Sirius Corporation plc - control through freedom
http://www.siriusit.co.uk
t: +44 870 608 0063
Sirius Labs: http://www.siriusit.co.uk/labs
More information about the OpenBIOS
mailing list