| /* | 
 |  * AMD Platform Security Processor (PSP) interface driver | 
 |  * | 
 |  * Copyright (C) 2017 Advanced Micro Devices, Inc. | 
 |  * | 
 |  * Author: Brijesh Singh <brijesh.singh@amd.com> | 
 |  * | 
 |  * This program is free software; you can redistribute it and/or modify | 
 |  * it under the terms of the GNU General Public License version 2 as | 
 |  * published by the Free Software Foundation. | 
 |  */ | 
 |  | 
 | #ifndef __PSP_DEV_H__ | 
 | #define __PSP_DEV_H__ | 
 |  | 
 | #include <linux/device.h> | 
 | #include <linux/pci.h> | 
 | #include <linux/spinlock.h> | 
 | #include <linux/mutex.h> | 
 | #include <linux/list.h> | 
 | #include <linux/wait.h> | 
 | #include <linux/dmapool.h> | 
 | #include <linux/hw_random.h> | 
 | #include <linux/bitops.h> | 
 | #include <linux/interrupt.h> | 
 | #include <linux/irqreturn.h> | 
 | #include <linux/dmaengine.h> | 
 | #include <linux/psp-sev.h> | 
 | #include <linux/miscdevice.h> | 
 |  | 
 | #include "sp-dev.h" | 
 |  | 
 | #define PSP_CMD_COMPLETE		BIT(1) | 
 |  | 
 | #define PSP_CMDRESP_CMD_SHIFT		16 | 
 | #define PSP_CMDRESP_IOC			BIT(0) | 
 | #define PSP_CMDRESP_RESP		BIT(31) | 
 | #define PSP_CMDRESP_ERR_MASK		0xffff | 
 |  | 
 | #define MAX_PSP_NAME_LEN		16 | 
 |  | 
 | struct sev_misc_dev { | 
 | 	struct kref refcount; | 
 | 	struct miscdevice misc; | 
 | }; | 
 |  | 
 | struct psp_device { | 
 | 	struct list_head entry; | 
 |  | 
 | 	struct psp_vdata *vdata; | 
 | 	char name[MAX_PSP_NAME_LEN]; | 
 |  | 
 | 	struct device *dev; | 
 | 	struct sp_device *sp; | 
 |  | 
 | 	void __iomem *io_regs; | 
 |  | 
 | 	int sev_state; | 
 | 	unsigned int sev_int_rcvd; | 
 | 	wait_queue_head_t sev_int_queue; | 
 | 	struct sev_misc_dev *sev_misc; | 
 | 	struct sev_user_data_status status_cmd_buf; | 
 | 	struct sev_data_init init_cmd_buf; | 
 |  | 
 | 	u8 api_major; | 
 | 	u8 api_minor; | 
 | 	u8 build; | 
 | }; | 
 |  | 
 | #endif /* __PSP_DEV_H */ |