# Copyright 2017 syzkaller project authors. All rights reserved. # Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file. # AF_NETLINK/NETLINK_CRYPTO support. include <linux/net.h> include <linux/crypto.h> include <uapi/linux/netlink.h> include <uapi/linux/cryptouser.h> resource sock_nl_crypto[sock_netlink] socket$nl_crypto(domain const[AF_NETLINK], type const[SOCK_RAW], proto const[NETLINK_CRYPTO]) sock_nl_crypto sendmsg$nl_crypto(fd sock_nl_crypto, msg ptr[in, msghdr_nl_crypto], f flags[send_flags]) type msghdr_nl_crypto msghdr_netlink[netlink_msg_crypto] netlink_msg_crypto [ alg netlink_msg[CRYPTO_MSG_NEWALG, crypto_user_alg, netlink_crypto_attrs] del netlink_msg[CRYPTO_MSG_DELALG, crypto_user_alg, netlink_crypto_attrs] upd netlink_msg[CRYPTO_MSG_UPDATEALG, crypto_user_alg, netlink_crypto_attrs] get netlink_msg[CRYPTO_MSG_GETALG, crypto_user_alg, netlink_crypto_attrs] delrng netlink_msg[CRYPTO_MSG_DELRNG, void, void] ] [varlen] type netlink_crypto_attrs nlattr[CRYPTOCFGA_PRIORITY_VAL, int32] crypto_user_alg { cru_name alg_name # TODO: generate driver names. cru_driver_name array[const[0, int8], CRYPTO_MAX_NAME] cru_module_name array[const[0, int8], CRYPTO_MAX_NAME] cru_type flags[crypto_user_alg_flags, int32] cru_mask flags[crypto_user_alg_flags, int32] cru_refcnt const[0, int32] cru_flags const[0, int32] } crypto_user_alg_flags = CRYPTO_ALG_TESTED, CRYPTO_ALG_INTERNAL