started in on a bunch of memory management code
This commit is contained in:
61
include/comrogue/internals/memmgr.h
Normal file
61
include/comrogue/internals/memmgr.h
Normal file
@@ -0,0 +1,61 @@
|
||||
/*
|
||||
* 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 __MEMMGR_H_INCLUDED
|
||||
#define __MEMMGR_H_INCLUDED
|
||||
|
||||
#ifdef __COMROGUE_INTERNALS__
|
||||
|
||||
#ifndef __ASM__
|
||||
|
||||
#include <comrogue/types.h>
|
||||
#include <comrogue/compiler_macros.h>
|
||||
#include <comrogue/internals/mmu.h>
|
||||
#include <comrogue/internals/startup.h>
|
||||
|
||||
CDECL_BEGIN
|
||||
|
||||
/* Page mapping functions */
|
||||
extern PHYSADDR MmGetPhysAddr(PTTB pTTB, KERNADDR vma);
|
||||
extern HRESULT MmDemapPages(PTTB pTTB, KERNADDR vmaBase, UINT32 cpg);
|
||||
extern HRESULT MmMapPages(PTTB pTTB, PHYSADDR paBase, KERNADDR vmaBase, UINT32 cpg, UINT32 uiTableFlags,
|
||||
UINT32 uiPageFlags);
|
||||
|
||||
/* Initialization functions only */
|
||||
extern void _MmInit(PSTARTUP_INFO pstartup);
|
||||
|
||||
CDECL_END
|
||||
|
||||
#endif /* __ASM__ */
|
||||
|
||||
#endif /* __COMROGUE_INTERNALS__ */
|
||||
|
||||
#endif /* __MEMMGR_H_INCLUDED */
|
||||
@@ -43,6 +43,7 @@
|
||||
#define SYS_PAGE_SIZE 4096 /* standard page size for normal page */
|
||||
#define SYS_PAGE_BITS 12 /* log2(SYS_PAGE_SIZE), number of bits in a page address */
|
||||
#define SYS_TTB0_SIZE 8192 /* TTB0 must be located on this boundary and is this size */
|
||||
#define SYS_TTB0_ENTRIES 2048 /* SYS_TTB0_SIZE/4, number of entries in TTB0 */
|
||||
#define SYS_TTB1_SIZE 16384 /* TTB1 must be located on this boundary and is this size */
|
||||
#define SYS_TTB1_ENTRIES 4096 /* SYS_TTB1_SIZE/4, number of entries in TTB1 */
|
||||
#define SYS_TTB_BITS 12 /* log2(SYS_TTB1_SIZE/4), number of bits in a TTB address */
|
||||
@@ -124,6 +125,16 @@
|
||||
#define PGQUERY_SM 0x00000002 /* small page (4K) */
|
||||
#define PGQUERY_SM_XN 0x00000003 /* small page with Execute-Never set */
|
||||
|
||||
/* Combinations of flags we use regularly. */
|
||||
#define TTBFLAGS_LIB_CODE TTBPGTBL_ALWAYS
|
||||
#define PGTBLFLAGS_LIB_CODE (PGTBLSM_ALWAYS | PGTBLSM_B | PGTBLSM_C | PGTBLSM_AP10)
|
||||
#define TTBFLAGS_KERNEL_CODE TTBPGTBL_ALWAYS
|
||||
#define PGTBLFLAGS_KERNEL_CODE (PGTBLSM_ALWAYS | PGTBLSM_B | PGTBLSM_C | PGTBLSM_AP01)
|
||||
#define TTBFLAGS_KERNEL_DATA TTBPGTBL_ALWAYS
|
||||
#define PGTBLFLAGS_KERNEL_DATA (PGTBLSM_XN | PGTBLSM_ALWAYS | PGTBLSM_B | PGTBLSM_C | PGTBLSM_AP01)
|
||||
#define TTBFLAGS_MMIO TTBPGTBL_ALWAYS
|
||||
#define PGTBLFLAGS_MMIO (PGTBLSM_ALWAYS | PGTBLSM_AP01)
|
||||
|
||||
#ifndef __ASM__
|
||||
|
||||
/*-------------------------------------------------------
|
||||
@@ -224,16 +235,21 @@ typedef struct tagPAGETAB {
|
||||
|
||||
/* internal structure of a MPDB entry */
|
||||
typedef struct tagMPDB1 {
|
||||
PHYSADDR paPTE; /* PA of page table entry for the page */
|
||||
unsigned next : 20; /* index of "next" entry in list */
|
||||
unsigned tag : 12; /* page tag */
|
||||
} MPDB1;
|
||||
|
||||
/* The MPDB entry itself. */
|
||||
typedef union tagMPDB {
|
||||
UINT32 raw; /* raw data */
|
||||
UINT64 raw; /* raw data */
|
||||
MPDB1 d; /* structured data */
|
||||
} MPDB, *PMPDB;
|
||||
|
||||
/* Page index macros */
|
||||
#define mmPA2PageIndex(pa) ((pa) >> SYS_PAGE_BITS)
|
||||
#define mmPageIndex2PA(ndx) ((ndx) << SYS_PAGE_BITS)
|
||||
|
||||
#endif /* __ASM__ */
|
||||
|
||||
#endif /* __COMROGUE_INTERNALS__ */
|
||||
|
||||
@@ -1,3 +1,34 @@
|
||||
/*
|
||||
* 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 __OBJECT_DEFINITION_MACROS_H_INCLUDED
|
||||
#define __OBJECT_DEFINITION_MACROS_H_INCLUDED
|
||||
|
||||
@@ -28,7 +59,7 @@
|
||||
#else
|
||||
|
||||
#define DEFINE_UUID_TYPE(typ, name, l, w1, w2, b1, b2, b3, b4, b5, b6, b7, b8) \
|
||||
EXTERN_C extern const typ GUIDATTR name
|
||||
EXTERN_C extern const typ name
|
||||
|
||||
#endif /* INITGUID */
|
||||
|
||||
@@ -61,11 +92,11 @@
|
||||
#define INHERIT_METHODS(sym) sym
|
||||
|
||||
#define BEGIN_INTERFACE(typ) \
|
||||
struct typ ## VTable; \
|
||||
typedef interface tagIf ## typ { const struct typ ## VTable *pVTable; } typ; \
|
||||
struct typ ## VTable {
|
||||
#define BEGIN_INTERFACE_(typ, parent) \
|
||||
struct typ ## VTable {
|
||||
#define END_INTERFACE(typ) }; \
|
||||
typedef interface typ { const struct typ ## VTable *pVTable; } typ;
|
||||
#define BEGIN_INTERFACE_(typ, parent) BEGIN_INTERFACE(typ)
|
||||
#define END_INTERFACE(typ) };
|
||||
|
||||
#else
|
||||
|
||||
|
||||
56
include/comrogue/objhelp.h
Normal file
56
include/comrogue/objhelp.h
Normal file
@@ -0,0 +1,56 @@
|
||||
/*
|
||||
* 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 __OBJHELP_H_INCLUDED
|
||||
#define __OBJHELP_H_INCLUDED
|
||||
|
||||
#ifndef __ASM__
|
||||
|
||||
#include <comrogue/compiler_macros.h>
|
||||
#include <comrogue/objectbase.h>
|
||||
#include <comrogue/allocator.h>
|
||||
|
||||
CDECL_BEGIN
|
||||
|
||||
/* QueryInterface helpers */
|
||||
extern HRESULT ObjHlpStandardQueryInterface_IMalloc(IUnknown *pThis, REFIID riid, PPVOID ppvObject);
|
||||
|
||||
/* AddRef/Release helpers */
|
||||
extern UINT32 ObjHlpStaticAddRefRelease(IUnknown *pThis);
|
||||
|
||||
/* Other helpers */
|
||||
extern void ObjHlpDoNothingReturnVoid(IUnknown *pThis);
|
||||
|
||||
CDECL_END
|
||||
|
||||
#endif /* __ASM__ */
|
||||
|
||||
#endif /* __OBJHELP_H_INCLUDED */
|
||||
@@ -58,6 +58,7 @@
|
||||
#define FACILITY_ITF 4
|
||||
#define FACILITY_COMROGUE 7
|
||||
#define FACILITY_STRFORMAT 0x333
|
||||
#define FACILITY_MEMMGR 0x601
|
||||
|
||||
#ifndef __ASM__
|
||||
|
||||
@@ -79,19 +80,27 @@
|
||||
|
||||
#endif /* __ASM__ */
|
||||
|
||||
#define S_OK SCODE_CAST(0x00000000) /* OK return */
|
||||
#define S_FALSE SCODE_CAST(0x00000001) /* "False" return */
|
||||
/* Basic success codes */
|
||||
#define S_OK SCODE_CAST(0x00000000) /* OK return */
|
||||
#define S_FALSE SCODE_CAST(0x00000001) /* "False" return */
|
||||
|
||||
#define E_NOTIMPL SCODE_CAST(0x80000001) /* not implemented */
|
||||
#define E_OUTOFMEMORY SCODE_CAST(0x80000002) /* out of memory */
|
||||
#define E_INVALIDARG SCODE_CAST(0x80000003) /* invalid argument */
|
||||
#define E_NOINTERFACE SCODE_CAST(0x80000004) /* no such interface */
|
||||
#define E_POINTER SCODE_CAST(0x80000005) /* invalid pointer */
|
||||
#define E_HANDLE SCODE_CAST(0x80000006) /* invalid handle */
|
||||
#define E_ABORT SCODE_CAST(0x80000007) /* aborted operation */
|
||||
#define E_FAIL SCODE_CAST(0x80000008) /* unspecified failure */
|
||||
#define E_ACCESSDENIED SCODE_CAST(0x80000009) /* access denied */
|
||||
#define E_PENDING SCODE_CAST(0x8000000A) /* data not yet available */
|
||||
#define E_UNEXPECTED SCODE_CAST(0x8000FFFF) /* unexpected error */
|
||||
/* Basic error codes */
|
||||
#define E_NOTIMPL SCODE_CAST(0x80000001) /* not implemented */
|
||||
#define E_OUTOFMEMORY SCODE_CAST(0x80000002) /* out of memory */
|
||||
#define E_INVALIDARG SCODE_CAST(0x80000003) /* invalid argument */
|
||||
#define E_NOINTERFACE SCODE_CAST(0x80000004) /* no such interface */
|
||||
#define E_POINTER SCODE_CAST(0x80000005) /* invalid pointer */
|
||||
#define E_HANDLE SCODE_CAST(0x80000006) /* invalid handle */
|
||||
#define E_ABORT SCODE_CAST(0x80000007) /* aborted operation */
|
||||
#define E_FAIL SCODE_CAST(0x80000008) /* unspecified failure */
|
||||
#define E_ACCESSDENIED SCODE_CAST(0x80000009) /* access denied */
|
||||
#define E_PENDING SCODE_CAST(0x8000000A) /* data not yet available */
|
||||
#define E_UNEXPECTED SCODE_CAST(0x8000FFFF) /* unexpected error */
|
||||
|
||||
/* Memory manager error codes */
|
||||
#define MEMMGR_E_NOPGTBL SCODE_CAST(0x86010001) /* no page tables available */
|
||||
#define MEMMGR_E_BADTTBFLG SCODE_CAST(0x86010002) /* bad TTB flags encountered */
|
||||
#define MEMMGR_E_COLLIDED SCODE_CAST(0x86010003) /* memory mapping collided */
|
||||
#define MEMMGR_E_ENDTTB SCODE_CAST(0x86010004) /* tried to "walk off" end of TTB */
|
||||
|
||||
#endif /* __SCODE_H_INCLUDED */
|
||||
|
||||
51
include/comrogue/stdobj.h
Normal file
51
include/comrogue/stdobj.h
Normal file
@@ -0,0 +1,51 @@
|
||||
/*
|
||||
* 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 __STDOBJ_H_INCLUDED
|
||||
#define __STDOBJ_H_INCLUDED
|
||||
|
||||
#ifndef __ASM__
|
||||
|
||||
#include <comrogue/compiler_macros.h>
|
||||
#include <comrogue/object_types.h>
|
||||
|
||||
CDECL_BEGIN
|
||||
|
||||
extern BOOL IsEqualGUID(REFGUID guid1, REFGUID guid2);
|
||||
|
||||
CDECL_END
|
||||
|
||||
#define IsEqualIID(iid1, iid2) IsEqualGUID(iid1, iid2)
|
||||
#define IsEqualCLSID(clsid1, clsid2) IsEqualGUID(clsid1, clsid2)
|
||||
|
||||
#endif /* __ASM__ */
|
||||
|
||||
#endif /* __STDOBJ_H_INCLUDED */
|
||||
@@ -48,7 +48,9 @@ typedef HRESULT (*PFNFORMAT8)(PPVOID, PCCHAR, UINT32);
|
||||
|
||||
CDECL_BEGIN
|
||||
|
||||
extern PVOID StrCopyMem(PVOID pDest, PCVOID pSrc, INT32 nBytes);
|
||||
extern PVOID StrCopyMem(PVOID pDest, PCVOID pSrc, SSIZE_T cb);
|
||||
extern INT32 StrCompareMem(PCVOID pMem1, PCVOID pMem2, SSIZE_T cb);
|
||||
extern PVOID StrSetMem(PVOID pMem, INT32 ch, SSIZE_T cb);
|
||||
|
||||
extern BOOL StrIsDigit8(CHAR ch);
|
||||
extern INT32 StrLength8(PCSTR psz);
|
||||
|
||||
Reference in New Issue
Block a user