- 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:
ReactOS Portable Systems Group 2009-07-15 18:30:04 +00:00
parent 4c1ac0d33e
commit cc98ebfe87
6 changed files with 207 additions and 16 deletions

View file

@ -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:

View file

@ -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
// //

View 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);
}

View file

@ -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>

View file

@ -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);

View file

@ -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*