diff options
Diffstat (limited to 'templates/man2/userfaultfd.2.pot')
-rw-r--r-- | templates/man2/userfaultfd.2.pot | 238 |
1 files changed, 28 insertions, 210 deletions
diff --git a/templates/man2/userfaultfd.2.pot b/templates/man2/userfaultfd.2.pot index e20ccd99..f03d619d 100644 --- a/templates/man2/userfaultfd.2.pot +++ b/templates/man2/userfaultfd.2.pot @@ -7,7 +7,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" -"POT-Creation-Date: 2024-03-01 17:12+0100\n" +"POT-Creation-Date: 2024-06-01 06:33+0200\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n" "Language-Team: LANGUAGE <LL@li.org>\n" @@ -24,15 +24,15 @@ msgid "userfaultfd" msgstr "" #. type: TH -#: archlinux fedora-40 fedora-rawhide mageia-cauldron +#: archlinux debian-unstable opensuse-tumbleweed #, no-wrap -msgid "2024-02-12" +msgid "2024-05-02" msgstr "" #. type: TH -#: archlinux fedora-40 fedora-rawhide mageia-cauldron +#: archlinux debian-unstable #, no-wrap -msgid "Linux man-pages 6.06" +msgid "Linux man-pages 6.8" msgstr "" #. type: SH @@ -349,7 +349,7 @@ msgstr "" #. problematic for multi-threaded monitor. I even suspect that it would be #. impossible to ensure synchronization between page faults and non-page #. fault events in multi-threaded monitor. -#. .PP +#. .P #. FIXME elaborate about non-cooperating mode, describe its limitations #. for kernels before Linux 4.11, features added in Linux 4.11 #. and limitations remaining in Linux 4.11 @@ -409,7 +409,7 @@ msgstr "" #. problematic for multi-threaded monitor. I even suspect that it would be #. impossible to ensure synchronization between page faults and non-page #. fault events in multi-threaded monitor. -#. .PP +#. .P #. FIXME elaborate about non-cooperating mode, describe its limitations #. for kernels before Linux 4.11, features added in Linux 4.11 #. and limitations remaining in Linux 4.11 @@ -444,7 +444,8 @@ msgid "Userfaultfd operation" msgstr "" #. type: Plain text -#: archlinux fedora-40 fedora-rawhide mageia-cauldron +#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron +#: opensuse-tumbleweed msgid "" "After the userfaultfd object is created with B<userfaultfd>(), the " "application must enable it using the B<UFFDIO_API> B<ioctl>(2) operation. " @@ -456,7 +457,8 @@ msgid "" msgstr "" #. type: Plain text -#: archlinux fedora-40 fedora-rawhide mageia-cauldron +#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron +#: opensuse-tumbleweed msgid "" "After a successful B<UFFDIO_API> operation, the application then registers " "memory address ranges using the B<UFFDIO_REGISTER> B<ioctl>(2) operation. " @@ -1298,7 +1300,8 @@ msgid "Program source" msgstr "" #. type: Plain text -#: archlinux fedora-40 fedora-rawhide mageia-cauldron +#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron +#: opensuse-tumbleweed #, no-wrap msgid "" "/* userfaultfd_demo.c\n" @@ -1537,7 +1540,7 @@ msgid "Linux man-pages 6.03" msgstr "" #. type: Plain text -#: debian-bookworm debian-unstable opensuse-leap-15-6 opensuse-tumbleweed +#: debian-bookworm opensuse-leap-15-6 msgid "" "After the userfaultfd object is created with B<userfaultfd>(), the " "application must enable it using the B<UFFDIO_API> B<ioctl>(2) operation. " @@ -1548,7 +1551,7 @@ msgid "" msgstr "" #. type: Plain text -#: debian-bookworm debian-unstable opensuse-leap-15-6 opensuse-tumbleweed +#: debian-bookworm opensuse-leap-15-6 msgid "" "After a successful B<UFFDIO_API> operation, the application then registers " "memory address ranges using the B<UFFDIO_REGISTER> B<ioctl>(2) operation. " @@ -2083,212 +2086,21 @@ msgid "" msgstr "" #. type: TH -#: debian-unstable opensuse-tumbleweed +#: fedora-40 fedora-rawhide mageia-cauldron #, no-wrap -msgid "2023-05-03" +msgid "2024-02-12" msgstr "" #. type: TH -#: debian-unstable opensuse-tumbleweed +#: fedora-40 mageia-cauldron #, no-wrap -msgid "Linux man-pages 6.05.01" +msgid "Linux man-pages 6.06" msgstr "" -#. type: Plain text -#: debian-unstable opensuse-tumbleweed +#. type: TH +#: fedora-rawhide #, no-wrap -msgid "" -"/* userfaultfd_demo.c\n" -"\\&\n" -" Licensed under the GNU General Public License version 2 or later.\n" -"*/\n" -"#define _GNU_SOURCE\n" -"#include E<lt>err.hE<gt>\n" -"#include E<lt>errno.hE<gt>\n" -"#include E<lt>fcntl.hE<gt>\n" -"#include E<lt>inttypes.hE<gt>\n" -"#include E<lt>linux/userfaultfd.hE<gt>\n" -"#include E<lt>poll.hE<gt>\n" -"#include E<lt>pthread.hE<gt>\n" -"#include E<lt>stdio.hE<gt>\n" -"#include E<lt>stdlib.hE<gt>\n" -"#include E<lt>string.hE<gt>\n" -"#include E<lt>sys/ioctl.hE<gt>\n" -"#include E<lt>sys/mman.hE<gt>\n" -"#include E<lt>sys/syscall.hE<gt>\n" -"#include E<lt>unistd.hE<gt>\n" -"\\&\n" -"static int page_size;\n" -"\\&\n" -"static void *\n" -"fault_handler_thread(void *arg)\n" -"{\n" -" int nready;\n" -" long uffd; /* userfaultfd file descriptor */\n" -" ssize_t nread;\n" -" struct pollfd pollfd;\n" -" struct uffdio_copy uffdio_copy;\n" -"\\&\n" -" static int fault_cnt = 0; /* Number of faults so far handled */\n" -" static char *page = NULL;\n" -" static struct uffd_msg msg; /* Data read from userfaultfd */\n" -"\\&\n" -" uffd = (long) arg;\n" -"\\&\n" -" /* Create a page that will be copied into the faulting region. */\n" -"\\&\n" -" if (page == NULL) {\n" -" page = mmap(NULL, page_size, PROT_READ | PROT_WRITE,\n" -" MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);\n" -" if (page == MAP_FAILED)\n" -" err(EXIT_FAILURE, \"mmap\");\n" -" }\n" -"\\&\n" -" /* Loop, handling incoming events on the userfaultfd\n" -" file descriptor. */\n" -"\\&\n" -" for (;;) {\n" -"\\&\n" -" /* See what poll() tells us about the userfaultfd. */\n" -"\\&\n" -" pollfd.fd = uffd;\n" -" pollfd.events = POLLIN;\n" -" nready = poll(&pollfd, 1, -1);\n" -" if (nready == -1)\n" -" err(EXIT_FAILURE, \"poll\");\n" -"\\&\n" -" printf(\"\\enfault_handler_thread():\\en\");\n" -" printf(\" poll() returns: nready = %d; \"\n" -" \"POLLIN = %d; POLLERR = %d\\en\", nready,\n" -" (pollfd.revents & POLLIN) != 0,\n" -" (pollfd.revents & POLLERR) != 0);\n" -"\\&\n" -" /* Read an event from the userfaultfd. */\n" -"\\&\n" -" nread = read(uffd, &msg, sizeof(msg));\n" -" if (nread == 0) {\n" -" printf(\"EOF on userfaultfd!\\en\");\n" -" exit(EXIT_FAILURE);\n" -" }\n" -"\\&\n" -" if (nread == -1)\n" -" err(EXIT_FAILURE, \"read\");\n" -"\\&\n" -" /* We expect only one kind of event; verify that assumption. */\n" -"\\&\n" -" if (msg.event != UFFD_EVENT_PAGEFAULT) {\n" -" fprintf(stderr, \"Unexpected event on userfaultfd\\en\");\n" -" exit(EXIT_FAILURE);\n" -" }\n" -"\\&\n" -" /* Display info about the page-fault event. */\n" -"\\&\n" -" printf(\" UFFD_EVENT_PAGEFAULT event: \");\n" -" printf(\"flags = %\"PRIx64\"; \", msg.arg.pagefault.flags);\n" -" printf(\"address = %\"PRIx64\"\\en\", msg.arg.pagefault.address);\n" -"\\&\n" -" /* Copy the page pointed to by \\[aq]page\\[aq] into the faulting\n" -" region. Vary the contents that are copied in, so that it\n" -" is more obvious that each fault is handled separately. */\n" -"\\&\n" -" memset(page, \\[aq]A\\[aq] + fault_cnt % 20, page_size);\n" -" fault_cnt++;\n" -"\\&\n" -" uffdio_copy.src = (unsigned long) page;\n" -"\\&\n" -" /* We need to handle page faults in units of pages(!).\n" -" So, round faulting address down to page boundary. */\n" -"\\&\n" -" uffdio_copy.dst = (unsigned long) msg.arg.pagefault.address &\n" -" \\[ti](page_size - 1);\n" -" uffdio_copy.len = page_size;\n" -" uffdio_copy.mode = 0;\n" -" uffdio_copy.copy = 0;\n" -" if (ioctl(uffd, UFFDIO_COPY, &uffdio_copy) == -1)\n" -" err(EXIT_FAILURE, \"ioctl-UFFDIO_COPY\");\n" -"\\&\n" -" printf(\" (uffdio_copy.copy returned %\"PRId64\")\\en\",\n" -" uffdio_copy.copy);\n" -" }\n" -"}\n" -"\\&\n" -"int\n" -"main(int argc, char *argv[])\n" -"{\n" -" int s;\n" -" char c;\n" -" char *addr; /* Start of region handled by userfaultfd */\n" -" long uffd; /* userfaultfd file descriptor */\n" -" size_t len, l; /* Length of region handled by userfaultfd */\n" -" pthread_t thr; /* ID of thread that handles page faults */\n" -" struct uffdio_api uffdio_api;\n" -" struct uffdio_register uffdio_register;\n" -"\\&\n" -" if (argc != 2) {\n" -" fprintf(stderr, \"Usage: %s num-pages\\en\", argv[0]);\n" -" exit(EXIT_FAILURE);\n" -" }\n" -"\\&\n" -" page_size = sysconf(_SC_PAGE_SIZE);\n" -" len = strtoull(argv[1], NULL, 0) * page_size;\n" -"\\&\n" -" /* Create and enable userfaultfd object. */\n" -"\\&\n" -" uffd = syscall(SYS_userfaultfd, O_CLOEXEC | O_NONBLOCK);\n" -" if (uffd == -1)\n" -" err(EXIT_FAILURE, \"userfaultfd\");\n" -"\\&\n" -" uffdio_api.api = UFFD_API;\n" -" uffdio_api.features = 0;\n" -" if (ioctl(uffd, UFFDIO_API, &uffdio_api) == -1)\n" -" err(EXIT_FAILURE, \"ioctl-UFFDIO_API\");\n" -"\\&\n" -" /* Create a private anonymous mapping. The memory will be\n" -" demand-zero paged--that is, not yet allocated. When we\n" -" actually touch the memory, it will be allocated via\n" -" the userfaultfd. */\n" -"\\&\n" -" addr = mmap(NULL, len, PROT_READ | PROT_WRITE,\n" -" MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);\n" -" if (addr == MAP_FAILED)\n" -" err(EXIT_FAILURE, \"mmap\");\n" -"\\&\n" -" printf(\"Address returned by mmap() = %p\\en\", addr);\n" -"\\&\n" -" /* Register the memory range of the mapping we just created for\n" -" handling by the userfaultfd object. In mode, we request to track\n" -" missing pages (i.e., pages that have not yet been faulted in). */\n" -"\\&\n" -" uffdio_register.range.start = (unsigned long) addr;\n" -" uffdio_register.range.len = len;\n" -" uffdio_register.mode = UFFDIO_REGISTER_MODE_MISSING;\n" -" if (ioctl(uffd, UFFDIO_REGISTER, &uffdio_register) == -1)\n" -" err(EXIT_FAILURE, \"ioctl-UFFDIO_REGISTER\");\n" -"\\&\n" -" /* Create a thread that will process the userfaultfd events. */\n" -"\\&\n" -" s = pthread_create(&thr, NULL, fault_handler_thread, (void *) uffd);\n" -" if (s != 0) {\n" -" errc(EXIT_FAILURE, s, \"pthread_create\");\n" -" }\n" -"\\&\n" -" /* Main thread now touches memory in the mapping, touching\n" -" locations 1024 bytes apart. This will trigger userfaultfd\n" -" events for all pages in the region. */\n" -"\\&\n" -" l = 0xf; /* Ensure that faulting address is not on a page\n" -" boundary, in order to test that we correctly\n" -" handle that case in fault_handling_thread(). */\n" -" while (l E<lt> len) {\n" -" c = addr[l];\n" -" printf(\"Read address %p in %s(): \", addr + l, __func__);\n" -" printf(\"%c\\en\", c);\n" -" l += 1024;\n" -" usleep(100000); /* Slow things down a little */\n" -" }\n" -"\\&\n" -" exit(EXIT_SUCCESS);\n" -"}\n" +msgid "Linux man-pages 6.7" msgstr "" #. type: TH @@ -2302,3 +2114,9 @@ msgstr "" #, no-wrap msgid "Linux man-pages 6.04" msgstr "" + +#. type: TH +#: opensuse-tumbleweed +#, no-wrap +msgid "Linux man-pages (unreleased)" +msgstr "" |