127 lines
4.0 KiB
C
127 lines
4.0 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
#ifndef _TELEMETRY_H
|
||
|
#define _TELEMETRY_H
|
||
|
|
||
|
/* Telemetry types */
|
||
|
#define PMT_TELEM_TELEMETRY 0
|
||
|
#define PMT_TELEM_CRASHLOG 1
|
||
|
|
||
|
struct telem_endpoint;
|
||
|
struct pci_dev;
|
||
|
|
||
|
struct telem_header {
|
||
|
u8 access_type;
|
||
|
u16 size;
|
||
|
u32 guid;
|
||
|
u32 base_offset;
|
||
|
};
|
||
|
|
||
|
struct telem_endpoint_info {
|
||
|
struct pci_dev *pdev;
|
||
|
struct telem_header header;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_get_next_endpoint() - Get next device id for a telemetry endpoint
|
||
|
* @start: starting devid to look from
|
||
|
*
|
||
|
* This functions can be used in a while loop predicate to retrieve the devid
|
||
|
* of all available telemetry endpoints. Functions pmt_telem_get_next_endpoint()
|
||
|
* and pmt_telem_register_endpoint() can be used inside of the loop to examine
|
||
|
* endpoint info and register to receive a pointer to the endpoint. The pointer
|
||
|
* is then usable in the telemetry read calls to access the telemetry data.
|
||
|
*
|
||
|
* Return:
|
||
|
* * devid - devid of the next present endpoint from start
|
||
|
* * 0 - when no more endpoints are present after start
|
||
|
*/
|
||
|
unsigned long pmt_telem_get_next_endpoint(unsigned long start);
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_register_endpoint() - Register a telemetry endpoint
|
||
|
* @devid: device id/handle of the telemetry endpoint
|
||
|
*
|
||
|
* Increments the kref usage counter for the endpoint.
|
||
|
*
|
||
|
* Return:
|
||
|
* * endpoint - On success returns pointer to the telemetry endpoint
|
||
|
* * -ENXIO - telemetry endpoint not found
|
||
|
*/
|
||
|
struct telem_endpoint *pmt_telem_register_endpoint(int devid);
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_unregister_endpoint() - Unregister a telemetry endpoint
|
||
|
* @ep: ep structure to populate.
|
||
|
*
|
||
|
* Decrements the kref usage counter for the endpoint.
|
||
|
*/
|
||
|
void pmt_telem_unregister_endpoint(struct telem_endpoint *ep);
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_get_endpoint_info() - Get info for an endpoint from its devid
|
||
|
* @devid: device id/handle of the telemetry endpoint
|
||
|
* @info: Endpoint info structure to be populated
|
||
|
*
|
||
|
* Return:
|
||
|
* * 0 - Success
|
||
|
* * -ENXIO - telemetry endpoint not found for the devid
|
||
|
* * -EINVAL - @info is NULL
|
||
|
*/
|
||
|
int pmt_telem_get_endpoint_info(int devid, struct telem_endpoint_info *info);
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_find_and_register_endpoint() - Get a telemetry endpoint from
|
||
|
* pci_dev device, guid and pos
|
||
|
* @pdev: PCI device inside the Intel vsec
|
||
|
* @guid: GUID of the telemetry space
|
||
|
* @pos: Instance of the guid
|
||
|
*
|
||
|
* Return:
|
||
|
* * endpoint - On success returns pointer to the telemetry endpoint
|
||
|
* * -ENXIO - telemetry endpoint not found
|
||
|
*/
|
||
|
struct telem_endpoint *pmt_telem_find_and_register_endpoint(struct pci_dev *pcidev,
|
||
|
u32 guid, u16 pos);
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_read() - Read qwords from counter sram using sample id
|
||
|
* @ep: Telemetry endpoint to be read
|
||
|
* @id: The beginning sample id of the metric(s) to be read
|
||
|
* @data: Allocated qword buffer
|
||
|
* @count: Number of qwords requested
|
||
|
*
|
||
|
* Callers must ensure reads are aligned. When the call returns -ENODEV,
|
||
|
* the device has been removed and callers should unregister the telemetry
|
||
|
* endpoint.
|
||
|
*
|
||
|
* Return:
|
||
|
* * 0 - Success
|
||
|
* * -ENODEV - The device is not present.
|
||
|
* * -EINVAL - The offset is out bounds
|
||
|
* * -EPIPE - The device was removed during the read. Data written
|
||
|
* but should be considered invalid.
|
||
|
*/
|
||
|
int pmt_telem_read(struct telem_endpoint *ep, u32 id, u64 *data, u32 count);
|
||
|
|
||
|
/**
|
||
|
* pmt_telem_read32() - Read qwords from counter sram using sample id
|
||
|
* @ep: Telemetry endpoint to be read
|
||
|
* @id: The beginning sample id of the metric(s) to be read
|
||
|
* @data: Allocated dword buffer
|
||
|
* @count: Number of dwords requested
|
||
|
*
|
||
|
* Callers must ensure reads are aligned. When the call returns -ENODEV,
|
||
|
* the device has been removed and callers should unregister the telemetry
|
||
|
* endpoint.
|
||
|
*
|
||
|
* Return:
|
||
|
* * 0 - Success
|
||
|
* * -ENODEV - The device is not present.
|
||
|
* * -EINVAL - The offset is out bounds
|
||
|
* * -EPIPE - The device was removed during the read. Data written
|
||
|
* but should be considered invalid.
|
||
|
*/
|
||
|
int pmt_telem_read32(struct telem_endpoint *ep, u32 id, u32 *data, u32 count);
|
||
|
|
||
|
#endif
|