Commit aa5cea38 authored by Tomer Tayar's avatar Tomer Tayar Committed by Oded Gabbay
Browse files

accel/habanalabs: add parent_device sysfs attribute



The device debugfs directory was modified to be named as the
device-name.
This name is the parent device name, i.e. either the PCI address in case
of an ASIC, or the simulator device name in case of a simulator.

This change makes it more difficult for a user to access the debugfs
directory for a specific accel device, because he can't just use the
accel minor id, but he needs to do more device-dependent operations to
get the device name.

To make it easier to get this name, add a 'parent_device' sysfs
attribute that the user can read using the minor id before accessing
debugfs.

Signed-off-by: default avatarTomer Tayar <ttayar@habana.ai>
Reviewed-by: default avatarOded Gabbay <ogabbay@kernel.org>
Signed-off-by: default avatarOded Gabbay <ogabbay@kernel.org>
parent cf0719a8
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -155,6 +155,12 @@ KernelVersion: not yet upstreamed
Contact:        ogabbay@kernel.org
Description:    Displays the device's module id

What:           /sys/class/accel/accel<n>/device/parent_device
Date:           Nov 2023
KernelVersion:  6.8
Contact:        ttayar@habana.ai
Description:    Displays the name of the parent device of the accel device

What:           /sys/class/accel/accel<n>/device/pci_addr
Date:           Jan 2019
KernelVersion:  5.1
+3 −0
Original line number Diff line number Diff line
@@ -3521,6 +3521,9 @@ struct hl_device {
	u8				heartbeat;
};

/* Retrieve PCI device name in case of a PCI device or dev name in simulator */
#define HL_DEV_NAME(hdev)	\
		((hdev)->pdev ? dev_name(&(hdev)->pdev->dev) : "NA-DEVICE")

/**
 * struct hl_cs_encaps_sig_handle - encapsulated signals handle structure
+9 −0
Original line number Diff line number Diff line
@@ -410,6 +410,13 @@ static ssize_t module_id_show(struct device *dev,
	return sprintf(buf, "%u\n", le32_to_cpu(hdev->asic_prop.cpucp_info.card_location));
}

static ssize_t parent_device_show(struct device *dev, struct device_attribute *attr, char *buf)
{
	struct hl_device *hdev = dev_get_drvdata(dev);

	return sprintf(buf, "%s\n", HL_DEV_NAME(hdev));
}

static DEVICE_ATTR_RO(armcp_kernel_ver);
static DEVICE_ATTR_RO(armcp_ver);
static DEVICE_ATTR_RO(cpld_ver);
@@ -430,6 +437,7 @@ static DEVICE_ATTR_RO(uboot_ver);
static DEVICE_ATTR_RO(fw_os_ver);
static DEVICE_ATTR_RO(security_enabled);
static DEVICE_ATTR_RO(module_id);
static DEVICE_ATTR_RO(parent_device);

static struct bin_attribute bin_attr_eeprom = {
	.attr = {.name = "eeprom", .mode = (0444)},
@@ -456,6 +464,7 @@ static struct attribute *hl_dev_attrs[] = {
	&dev_attr_fw_os_ver.attr,
	&dev_attr_security_enabled.attr,
	&dev_attr_module_id.attr,
	&dev_attr_parent_device.attr,
	NULL,
};