mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-20 04:24:13 +00:00
706add1367
The keyring and auth functions can be called from both the host and the target side and are controlled by Kconfig options for each of the combinations, but the declarations are controlled by #ifdef checks on the shared Kconfig symbols. This leads to link failures in combinations where one of the frontends is built-in and the other one is a module, and the keyring code ends up in a module that is not reachable from the builtin code: ld: drivers/nvme/host/core.o: in function `nvme_core_exit': core.c:(.exit.text+0x4): undefined reference to `nvme_keyring_exit' ld: drivers/nvme/host/core.o: in function `nvme_core_init': core.c:(.init.text+0x94): undefined reference to `nvme_keyring_init ld: drivers/nvme/host/tcp.o: in function `nvme_tcp_setup_ctrl': tcp.c:(.text+0x4c18): undefined reference to `nvme_tls_psk_default' Address this by moving nvme_keyring_init()/nvme_keyring_exit() into module init/exit functions for the keyring module. Fixes: be8e82caa6859 ("nvme-tcp: enable TLS handshake upcall") Signed-off-by: Hannes Reinecke <hare@suse.de> Cc: Arnd Bergmann <arnd@arndb.de> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Keith Busch <kbusch@kernel.org>
29 lines
580 B
C
29 lines
580 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2023 Hannes Reinecke, SUSE Labs
|
|
*/
|
|
|
|
#ifndef _NVME_KEYRING_H
|
|
#define _NVME_KEYRING_H
|
|
|
|
#if IS_ENABLED(CONFIG_NVME_KEYRING)
|
|
|
|
key_serial_t nvme_tls_psk_default(struct key *keyring,
|
|
const char *hostnqn, const char *subnqn);
|
|
|
|
key_serial_t nvme_keyring_id(void);
|
|
|
|
#else
|
|
|
|
static inline key_serial_t nvme_tls_psk_default(struct key *keyring,
|
|
const char *hostnqn, const char *subnqn)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline key_serial_t nvme_keyring_id(void)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif /* !CONFIG_NVME_KEYRING */
|
|
#endif /* _NVME_KEYRING_H */
|