mirror of
https://github.com/reactos/reactos.git
synced 2025-01-07 14:51:00 +00:00
- Add initial support for TI OMAP3530 (last commit said OMAP3450, this was incorrect), an ARM Cortex-A8 based SoC.
- This gets us booting to FreeLDR with some serial output. - The entire MMU code needs a rewrite. svn path=/trunk/; revision=41983
This commit is contained in:
parent
4c1ac0d33e
commit
cc98ebfe87
6 changed files with 207 additions and 16 deletions
|
@ -10,7 +10,6 @@
|
||||||
.include "ntoskrnl/include/internal/arm/kxarm.h"
|
.include "ntoskrnl/include/internal/arm/kxarm.h"
|
||||||
.include "ntoskrnl/include/internal/arm/ksarm.h"
|
.include "ntoskrnl/include/internal/arm/ksarm.h"
|
||||||
|
|
||||||
.section startup
|
|
||||||
NESTED_ENTRY _start
|
NESTED_ENTRY _start
|
||||||
PROLOG_END _start
|
PROLOG_END _start
|
||||||
|
|
||||||
|
@ -45,7 +44,7 @@
|
||||||
//
|
//
|
||||||
// Okay, now give us a stack
|
// Okay, now give us a stack
|
||||||
//
|
//
|
||||||
ldr sp, L_BootStackEnd
|
//ldr sp, L_BootStackEnd
|
||||||
|
|
||||||
//
|
//
|
||||||
// Go ahead and call the C initialization code
|
// Go ahead and call the C initialization code
|
||||||
|
@ -60,13 +59,6 @@ L_BootStackEnd:
|
||||||
L_ArmInit:
|
L_ArmInit:
|
||||||
.long ArmInit
|
.long ArmInit
|
||||||
|
|
||||||
.align 4
|
|
||||||
.global BootStack
|
|
||||||
BootStack:
|
|
||||||
.space 0x4000
|
|
||||||
BootStackEnd:
|
|
||||||
.long 0
|
|
||||||
|
|
||||||
.section pagedata
|
.section pagedata
|
||||||
.global TranslationTableStart
|
.global TranslationTableStart
|
||||||
TranslationTableStart:
|
TranslationTableStart:
|
||||||
|
|
|
@ -12,6 +12,8 @@
|
||||||
|
|
||||||
/* GLOBALS ********************************************************************/
|
/* GLOBALS ********************************************************************/
|
||||||
|
|
||||||
|
UCHAR BootStack[0x4000];
|
||||||
|
PUCHAR BootStackEnd = &BootStack[0x3FFF];
|
||||||
PARM_BOARD_CONFIGURATION_BLOCK ArmBoardBlock;
|
PARM_BOARD_CONFIGURATION_BLOCK ArmBoardBlock;
|
||||||
ULONG BootDrive, BootPartition;
|
ULONG BootDrive, BootPartition;
|
||||||
VOID ArmPrepareForReactOS(IN BOOLEAN Setup);
|
VOID ArmPrepareForReactOS(IN BOOLEAN Setup);
|
||||||
|
@ -40,7 +42,8 @@ ArmInit(IN PARM_BOARD_CONFIGURATION_BLOCK BootContext)
|
||||||
// This should probably go away once we support more boards
|
// This should probably go away once we support more boards
|
||||||
//
|
//
|
||||||
ASSERT((ArmBoardBlock->BoardType == MACH_TYPE_FEROCEON) ||
|
ASSERT((ArmBoardBlock->BoardType == MACH_TYPE_FEROCEON) ||
|
||||||
(ArmBoardBlock->BoardType == MACH_TYPE_VERSATILE_PB));
|
(ArmBoardBlock->BoardType == MACH_TYPE_VERSATILE_PB) ||
|
||||||
|
(ArmBoardBlock->BoardType == MACH_TYPE_OMAP3_BEAGLE));
|
||||||
|
|
||||||
//
|
//
|
||||||
// Save data required for memory initialization
|
// Save data required for memory initialization
|
||||||
|
@ -169,10 +172,25 @@ MachInit(IN PCCH CommandLine)
|
||||||
MachVtbl.ConsGetCh = ArmVersaGetCh;
|
MachVtbl.ConsGetCh = ArmVersaGetCh;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Check for TI OMAP3 boards
|
||||||
|
// For now that means only Beagle, but ZOOM and others should be ok too
|
||||||
|
//
|
||||||
|
case MACH_TYPE_OMAP3_BEAGLE:
|
||||||
|
|
||||||
|
//
|
||||||
|
// These boards use a UART16550
|
||||||
|
//
|
||||||
|
ArmOmap3SerialInit(115200);
|
||||||
|
MachVtbl.ConsPutChar = ArmOmap3PutChar;
|
||||||
|
MachVtbl.ConsKbHit = ArmOmap3KbHit;
|
||||||
|
MachVtbl.ConsGetCh = ArmOmap3GetCh;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
ASSERT(FALSE);
|
ASSERT(FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Setup generic ARM routines for all boards
|
// Setup generic ARM routines for all boards
|
||||||
//
|
//
|
||||||
|
|
162
reactos/boot/freeldr/freeldr/arch/arm/omapuart.c
Normal file
162
reactos/boot/freeldr/freeldr/arch/arm/omapuart.c
Normal file
|
@ -0,0 +1,162 @@
|
||||||
|
/*
|
||||||
|
* PROJECT: ReactOS Boot Loader
|
||||||
|
* LICENSE: BSD - See COPYING.ARM in the top level directory
|
||||||
|
* FILE: boot/freeldr/arch/arm/omapuart.c
|
||||||
|
* PURPOSE: Implements code for TI OMAP3 boards using the 16550 UART
|
||||||
|
* PROGRAMMERS: ReactOS Portable Systems Group
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* INCLUDES *******************************************************************/
|
||||||
|
|
||||||
|
#include <freeldr.h>
|
||||||
|
|
||||||
|
/* GLOBALS ********************************************************************/
|
||||||
|
|
||||||
|
//
|
||||||
|
// UART Registers
|
||||||
|
//
|
||||||
|
#define UART0_RHR (ArmBoardBlock->UartRegisterBase + 0x00)
|
||||||
|
#define UART0_THR UART0_RHR
|
||||||
|
#define UART0_IER (ArmBoardBlock->UartRegisterBase + 0x04)
|
||||||
|
#define UART0_FCR (ArmBoardBlock->UartRegisterBase + 0x08)
|
||||||
|
#define UART0_LCR (ArmBoardBlock->UartRegisterBase + 0x0C)
|
||||||
|
#define UART0_MCR (ArmBoardBlock->UartRegisterBase + 0x10)
|
||||||
|
#define UART0_LSR (ArmBoardBlock->UartRegisterBase + 0x14)
|
||||||
|
#define UART0_MDR1 (ArmBoardBlock->UartRegisterBase + 0x20)
|
||||||
|
|
||||||
|
//
|
||||||
|
// When we enable the divisor latch
|
||||||
|
//
|
||||||
|
#define UART0_DLL UART0_RHR
|
||||||
|
#define UART0_DLH UART0_IER
|
||||||
|
|
||||||
|
//
|
||||||
|
// FCR Values
|
||||||
|
//
|
||||||
|
#define FCR_FIFO_EN 0x01
|
||||||
|
#define FCR_RXSR 0x02
|
||||||
|
#define FCR_TXSR 0x04
|
||||||
|
|
||||||
|
//
|
||||||
|
// LCR Values
|
||||||
|
//
|
||||||
|
#define LCR_WLS_8 0x03
|
||||||
|
#define LCR_1_STB 0x00
|
||||||
|
#define LCR_DIVL_EN 0x80
|
||||||
|
#define LCR_NO_PAR 0x00
|
||||||
|
|
||||||
|
//
|
||||||
|
// LSR Values
|
||||||
|
//
|
||||||
|
#define LSR_DR 0x01
|
||||||
|
#define LSR_THRE 0x20
|
||||||
|
|
||||||
|
//
|
||||||
|
// MCR Values
|
||||||
|
//
|
||||||
|
#define MCR_DTR 0x01
|
||||||
|
#define MCR_RTS 0x02
|
||||||
|
|
||||||
|
//
|
||||||
|
// MDR1 Modes
|
||||||
|
//
|
||||||
|
#define MDR1_UART16X 1
|
||||||
|
#define MDR1_SIR 2
|
||||||
|
#define MDR1_UART16X_AUTO_BAUD 3
|
||||||
|
#define MDR1_UART13X 4
|
||||||
|
#define MDR1_MIR 5
|
||||||
|
#define MDR1_FIR 6
|
||||||
|
#define MDR1_CIR 7
|
||||||
|
#define MDR1_DISABLE 8
|
||||||
|
|
||||||
|
/* FUNCTIONS ******************************************************************/
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ArmOmap3SerialInit(IN ULONG Baudrate)
|
||||||
|
{
|
||||||
|
ULONG BaudClock;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Calculate baudrate clock divider to set the baud rate
|
||||||
|
//
|
||||||
|
BaudClock = (ArmBoardBlock->ClockRate / 16) / Baudrate;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Disable serial port
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_MDR1, MDR1_DISABLE);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Disable interrupts
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_IER, 0);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Set the baud rate to 115200 bps
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_LCR, LCR_DIVL_EN);
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_DLL, BaudClock);
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_DLH, (BaudClock >> 8) & 0xFF);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Setup loopback
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_MCR, MCR_DTR | MCR_RTS);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Set 8 bits for data, 1 stop bit, no parity
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_LCR, LCR_WLS_8 | LCR_1_STB | LCR_NO_PAR);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Clear and enable FIFO
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_FCR, FCR_FIFO_EN | FCR_RXSR | FCR_TXSR);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Enable serial port
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_MDR1, MDR1_UART16X);
|
||||||
|
}
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ArmOmap3PutChar(IN INT Char)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Properly support new-lines
|
||||||
|
//
|
||||||
|
if (Char == '\n') ArmOmap3PutChar('\r');
|
||||||
|
|
||||||
|
//
|
||||||
|
// Wait for ready
|
||||||
|
//
|
||||||
|
while ((READ_REGISTER_UCHAR(UART0_LSR) & LSR_THRE) == 0);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Send the character
|
||||||
|
//
|
||||||
|
WRITE_REGISTER_UCHAR(UART0_THR, Char);
|
||||||
|
}
|
||||||
|
|
||||||
|
INT
|
||||||
|
ArmOmap3GetCh(VOID)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Wait for ready
|
||||||
|
//
|
||||||
|
while ((READ_REGISTER_UCHAR(UART0_LSR) & LSR_DR) == 0);
|
||||||
|
|
||||||
|
//
|
||||||
|
// Read the character
|
||||||
|
//
|
||||||
|
return READ_REGISTER_UCHAR(UART0_RHR);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOLEAN
|
||||||
|
ArmOmap3KbHit(VOID)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Return if something is ready
|
||||||
|
//
|
||||||
|
return ((READ_REGISTER_UCHAR(UART0_LSR) & LSR_DR) != 0);
|
||||||
|
}
|
|
@ -69,10 +69,11 @@
|
||||||
</directory>
|
</directory>
|
||||||
<directory name="arm">
|
<directory name="arm">
|
||||||
<if property="ARCH" value="arm">
|
<if property="ARCH" value="arm">
|
||||||
<file>boot.s</file>
|
<file first="true">boot.s</file>
|
||||||
<file>ferouart.c</file>
|
<file>ferouart.c</file>
|
||||||
<file>loader.c</file>
|
<file>loader.c</file>
|
||||||
<file>macharm.c</file>
|
<file>macharm.c</file>
|
||||||
|
<file>omapuart.c</file>
|
||||||
<file>versuart.c</file>
|
<file>versuart.c</file>
|
||||||
</if>
|
</if>
|
||||||
</directory>
|
</directory>
|
||||||
|
|
|
@ -25,6 +25,12 @@
|
||||||
//
|
//
|
||||||
#define MACH_TYPE_VERSATILE_PB 387
|
#define MACH_TYPE_VERSATILE_PB 387
|
||||||
|
|
||||||
|
//
|
||||||
|
// TI Beagle Board, OMAP3530 SoC
|
||||||
|
// qemu-system-arm -M beagle, Beagle Board
|
||||||
|
//
|
||||||
|
#define MACH_TYPE_OMAP3_BEAGLE 1546
|
||||||
|
|
||||||
//
|
//
|
||||||
// Compatible boot-loaders should return us this information
|
// Compatible boot-loaders should return us this information
|
||||||
//
|
//
|
||||||
|
@ -105,6 +111,18 @@ ArmFeroGetCh(VOID);
|
||||||
BOOLEAN
|
BOOLEAN
|
||||||
ArmFeroKbHit(VOID);
|
ArmFeroKbHit(VOID);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ArmOmap3SerialInit(IN ULONG Baudrate);
|
||||||
|
|
||||||
|
VOID
|
||||||
|
ArmOmap3PutChar(IN INT Char);
|
||||||
|
|
||||||
|
INT
|
||||||
|
ArmOmap3GetCh(VOID);
|
||||||
|
|
||||||
|
BOOLEAN
|
||||||
|
ArmOmap3KbHit(VOID);
|
||||||
|
|
||||||
VOID
|
VOID
|
||||||
ArmVersaSerialInit(IN ULONG Baudrate);
|
ArmVersaSerialInit(IN ULONG Baudrate);
|
||||||
|
|
||||||
|
|
|
@ -169,10 +169,10 @@ static const MEMORY_DESCRIPTOR_INT MemoryDescriptors[] =
|
||||||
{ { MemoryFirmwareTemporary, 0x90, 0x10 }, 5, }, // Disk read buffer for int 13h. DISKREADBUFFER
|
{ { MemoryFirmwareTemporary, 0x90, 0x10 }, 5, }, // Disk read buffer for int 13h. DISKREADBUFFER
|
||||||
{ { MemoryFirmwarePermanent, 0xA0, 0x60 }, 6, }, // ROM / Video
|
{ { MemoryFirmwarePermanent, 0xA0, 0x60 }, 6, }, // ROM / Video
|
||||||
{ { MemorySpecialMemory, 0xFFF, 1 }, 7, }, // unusable memory
|
{ { MemorySpecialMemory, 0xFFF, 1 }, 7, }, // unusable memory
|
||||||
#elif __arm__
|
#elif __arm__ // This needs to be done per-platform specific way
|
||||||
{ { MemoryFirmwarePermanent, 0x00, 1 }, 0, }, // arm exception handlers
|
{ { MemoryLoadedProgram, 0x80000, 32 }, 0, }, // X-Loader + OmapLdr
|
||||||
{ { MemoryFirmwareTemporary, 0x01, 7 }, 1, }, // arm board block + freeldr stack + cmdline
|
{ { MemoryLoadedProgram, 0x81000, 128 }, 1, }, // FreeLDR
|
||||||
{ { MemoryLoadedProgram, 0x08, 0x70 }, 2, }, // freeldr image (roughly max. 0x64 pages)
|
{ { MemoryFirmwareTemporary, 0x80500, 4096 }, 2, }, // Video Buffer
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
MEMORY_DESCRIPTOR*
|
MEMORY_DESCRIPTOR*
|
||||||
|
|
Loading…
Reference in a new issue