added initfuncs.h private header to memory manager to allow us to centralize

some local definitions
This commit is contained in:
Eric J. Bowersox 2013-05-02 23:58:14 -06:00
parent 621aec75bb
commit 61ff5d8db4
7 changed files with 63 additions and 11 deletions

View File

@ -62,9 +62,6 @@ typedef struct tagVMCTXT {
RBTREE rbtPageTables; /* tree containing page tables this context owns */ RBTREE rbtPageTables; /* tree containing page tables this context owns */
} VMCTXT, *PVMCTXT; } VMCTXT, *PVMCTXT;
/* Pointer to a function to update the page database with a PTE address. */
typedef void (*PFNSETPTEADDR)(UINT32, PHYSADDR, BOOL);
/* Invalid page return. */ /* Invalid page return. */
#define INVALID_PAGE ((UINT32)(-1)) #define INVALID_PAGE ((UINT32)(-1))

View File

@ -36,6 +36,7 @@
#include <comrogue/objhelp.h> #include <comrogue/objhelp.h>
#include <comrogue/internals/seg.h> #include <comrogue/internals/seg.h>
#include <comrogue/internals/layout.h> #include <comrogue/internals/layout.h>
#include "initfuncs.h"
/*------------------------------------------------------------------------------------------------------------- /*-------------------------------------------------------------------------------------------------------------
* Initial heap implementation. Since this will only be used by initializer code and freed with the rest * Initial heap implementation. Since this will only be used by initializer code and freed with the rest

58
kernel/mm/initfuncs.h Normal file
View File

@ -0,0 +1,58 @@
/*
* This file is part of the COMROGUE Operating System for Raspberry Pi
*
* Copyright (c) 2013, Eric J. Bowersox / Erbosoft Enterprises
* All rights reserved.
*
* This program is free for commercial and non-commercial use as long as the following conditions are
* adhered to.
*
* Copyright in this file remains Eric J. Bowersox and/or Erbosoft, and as such any copyright notices
* in the code are not to be removed.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted
* provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice, this list of conditions and
* the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and
* the following disclaimer in the documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
* "Raspberry Pi" is a trademark of the Raspberry Pi Foundation.
*/
#ifndef __INITFUNCS_H_INCLUDED
#define __INITFUNCS_H_INCLUDED
#ifndef __ASM__
#include <comrogue/allocator.h>
#include <comrogue/internals/startup.h>
/* Pointer to a function to update the page database with a PTE address. */
typedef void (*PFNSETPTEADDR)(UINT32, PHYSADDR, BOOL);
/*------------------------------------
* Prototypes for the init functions.
*------------------------------------
*/
extern IMalloc *_MmGetInitHeap(void);
extern void _MmInitKernelSpace(PSTARTUP_INFO pstartup, PMALLOC pmInitHeap);
extern void _MmInitVMMap(PSTARTUP_INFO pstartup, PMALLOC pmInitHeap);
extern void _MmInitPageAlloc(PSTARTUP_INFO pstartup);
/* secondary init function in the VM mapper */
extern void _MmInitPTEMappings(PFNSETPTEADDR pfnSetPTEAddr);
#endif /* __ASM__ */
#endif /* __INITFUNCS_H_INCLUDED */

View File

@ -38,6 +38,7 @@
#include <comrogue/internals/seg.h> #include <comrogue/internals/seg.h>
#include <comrogue/internals/startup.h> #include <comrogue/internals/startup.h>
#include <comrogue/internals/trace.h> #include <comrogue/internals/trace.h>
#include "initfuncs.h"
#ifdef THIS_FILE #ifdef THIS_FILE
#undef THIS_FILE #undef THIS_FILE

View File

@ -35,17 +35,13 @@
#include <comrogue/internals/seg.h> #include <comrogue/internals/seg.h>
#include <comrogue/internals/memmgr.h> #include <comrogue/internals/memmgr.h>
#include <comrogue/internals/startup.h> #include <comrogue/internals/startup.h>
#include "initfuncs.h"
/*--------------------- /*---------------------
* Initialization code * Initialization code
*--------------------- *---------------------
*/ */
extern IMalloc *_MmGetInitHeap(void);
extern void _MmInitKernelSpace(PSTARTUP_INFO pstartup, PMALLOC pmInitHeap);
extern void _MmInitVMMap(PSTARTUP_INFO pstartup, PMALLOC pmInitHeap);
extern void _MmInitPageAlloc(PSTARTUP_INFO pstartup);
SEG_INIT_CODE void _MmInit(PSTARTUP_INFO pstartup) SEG_INIT_CODE void _MmInit(PSTARTUP_INFO pstartup)
{ {
IMalloc *pmInitHeap = _MmGetInitHeap(); IMalloc *pmInitHeap = _MmGetInitHeap();

View File

@ -37,6 +37,7 @@
#include <comrogue/internals/memmgr.h> #include <comrogue/internals/memmgr.h>
#include <comrogue/internals/startup.h> #include <comrogue/internals/startup.h>
#include <comrogue/internals/trace.h> #include <comrogue/internals/trace.h>
#include "initfuncs.h"
#ifdef THIS_FILE #ifdef THIS_FILE
#undef THIS_FILE #undef THIS_FILE
@ -349,9 +350,6 @@ SEG_INIT_CODE static UINT32 build_page_chain(UINT32 ndxFirstPage, UINT32 cpg, un
extern char cpgPrestartTotal, cpgLibraryCode, cpgKernelCode, cpgKernelData, cpgKernelBss, cpgInitCode, extern char cpgPrestartTotal, cpgLibraryCode, cpgKernelCode, cpgKernelData, cpgKernelBss, cpgInitCode,
cpgInitData, cpgInitBss; cpgInitData, cpgInitBss;
/* secondary init function in the VM mapper */
extern void _MmInitPTEMappings(PFNSETPTEADDR pfnSetPTEAddr);
/* /*
* Initializes the page allocator and the Master Page Database. * Initializes the page allocator and the Master Page Database.
* *

View File

@ -40,6 +40,7 @@
#include <comrogue/internals/rbtree.h> #include <comrogue/internals/rbtree.h>
#include <comrogue/internals/startup.h> #include <comrogue/internals/startup.h>
#include <comrogue/internals/trace.h> #include <comrogue/internals/trace.h>
#include "initfuncs.h"
#ifdef THIS_FILE #ifdef THIS_FILE
#undef THIS_FILE #undef THIS_FILE