[PATCH 3/4] um: add mmap/mremap/munmap OS calls
Anton Ivanov
anton.ivanov at kot-begemot.co.uk
Fri Nov 10 12:40:24 PST 2023
On 10/11/2023 18:52, Johannes Berg wrote:
> From: Johannes Berg <johannes.berg at intel.com>
>
> For the upcoming shared-memory time-travel external
> optimisations, we need to be able to mmap/mremap
> (and on error munmap). Add the necessary OS calls.
>
> Signed-off-by: Johannes Berg <johannes.berg at intel.com>
> ---
> arch/um/include/shared/os.h | 3 +++
> arch/um/os-Linux/file.c | 28 ++++++++++++++++++++++++++++
> 2 files changed, 31 insertions(+)
>
> diff --git a/arch/um/include/shared/os.h b/arch/um/include/shared/os.h
> index 4fbe574eff4c..1a82c6548dd5 100644
> --- a/arch/um/include/shared/os.h
> +++ b/arch/um/include/shared/os.h
> @@ -180,6 +180,9 @@ extern int os_eventfd(unsigned int initval, int flags);
> extern int os_sendmsg_fds(int fd, const void *buf, unsigned int len,
> const int *fds, unsigned int fds_num);
> int os_poll(unsigned int n, const int *fds);
> +void *os_mmap_rw_shared(int fd, size_t size);
> +void *os_mremap_rw_shared(void *old_addr, size_t old_size, size_t new_size);
> +void os_munmap(void *addr, size_t size);
>
> /* start_up.c */
> extern void os_early_checks(void);
> diff --git a/arch/um/os-Linux/file.c b/arch/um/os-Linux/file.c
> index c972dfeab9a3..c482850f27d8 100644
> --- a/arch/um/os-Linux/file.c
> +++ b/arch/um/os-Linux/file.c
> @@ -17,6 +17,7 @@
> #include <sys/stat.h>
> #include <sys/sysmacros.h>
> #include <sys/un.h>
> +#include <sys/mman.h>
> #include <sys/types.h>
> #include <sys/eventfd.h>
> #include <poll.h>
> @@ -708,3 +709,30 @@ int os_poll(unsigned int n, const int *fds)
>
> return -EIO;
> }
> +
> +void *os_mmap_rw_shared(int fd, size_t size)
> +{
> + void *res = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
> +
> + if (res == MAP_FAILED)
> + return NULL;
> +
> + return res;
> +}
> +
> +void *os_mremap_rw_shared(void *old_addr, size_t old_size, size_t new_size)
> +{
> + void *res;
> +
> + res = mremap(old_addr, old_size, new_size, MREMAP_MAYMOVE, NULL);
> +
> + if (res == MAP_FAILED)
> + return NULL;
> +
> + return res;
> +}
> +
> +void os_munmap(void *addr, size_t size)
> +{
> + munmap(addr, size);
> +}
os_munmap already exists as os_munmap_memory
The other two are OK.
--
Anton R. Ivanov
https://www.kot-begemot.co.uk/
More information about the linux-um
mailing list