lib: utils: Add simple FDT based HSM driver framework

The generic platform can have multiple HSM drivers so add a simple
FDT based HSM driver framework.

Signed-off-by: Anup Patel <apatel@ventanamicro.com>
This commit is contained in:
Anup Patel
2024-08-06 10:45:11 +05:30
committed by Anup Patel
parent 9d760b810e
commit ff4769bf08
8 changed files with 77 additions and 0 deletions

10
lib/utils/hsm/Kconfig Normal file
View File

@@ -0,0 +1,10 @@
# SPDX-License-Identifier: BSD-2-Clause
menu "HSM Device Support"
config FDT_HSM
bool "FDT based HSM drivers"
depends on FDT
default n
endmenu

22
lib/utils/hsm/fdt_hsm.c Normal file
View File

@@ -0,0 +1,22 @@
/*
* SPDX-License-Identifier: BSD-2-Clause
*
* Copyright (c) 2024 Ventana Micro Systems Inc.
*
* Authors:
* Anup Patel <apatel@ventanamicro.com>
*/
#include <sbi_utils/hsm/fdt_hsm.h>
/* List of FDT HSM drivers generated at compile time */
extern const struct fdt_driver *const fdt_hsm_drivers[];
void fdt_hsm_init(const void *fdt)
{
/*
* Platforms might have multiple HSM devices or might
* not have any so probe all and don't fail.
*/
fdt_driver_init_all(fdt, fdt_hsm_drivers);
}

View File

@@ -0,0 +1,3 @@
HEADER: sbi_utils/hsm/fdt_hsm.h
TYPE: const struct fdt_driver
NAME: fdt_hsm_drivers

11
lib/utils/hsm/objects.mk Normal file
View File

@@ -0,0 +1,11 @@
#
# SPDX-License-Identifier: BSD-2-Clause
#
# Copyright (c) 2024 Ventana Micro Systems Inc.
#
# Authors:
# Anup Patel <apatel@ventanamicro.com>
#
libsbiutils-objs-$(CONFIG_FDT_HSM) += hsm/fdt_hsm.o
libsbiutils-objs-$(CONFIG_FDT_HSM) += hsm/fdt_hsm_drivers.carray.o