On Thu, 7 Sep 2006 16:48:19 +0800, Yu Luming wrote:

>> I agree. I'm also happy if kdb and kdump share the code.
>> I'll check kdb code.
>>
>> >>+          /* change region of gp to region5 */
>> >>+          asm volatile ("movl gp=__gp"::: "memory");
>> >
>> >Why?  gp is already pointing at the kernel code before we enter
>> >ia64_init_handler().
>>
>> The purpose of this code is just changing region of gp from region7 to
>> region5. For example, if gp is e000000004ace170, I want to change gp to
>> a000000104ace170, but I couldn't find good method. Is there good method
>> to change region?
>>
>Did  saved Os gp in SAL OS state  somehow get overridden before 
>ia64_set_kernel_registers prior to invocation of ia64_init_handler?
>
>I assume the following code (in ia64_set_kernel_registers ) should restore 
>correct GP value.
>
>ia64_set_kernel_registers:
>       ...
>        ;;
>        ld8 r1=[temp4]          // OS GP from SAL OS state

Yes, but this gp value is physical address.
In the next line, gp is changed to virtual address.

DATA_PA_TO_VA(r1,temp1)

This macro just sets region7 bit, so gp value becomes region7 address.

Regards,
Takao Indoh


_______________________________________________
fastboot mailing list
[email protected]
https://lists.osdl.org/mailman/listinfo/fastboot

Reply via email to