I have a large buffer:
char *buf = malloc(1000000000); // 1GB
If I forked a new process, it would have a buf which shared memory with the parent's buf until one or the other wrote to it. Even then, only one new 4KiB block would need to be allocated by the kernel, the rest would continue to be shared.
I'd like to make a copy of buf, but I'm only going to change a little of the copy. I'd like copy-on-write behaviour without forking. (Like you get for free when forking.)
Is this possible?
You'll want to create a file on disk or a POSIX shared memory segment (
shm_open
) for the block. The first time, map it withMAP_SHARED
. When you're ready to make a copy and switch to COW, callmmap
again withMAP_FIXED
andMAP_PRIVATE
to map over top of your original map, and withMAP_PRIVATE
to make the second copy. This should get you the effects you want.