xref: /kernel/linux/linux-6.6/drivers/crypto/ccp/dbc.h (revision 62306a36)
162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * AMD Platform Security Processor (PSP) Dynamic Boost Control support
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2023 Advanced Micro Devices, Inc.
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * Author: Mario Limonciello <mario.limonciello@amd.com>
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#ifndef __DBC_H__
1162306a36Sopenharmony_ci#define __DBC_H__
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include <uapi/linux/psp-dbc.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci#include <linux/device.h>
1662306a36Sopenharmony_ci#include <linux/miscdevice.h>
1762306a36Sopenharmony_ci#include <linux/psp-platform-access.h>
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci#include "psp-dev.h"
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_cistruct psp_dbc_device {
2262306a36Sopenharmony_ci	struct device *dev;
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci	union dbc_buffer *mbox;
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	struct mutex ioctl_mutex;
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci	struct miscdevice char_dev;
2962306a36Sopenharmony_ci};
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_cistruct dbc_nonce {
3262306a36Sopenharmony_ci	struct psp_req_buffer_hdr	header;
3362306a36Sopenharmony_ci	struct dbc_user_nonce		user;
3462306a36Sopenharmony_ci} __packed;
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_cistruct dbc_set_uid {
3762306a36Sopenharmony_ci	struct psp_req_buffer_hdr	header;
3862306a36Sopenharmony_ci	struct dbc_user_setuid		user;
3962306a36Sopenharmony_ci} __packed;
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_cistruct dbc_param {
4262306a36Sopenharmony_ci	struct psp_req_buffer_hdr	header;
4362306a36Sopenharmony_ci	struct dbc_user_param		user;
4462306a36Sopenharmony_ci} __packed;
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ciunion dbc_buffer {
4762306a36Sopenharmony_ci	struct psp_request		req;
4862306a36Sopenharmony_ci	struct dbc_nonce		dbc_nonce;
4962306a36Sopenharmony_ci	struct dbc_set_uid		dbc_set_uid;
5062306a36Sopenharmony_ci	struct dbc_param		dbc_param;
5162306a36Sopenharmony_ci};
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_civoid dbc_dev_destroy(struct psp_device *psp);
5462306a36Sopenharmony_ciint dbc_dev_init(struct psp_device *psp);
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ci#endif /* __DBC_H */
57