From: "Zbigniew Kempczyński" <zbigniew.kempczynski@intel.com>
To: igt-dev@lists.freedesktop.org
Cc: "Zbigniew Kempczyński" <zbigniew.kempczynski@intel.com>,
"Lucas De Marchi" <lucas.demarchi@intel.com>,
"Kamil Konieczny" <kamil.konieczny@linux.intel.com>
Subject: [PATCH i-g-t] lib/igt_device_scan: limit fetched device attributes from udev
Date: Tue, 28 Jan 2025 09:30:14 +0100 [thread overview]
Message-ID: <20250128083014.27713-1-zbigniew.kempczynski@intel.com> (raw)
Tests don't need all attributes so default device scanning is now
limited to small list directly used in device filters. To be backward
compatible tools like lsgpu still may scan whole attribute list what
keeps this behavior intact.
Cc: Lucas De Marchi <lucas.demarchi@intel.com>
Cc: Kamil Konieczny <kamil.konieczny@linux.intel.com>
Signed-off-by: Zbigniew Kempczyński <zbigniew.kempczynski@intel.com>
---
lib/igt_device_scan.c | 69 ++++++++++++++++++++++++++++++-------------
lib/igt_device_scan.h | 1 +
tools/lsgpu.c | 2 +-
3 files changed, 50 insertions(+), 22 deletions(-)
diff --git a/lib/igt_device_scan.c b/lib/igt_device_scan.c
index c36b0efa90..15f6bf5728 100644
--- a/lib/igt_device_scan.c
+++ b/lib/igt_device_scan.c
@@ -22,6 +22,7 @@
*
*/
+#include "drmtest.h"
#include "igt_core.h"
#include "igt_device_scan.h"
#include "igt_list.h"
@@ -206,6 +207,8 @@ enum dev_type {
#define STR_INTEGRATED "integrated"
#define STR_DISCRETE "discrete"
+static const char * const attrs[] = { "driver", "sriov_numvfs", "physfn" };
+
static inline bool strequal(const char *a, const char *b)
{
if (a == NULL || b == NULL)
@@ -548,24 +551,35 @@ static void get_props(struct udev_device *dev, struct igt_device *idev)
* Function skips sysattrs from blacklist ht (acquiring some values can take
* seconds).
*/
-static void get_attrs(struct udev_device *dev, struct igt_device *idev)
+static void get_attrs(struct udev_device *dev, struct igt_device *idev,
+ bool limit_attrs)
{
struct udev_list_entry *entry;
+ const char *value;
- entry = udev_device_get_sysattr_list_entry(dev);
- while (entry) {
- const char *key = udev_list_entry_get_name(entry);
- const char *value;
+ if (limit_attrs) {
+ for (int i = 0; i < ARRAY_SIZE(attrs); i++) {
+ value = udev_device_get_sysattr_value(dev, attrs[i]);
+ if (!value)
+ continue;
+ igt_device_add_attr(idev, attrs[i], value);
+ DBG("attr: %s, val: %s\n", attrs[i], value);
+ }
+ } else {
+ entry = udev_device_get_sysattr_list_entry(dev);
+ while (entry) {
+ const char *key = udev_list_entry_get_name(entry);
- if (is_on_blacklist(key)) {
+ if (is_on_blacklist(key)) {
+ entry = udev_list_entry_get_next(entry);
+ continue;
+ }
+
+ value = udev_device_get_sysattr_value(dev, key);
+ igt_device_add_attr(idev, key, value);
entry = udev_list_entry_get_next(entry);
- continue;
+ DBG("attr: %s, val: %s\n", key, value);
}
-
- value = udev_device_get_sysattr_value(dev, key);
- igt_device_add_attr(idev, key, value);
- entry = udev_list_entry_get_next(entry);
- DBG("attr: %s, val: %s\n", key, value);
}
}
@@ -639,7 +653,8 @@ static char* strdup_nullsafe(const char* str)
* Fills structure with most usable udev device variables, properties
* and sysattrs.
*/
-static struct igt_device *igt_device_new_from_udev(struct udev_device *dev)
+static struct igt_device *igt_device_new_from_udev(struct udev_device *dev,
+ bool limit_attrs)
{
struct igt_device *idev = igt_device_new();
@@ -654,7 +669,7 @@ static struct igt_device *igt_device_new_from_udev(struct udev_device *dev)
idev->drm_render = strdup(idev->devnode);
get_props(dev, idev);
- get_attrs(dev, idev);
+ get_attrs(dev, idev, limit_attrs);
if (is_pci_subsystem(idev)) {
uint16_t vendor, device;
@@ -868,7 +883,8 @@ static struct igt_device *igt_device_from_syspath(const char *syspath)
*/
static void update_or_add_parent(struct udev *udev,
struct udev_device *dev,
- struct igt_device *idev)
+ struct igt_device *idev,
+ bool limit_attrs)
{
struct udev_device *parent_dev;
struct igt_device *parent_idev;
@@ -899,7 +915,7 @@ static void update_or_add_parent(struct udev *udev,
* return fresh udev device.
*/
parent_dev = udev_device_new_from_syspath(udev, syspath);
- parent_idev = igt_device_new_from_udev(parent_dev);
+ parent_idev = igt_device_new_from_udev(parent_dev, limit_attrs);
udev_device_unref(parent_dev);
if (parent_idev)
@@ -1000,7 +1016,7 @@ static void index_pci_devices(void)
* Function sorts all found devices to keep same order of bus devices
* for providing predictable search.
*/
-static void scan_drm_devices(void)
+static void scan_drm_devices(bool limit_attrs)
{
struct udev *udev;
struct udev_enumerate *enumerate;
@@ -1035,9 +1051,9 @@ static void scan_drm_devices(void)
path = udev_list_entry_get_name(dev_list_entry);
udev_dev = udev_device_new_from_syspath(udev, path);
- idev = igt_device_new_from_udev(udev_dev);
+ idev = igt_device_new_from_udev(udev_dev, limit_attrs);
igt_list_add_tail(&idev->link, &igt_devs.all);
- update_or_add_parent(udev, udev_dev, idev);
+ update_or_add_parent(udev, udev_dev, idev, limit_attrs);
udev_device_unref(udev_dev);
}
@@ -1092,17 +1108,28 @@ void igt_devices_free(void)
*
* Function scans udev in search of gpu devices.
*/
-void igt_devices_scan(void)
+
+static void __igt_devices_scan(bool limit_attrs)
{
if (igt_devs.devs_scanned)
igt_devices_free();
prepare_scan();
- scan_drm_devices();
+ scan_drm_devices(limit_attrs);
igt_devs.devs_scanned = true;
}
+void igt_devices_scan(void)
+{
+ __igt_devices_scan(true);
+}
+
+void igt_devices_scan_all_attrs(void)
+{
+ __igt_devices_scan(false);
+}
+
static inline void _pr_simple(const char *k, const char *v)
{
printf(" %-16s: %s\n", k, v);
diff --git a/lib/igt_device_scan.h b/lib/igt_device_scan.h
index fa90134aa3..92741fe3c7 100644
--- a/lib/igt_device_scan.h
+++ b/lib/igt_device_scan.h
@@ -64,6 +64,7 @@ struct igt_device_card {
};
void igt_devices_scan(void);
+void igt_devices_scan_all_attrs(void);
void igt_devices_print(const struct igt_devices_print_format *fmt);
void igt_devices_print_vendors(void);
diff --git a/tools/lsgpu.c b/tools/lsgpu.c
index e482ca6b75..e683900833 100644
--- a/tools/lsgpu.c
+++ b/tools/lsgpu.c
@@ -362,7 +362,7 @@ int main(int argc, char *argv[])
printf("Notice: Using filter from .igtrc\n");
}
- igt_devices_scan();
+ igt_devices_scan_all_attrs();
if (igt_device != NULL) {
struct igt_device_card card;
--
2.34.1
next reply other threads:[~2025-01-28 8:30 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-01-28 8:30 Zbigniew Kempczyński [this message]
2025-01-28 11:04 ` ✓ i915.CI.BAT: success for lib/igt_device_scan: limit fetched device attributes from udev Patchwork
2025-01-28 11:08 ` ✓ Xe.CI.BAT: " Patchwork
2025-01-28 17:42 ` ✗ i915.CI.Full: failure " Patchwork
2025-01-29 6:12 ` Zbigniew Kempczyński
2025-01-28 21:06 ` ✗ Xe.CI.Full: " Patchwork
2025-01-29 6:14 ` Zbigniew Kempczyński
2025-01-29 14:48 ` [PATCH i-g-t] " Kamil Konieczny
2025-01-30 10:17 ` Zbigniew Kempczyński
2025-01-30 10:20 ` Zbigniew Kempczyński
-- strict thread matches above, loose matches on Subject: below --
2025-01-30 10:27 Zbigniew Kempczyński
2025-01-30 12:00 ` Kamil Konieczny
2025-02-03 8:04 ` Bernatowicz, Marcin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250128083014.27713-1-zbigniew.kempczynski@intel.com \
--to=zbigniew.kempczynski@intel.com \
--cc=igt-dev@lists.freedesktop.org \
--cc=kamil.konieczny@linux.intel.com \
--cc=lucas.demarchi@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox