67 lines
1.5 KiB
C
67 lines
1.5 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/*
|
||
|
* AMD HSMP Platform Driver
|
||
|
* Copyright (c) 2024, AMD.
|
||
|
* All Rights Reserved.
|
||
|
*
|
||
|
* Header file for HSMP driver
|
||
|
*/
|
||
|
|
||
|
#ifndef HSMP_H
|
||
|
#define HSMP_H
|
||
|
|
||
|
#include <linux/compiler_types.h>
|
||
|
#include <linux/device.h>
|
||
|
#include <linux/miscdevice.h>
|
||
|
#include <linux/pci.h>
|
||
|
#include <linux/semaphore.h>
|
||
|
#include <linux/sysfs.h>
|
||
|
|
||
|
#define HSMP_METRICS_TABLE_NAME "metrics_bin"
|
||
|
|
||
|
#define HSMP_ATTR_GRP_NAME_SIZE 10
|
||
|
|
||
|
#define MAX_AMD_SOCKETS 8
|
||
|
|
||
|
#define HSMP_CDEV_NAME "hsmp_cdev"
|
||
|
#define HSMP_DEVNODE_NAME "hsmp"
|
||
|
|
||
|
struct hsmp_mbaddr_info {
|
||
|
u32 base_addr;
|
||
|
u32 msg_id_off;
|
||
|
u32 msg_resp_off;
|
||
|
u32 msg_arg_off;
|
||
|
u32 size;
|
||
|
};
|
||
|
|
||
|
struct hsmp_socket {
|
||
|
struct bin_attribute hsmp_attr;
|
||
|
struct hsmp_mbaddr_info mbinfo;
|
||
|
void __iomem *metric_tbl_addr;
|
||
|
void __iomem *virt_base_addr;
|
||
|
struct semaphore hsmp_sem;
|
||
|
char name[HSMP_ATTR_GRP_NAME_SIZE];
|
||
|
struct pci_dev *root;
|
||
|
struct device *dev;
|
||
|
u16 sock_ind;
|
||
|
int (*amd_hsmp_rdwr)(struct hsmp_socket *sock, u32 off, u32 *val, bool rw);
|
||
|
};
|
||
|
|
||
|
struct hsmp_plat_device {
|
||
|
struct miscdevice mdev;
|
||
|
struct hsmp_socket *sock;
|
||
|
u32 proto_ver;
|
||
|
u16 num_sockets;
|
||
|
bool is_probed;
|
||
|
};
|
||
|
|
||
|
int hsmp_cache_proto_ver(u16 sock_ind);
|
||
|
int hsmp_test(u16 sock_ind, u32 value);
|
||
|
long hsmp_ioctl(struct file *fp, unsigned int cmd, unsigned long arg);
|
||
|
void hsmp_misc_deregister(void);
|
||
|
int hsmp_misc_register(struct device *dev);
|
||
|
int hsmp_get_tbl_dram_base(u16 sock_ind);
|
||
|
ssize_t hsmp_metric_tbl_read(struct hsmp_socket *sock, char *buf, size_t size);
|
||
|
struct hsmp_plat_device *get_hsmp_pdev(void);
|
||
|
#endif /* HSMP_H */
|