Scroll to navigation

ZCRYPTCTL(8) System Manager's Manual ZCRYPTCTL(8)

NAME

zcryptctl - display information and administrate zcrypt multiple device nodes

SYNOPSIS

[ node-name ]
node-name
| delap node-name adapter-nr
| deldom node-name domain-nr
| delctrl node-name domain-nr
| delioctl node-name ioctl-term
config-file

DESCRIPTION

The zcryptctl command displays information and maintains the multi device node extension for the zcrypt device driver.

With the multi device node extension you can create and configure additional zcrypt device nodes which can be used as alternate device nodes to access the crypto hardware provided by the zcrypt device driver. Each zcrypt device node can be restricted in terms of crypto cards, domains, and available ioctls. Such a device node can be used as a base for container solutions like Docker to control and restrict the access to crypto resources. See the NOTES section below for information on control domains.

COMMANDS

Show all the additional device nodes that are currently active.
[ node-name ] Create a new zcrypt device node. The node-name might be given and needs to be unique and not in use. If there is no node name provided, the zcrypt device driver will create a new one with pattern zcrypt_x, with x being the next free number. Up to 256 additional device nodes can be created. The newly created additional device node appears in /dev and has read and write permissions enabled only for root. By default all adapters, domains and ioctls are initially disabled on this new device node.
node-name Destroy an additional zcrypt device node. The device node is only marked for disposal and destroyed when it is no longer used.
| delap node-name adapter-nr Update the filter for the specified zcrypt device node and add or delete a crypto adapter to be accessible via this node. The symbol ALL can be used to enable or disable all adapters.
| deldom node-name domain-nr Update the filter for the specified zcrypt device node and add or delete a domain to be accessible through this node. The symbol ALL can be used to enable or disable all domains.
| delctrl node-name domain-nr Update the filter for the specified zcrypt device node and add or delete a control domain to be accessible through this node. The symbol ALL can be used to enable or disable all domains.
| delioctl node-name ioctl-term Update the filter for the specified zcrypt device node and add or delete an ioctl. The ioctl might be specified as symbolic string (one of ICARSAMODEXPO, ICARSACRT, ZSECSENDCPRB, ZSENDEP11CPRB, ZCRYPT_DEVICE_STATUS, ZCRYPT_STATUS_MASK, ZCRYPT_QDEPTH_MASK, ZCRYPT_PERDEV_REQCNT) or numeric value in the range 0-255 and the symbol ALL can be used to include all ioctls.
config-file Process a config file. The given configuration file is read line by line and the settings are applied. Syntax is simple:

Empty lines are ignored and the '#' marks the rest of the line as comment.

The node= line creates a new zcrypt device node, the aps=, doms=, ctrls= and ioctls= lines customize the previously created node. The symbol ALL is also recognized for aps, doms, and ioctls.

Each action must fit into one line, spreading over multiple lines is not supported. But you can use more than one aps=, doms=, ctrls= and ioctls= lines to customize the very same node.

Processing stops when a line cannot be parsed or the current action fails. In this case the exit status is non zero but the successful actions until the failure occurs are not rolled back.

List the current configuration in a form suitable for input to the zcryptctl config command.

NOTES

Control domain filtering is only supported for custom device <nodename> if the admask file in sysfs under /sys/class/zcrypt/<nodename>/admask exists. If this file does not exist, the kernel is too old and does not support control command filtering. This is the same effect as setting the control domain mask to ALL. Note that, even though you can allow more than available to the system, you can only send control commands to control domains available to the system.

EXIT STATUS

On successful completion of the command the exit status is 0. A non zero return code (and some kind of failure message) is emitted if the processing could not complete successful.

SEE ALSO

lszcrypt(8)

JAN 2022 s390-tools