mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-03 21:48:15 +00:00 
			
		
		
		
	At the moment, we don't have a common API for working with SM, only the smc_call() function. This approach is not generic and difficult to configure and maintain. This patch adds UCLASS_SM with the generic API: - sm_call() - sm_call_write() - sm_call_read() These functions operate with struct pt_regs, which describes Secure Monitor arguments. Signed-off-by: Alexey Romanov <avromanov@salutedevices.com> Reviewed-by: Simon Glass <sjg@chromium.org> Link: https://lore.kernel.org/r/20230921081346.22157-2-avromanov@salutedevices.com Signed-off-by: Neil Armstrong <neil.armstrong@linaro.org>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0+
 | 
						|
/*
 | 
						|
 * Copyright (c) 2023 SberDevices, Inc.
 | 
						|
 *
 | 
						|
 * Author: Alexey Romanov <avromanov@salutedevices.com>
 | 
						|
 */
 | 
						|
 | 
						|
#include <common.h>
 | 
						|
#include <dm.h>
 | 
						|
#include <errno.h>
 | 
						|
#include <sm-uclass.h>
 | 
						|
 | 
						|
static const struct sm_ops *get_sm_ops(struct udevice *dev)
 | 
						|
{
 | 
						|
	return (const struct sm_ops *)dev->driver->ops;
 | 
						|
}
 | 
						|
 | 
						|
int sm_call(struct udevice *dev, u32 cmd, s32 *ret, struct pt_regs *args)
 | 
						|
{
 | 
						|
	const struct sm_ops *ops = get_sm_ops(dev);
 | 
						|
 | 
						|
	if (ops->sm_call)
 | 
						|
		return ops->sm_call(dev, cmd, ret, args);
 | 
						|
 | 
						|
	return -ENOSYS;
 | 
						|
}
 | 
						|
 | 
						|
int sm_call_read(struct udevice *dev, void *buffer, size_t size,
 | 
						|
		 u32 cmd, struct pt_regs *args)
 | 
						|
{
 | 
						|
	const struct sm_ops *ops = get_sm_ops(dev);
 | 
						|
 | 
						|
	if (ops->sm_call_read)
 | 
						|
		return ops->sm_call_read(dev, buffer, size, cmd,
 | 
						|
					 args);
 | 
						|
 | 
						|
	return -ENOSYS;
 | 
						|
}
 | 
						|
 | 
						|
int sm_call_write(struct udevice *dev, void *buffer, size_t size,
 | 
						|
		   u32 cmd, struct pt_regs *args)
 | 
						|
{
 | 
						|
	const struct sm_ops *ops = get_sm_ops(dev);
 | 
						|
 | 
						|
	if (ops->sm_call_write)
 | 
						|
		return ops->sm_call_write(dev, buffer, size, cmd,
 | 
						|
					  args);
 | 
						|
 | 
						|
	return -ENOSYS;
 | 
						|
}
 | 
						|
 | 
						|
UCLASS_DRIVER(sm) = {
 | 
						|
	.name           = "sm",
 | 
						|
	.id             = UCLASS_SM,
 | 
						|
};
 |