Add 68040 MMU support

This commit is contained in:
Laurent Vivier 2004-03-06 01:10:31 +00:00
parent 9b2dcff01f
commit 3329589705

View File

@ -24,6 +24,9 @@ extern char _kernel_end;
extern char _KERNEL_SIZE; extern char _KERNEL_SIZE;
extern void enter_kernel030(unsigned long addr, unsigned long size, unsigned long dest); extern void enter_kernel030(unsigned long addr, unsigned long size, unsigned long dest);
extern char end_enter_kernel030;
extern void enter_kernel040(unsigned long addr, unsigned long size, unsigned long dest);
extern char end_enter_kernel040;
#define PAGE_SHIFT 12 #define PAGE_SHIFT 12
#define PAGE_SIZE (1UL << PAGE_SHIFT) #define PAGE_SIZE (1UL << PAGE_SHIFT)
@ -46,6 +49,8 @@ int main(int argc, char** argv)
unsigned long start_mem; unsigned long start_mem;
unsigned long aligned_size; unsigned long aligned_size;
unsigned long aligned_addr; unsigned long aligned_addr;
unsigned long enter_kernel;
unsigned long end_enter_kernel;
#endif #endif
printf("Early Macintosh Image LoadEr\n"); printf("Early Macintosh Image LoadEr\n");
@ -129,23 +134,30 @@ int main(int argc, char** argv)
/* where is mapped my boot function ? */ /* where is mapped my boot function ? */
ret = logical2physical( (unsigned long)enter_kernel030, if (mmu_type == gestalt68040MMU)
(unsigned long*)&entry); {
enter_kernel = (unsigned long)enter_kernel030;
if ( (ret == 0) && end_enter_kernel = (unsigned long)&end_enter_kernel030;
((unsigned long)enter_kernel030 != (unsigned long)entry) ) }
else
{
enter_kernel = (unsigned long)enter_kernel040;
end_enter_kernel = (unsigned long)&end_enter_kernel040;
}
ret = logical2physical(enter_kernel, (unsigned long*)&entry);
if ( (ret == 0) && (enter_kernel != (unsigned long)entry) )
{ {
extern char end_enter_kernel030;
unsigned long logi; unsigned long logi;
unsigned long size = (unsigned long)&end_enter_kernel030 - unsigned long size = end_enter_kernel - enter_kernel;
(unsigned long)&enter_kernel030;
logi = console_get_video(); logi = console_get_video();
ret = logical2physical(logi, (unsigned long*)&entry); ret = logical2physical(logi, (unsigned long*)&entry);
memcpy((char*)logi, &enter_kernel030, size); memcpy((char*)logi, (char*)enter_kernel, size);
memcpy((char*)entry, &enter_kernel030, size); memcpy((char*)entry, (char*)enter_kernel, size);
} }