|
XenevaOS
|
#include <Mm/shm.h>#include <Mm/kmalloc.h>#include <Mm/pmmngr.h>#include <Mm/vmmngr.h>#include <list.h>#include <Hal/AA64/aa64lowlevel.h>#include <aucon.h>#include <_null.h>#include <string.h>#include <stdint.h>
Functions | |
| void | AuInitialiseSHMMan () |
| AuInitialiseSHMMan – initialise shm manager. | |
| uint16_t | AuSHMGetID () |
| AuSHMGetID – allocate a new shared memory id. | |
| AuSHM * | AuGetSHMSeg (uint16_t key) |
| AuGetSHMSeg – searches and return a shm segment by its key. | |
| AuSHM * | AuGetSHMByID (uint16_t id) |
| AuGetSHMSeg – searches and return a shm segment by its key. | |
| int | AuCreateSHM (AuProcess *proc, uint16_t key, size_t sz, uint8_t flags) |
| AuCreateSHM – create a new shared memory segment or returns previously allocated one. | |
| void | AuSHMDelete (AuSHM *shm) |
| AuSHMDelete – removes a SHM Segment from system shm list. | |
| size_t | AuSHMProcBreak (AuProcess *proc, size_t num_frames) |
| AuSHMProcBreak – gets some available shm memory and increase the break count. | |
| void | AuSHMProcSwap (dataentry *current, dataentry *index) |
| AuSHMProcSwap – Swaps data between list entry. | |
| void | AuSHMProcOrderList (AuProcess *proc) |
| void | envmdebug () |
| void * | AuSHMObtainMem (AuProcess *proc, uint16_t id, void *shmaddr, int shmflg) |
| AuSHMObtainMem – obtains a virtual memory from given shm segment. | |
| void | AuSHMUnmap (uint16_t key, AuProcess *proc) |
| AuSHMUnmap – unmaps a shared memory segment. | |
| void | AuSHMUnmapAll (AuProcess *proc) |
| AuSHMUnmapAll – unmaps all mappings for this process. | |
BSD 2-Clause License
Copyright (c) 2022-2023, Manas Kamal Choudhury All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
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.
AuCreateSHM – create a new shared memory segment or returns previously allocated one.
| proc | – Creator process |
| key | – unique key to use |
| sz | – size in multiple of PAGE_SIZE |
| flags | – security flags |
AuGetSHMSeg – searches and return a shm segment by its key.
| key | – key to search |
AuGetSHMSeg – searches and return a shm segment by its key.
| key | – key to search |
| void AuInitialiseSHMMan | ( | ) |
AuInitialiseSHMMan – initialise shm manager.
| void AuSHMDelete | ( | AuSHM * | shm | ) |
AuSHMDelete – removes a SHM Segment from system shm list.
| shm | – segment to delete |
| uint16_t AuSHMGetID | ( | ) |
AuSHMGetID – allocate a new shared memory id.
AuSHMObtainMem – obtains a virtual memory from given shm segment.
| proc | – Calling process |
| id | – shm segment id |
| shmaddr | – starting shared memory address to map @parma shmflg – flags |
AuSHMProcBreak – gets some available shm memory and increase the break count.
| proc | – Process to look |
| num_frames | – number of frames to increase |
| void AuSHMProcOrderList | ( | AuProcess * | proc | ) |
AuSHMProcSwap – Swaps data between list entry.
AuSHMUnmap – unmaps a shared memory segment.
| key | – key to search |
| proc | – process to look |
| void AuSHMUnmapAll | ( | AuProcess * | proc | ) |
AuSHMUnmapAll – unmaps all mappings for this process.
| proc | – Pointer to process that needs unmapping |
|
extern |