1 /*
2 * PROJECT: ReactOS Kernel
3 * LICENSE: GPL - See COPYING in the top level directory
4 * FILE: ntoskrnl/ex/xipdisp.c
5 * PURPOSE: eXecute In Place (XIP) Support.
6 * PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
7 */
8
9 /* INCLUDES ******************************************************************/
10
11 #include <ntoskrnl.h>
12 #include <debug.h>
13
14 /* GLOBALS *******************************************************************/
15
16 /* FUNCTIONS *****************************************************************/
17
18 NTSTATUS
19 NTAPI
XIPDispatch(IN ULONG DispatchCode,OUT PVOID Buffer,IN ULONG BufferSize)20 XIPDispatch(IN ULONG DispatchCode,
21 OUT PVOID Buffer,
22 IN ULONG BufferSize)
23 {
24 UNIMPLEMENTED;
25 return STATUS_NOT_IMPLEMENTED;
26 }
27
28 CODE_SEG("INIT")
29 PMEMORY_ALLOCATION_DESCRIPTOR
30 NTAPI
XIPpFindMemoryDescriptor(IN PLOADER_PARAMETER_BLOCK LoaderBlock)31 XIPpFindMemoryDescriptor(IN PLOADER_PARAMETER_BLOCK LoaderBlock)
32 {
33 PLIST_ENTRY NextEntry;
34 PMEMORY_ALLOCATION_DESCRIPTOR Descriptor = NULL;
35
36 /* Loop the memory descriptors */
37 for (NextEntry = LoaderBlock->MemoryDescriptorListHead.Flink;
38 NextEntry != &LoaderBlock->MemoryDescriptorListHead;
39 NextEntry = NextEntry->Flink)
40 {
41 /* Get the current descriptor and check if it's the XIP ROM */
42 Descriptor = CONTAINING_RECORD(NextEntry,
43 MEMORY_ALLOCATION_DESCRIPTOR,
44 ListEntry);
45 if (Descriptor->MemoryType == LoaderXIPRom) return Descriptor;
46 }
47
48 /* Nothing found if we got here */
49 return NULL;
50 }
51
52 CODE_SEG("INIT")
53 VOID
54 NTAPI
XIPInit(IN PLOADER_PARAMETER_BLOCK LoaderBlock)55 XIPInit(IN PLOADER_PARAMETER_BLOCK LoaderBlock)
56 {
57 PCHAR CommandLine, XipBoot, XipRom, XipMegs, XipVerbose, XipRam;
58 PMEMORY_ALLOCATION_DESCRIPTOR XipDescriptor;
59
60 /* Get the command line */
61 CommandLine = LoaderBlock->LoadOptions;
62 if (!CommandLine) return;
63
64 /* Get XIP settings */
65 XipBoot = strstr(CommandLine, "XIPBOOT");
66 XipRam = strstr(CommandLine, "XIPRAM=");
67 XipRom = strstr(CommandLine, "XIPROM=");
68 XipMegs = strstr(CommandLine, "XIPMEGS=");
69 XipVerbose = strstr(CommandLine, "XIPVERBOSE");
70
71 /* Check if this is a verbose boot */
72 if (XipVerbose)
73 {
74 /* Print out our header */
75 DbgPrint("\n\nXIP: debug timestamp at line %d in %s: <<<%s %s>>>\n\n",
76 __LINE__,
77 __FILE__,
78 __DATE__,
79 __TIME__);
80 }
81
82 /* Find the XIP memory descriptor */
83 XipDescriptor = XIPpFindMemoryDescriptor(LoaderBlock);
84 if (!XipDescriptor) return;
85
86 //
87 // Make sure this is really XIP, and not RAM Disk -- also validate XIP
88 // Basically, either this is a ROM boot or a RAM boot, but not both nor none
89 //
90 if (!((ULONG_PTR)XipRom ^ (ULONG_PTR)XipRam)) return;
91
92 /* FIXME: TODO */
93 DPRINT1("ReactOS does not yet support eXecute In Place boot technology\n");
94 DPRINT("%s MB requested (XIP = %s)\n", XipMegs, XipBoot);
95 }
96
97 /* EOF */
98