posixshmcontrol —
    Control POSIX shared memory segments
  
    | posixshmcontrol | create [ -lpagesize] [-mmode] [path ...] | 
  
    | posixshmcontrol | rm [path ...] | 
  
    | posixshmcontrol | ls [ -h]
      [-n] [-jjail] | 
  
    | posixshmcontrol | dump [path ...] | 
  
    | posixshmcontrol | stat [ -h]
      [-n] [path ...] | 
  
    | posixshmcontrol | truncate [ -slength] [path ...] | 
The posixshmcontrol command manipulates
    the named POSIX shared memory segments. It allows inspecting existing
    segments, dumping their metadata or contents, and unlinking them.
Unlinking removes the name from the system and, when the last
    process unmaps the segment and closes file descriptor pointing to the
    segment, frees underlying memory.
The number of hard links as displayed by the
    stat subcommand, is equal to the number of
    references to the underlying VM object. It is almost always equal to the
    number of mappings +1, except for transient references.
The following subcommands are provided:
  - create
- Create segments with the specified paths, if they do not already exist.
    The optional pagesize argument specifies
        the size of the virtual pages used to map the object with
        mmap(2).
        By default, the system page size is used, but on some platforms a larger
        page size can be specified. The size of an object backed by large pages
        must be a multiple of the specified page size. The
        hw.pagesizes sysctl variable lists the available
        page sizes. The optional numerical mode argument
        specifies the initial access mode. 
- rm
- Unlink the paths specified.
- ls
- List all linked named shared memory segments visible to the caller. For
      each segment, the user and group owner, size, and path are displayed. The
      -joption limits the output to segments within the
      specified jail name or id.
- dump
- Output raw bytes values from the segment to standard output.
- stat
- Print metadata for the specified path, in the format similar to the
      stat(1)
      utility.
- truncate
- Change the length of the segments. Argument to the
      -soption specifies new length. The human-friendly
      'k', 'm', 'g' suffixes can be used, see
      expand_number(3).
      If the option is not specified, assumed length is zero.
For some commands, the following options may be provided:
  - -h
- If specified, requests human-readable display of size, see
      humanize_number(3).
- -n
- Prevent translation of owner and group into symbolic names using
      name-switch services, instead the raw numeric values are printed.
The posixshmcontrol utility exits 0
    on success, and >0 if an error occurs.
  - To show content of the shared memory segment with the path
      /1, use the command
    posixshmcontrol dump /1 | hexdump
      -C
 
- To create a segment with the path /2 and then
      enlarge it to 1M, use the sequence of commands
    posixshmcontrol create
      /2
 posixshmcontrol truncate -s 1m
      /2
 
hexdump(1),
    stat(1),
    ftruncate(2),
    mmap(2),
    read(2),
    shm_open(2),
    shm_unlink(2),
    stat(2),
    expand_number(3),
    humanize_number(3),
    shm_create_largepage(3),
    sysctl(3)
The posixshmcontrol command appeared in
    FreeBSD 12.1.
The posixshmcontrol command and this
    manual page were written by Konstantin Belousov
    <kib@freebsd.org>
    under sponsorship from The FreeBSD Foundation.