add fedora patches for displaying more information while run lspci
This commit is contained in:
parent
c4dabe37c5
commit
72a57e0f03
12
0000-pciutils-2.2.1-idpath.patch
Normal file
12
0000-pciutils-2.2.1-idpath.patch
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
diff -up pciutils-3.0.0/Makefile.idpath pciutils-3.0.0/Makefile
|
||||||
|
--- pciutils-3.0.0/Makefile.idpath 2008-04-10 21:19:43.000000000 +0200
|
||||||
|
+++ pciutils-3.0.0/Makefile 2008-09-01 15:16:19.000000000 +0200
|
||||||
|
@@ -27,7 +27,7 @@ ABI_VERSION=.3
|
||||||
|
PREFIX=/usr/local
|
||||||
|
SBINDIR=$(PREFIX)/sbin
|
||||||
|
SHAREDIR=$(PREFIX)/share
|
||||||
|
-IDSDIR=$(SHAREDIR)
|
||||||
|
+IDSDIR=$(SHAREDIR)/hwdata
|
||||||
|
MANDIR:=$(shell if [ -d $(PREFIX)/share/man ] ; then echo $(PREFIX)/share/man ; else echo $(PREFIX)/man ; fi)
|
||||||
|
INCDIR=$(PREFIX)/include
|
||||||
|
LIBDIR=$(PREFIX)/lib
|
||||||
113
0001-pciutils-dir-d.patch
Normal file
113
0001-pciutils-dir-d.patch
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
diff -up pciutils-3.0.0/lib/names-parse.c.dird pciutils-3.0.0/lib/names-parse.c
|
||||||
|
--- pciutils-3.0.0/lib/names-parse.c.dird 2008-04-10 21:15:47.000000000 +0200
|
||||||
|
+++ pciutils-3.0.0/lib/names-parse.c 2008-09-01 15:17:23.000000000 +0200
|
||||||
|
@@ -6,10 +6,13 @@
|
||||||
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
||||||
|
*/
|
||||||
|
|
||||||
|
+#define _GNU_SOURCE
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <errno.h>
|
||||||
|
+#include <dirent.h>
|
||||||
|
+#include <libgen.h>
|
||||||
|
|
||||||
|
#include "internal.h"
|
||||||
|
#include "names.h"
|
||||||
|
@@ -82,7 +85,7 @@ static inline int id_white_p(int c)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
-static const char *id_parse_list(struct pci_access *a, pci_file f, int *lino)
|
||||||
|
+static const char *id_parse_list(struct pci_access *a, pci_file f, int *lino, int flags)
|
||||||
|
{
|
||||||
|
char line[MAX_LINE];
|
||||||
|
char *p;
|
||||||
|
@@ -207,7 +210,7 @@ static const char *id_parse_list(struct
|
||||||
|
p++;
|
||||||
|
if (!*p)
|
||||||
|
return parse_error;
|
||||||
|
- if (pci_id_insert(a, cat, id1, id2, id3, id4, p, SRC_LOCAL))
|
||||||
|
+ if (pci_id_insert(a, cat, id1, id2, id3, id4, p, SRC_LOCAL) && flags)
|
||||||
|
return "Duplicate entry";
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
@@ -223,13 +226,14 @@ pci_load_name_list(struct pci_access *a)
|
||||||
|
pci_free_name_list(a);
|
||||||
|
a->id_load_failed = 1;
|
||||||
|
if (!(f = pci_open(a)))
|
||||||
|
- return 0;
|
||||||
|
- err = id_parse_list(a, f, &lino);
|
||||||
|
+ return pci_new_load_name_list(a);
|
||||||
|
+ err = id_parse_list(a, f, &lino, 0);
|
||||||
|
PCI_ERROR(f, err);
|
||||||
|
pci_close(f);
|
||||||
|
if (err)
|
||||||
|
a->error("%s at %s, line %d\n", err, a->id_file_name, lino);
|
||||||
|
a->id_load_failed = 0;
|
||||||
|
+ pci_new_load_name_list(a);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -249,3 +253,49 @@ pci_set_name_list_path(struct pci_access
|
||||||
|
a->id_file_name = name;
|
||||||
|
a->free_id_name = to_be_freed;
|
||||||
|
}
|
||||||
|
+int pci_new_load_name_list(struct pci_access *a)
|
||||||
|
+{
|
||||||
|
+ pci_file f;
|
||||||
|
+ int lino, tempsize;
|
||||||
|
+ const char *err;
|
||||||
|
+ char *temp;
|
||||||
|
+ char new_id_path[PATH_MAX+1] = {0,};
|
||||||
|
+ DIR *pci_ids_dir;
|
||||||
|
+ struct dirent *dp;
|
||||||
|
+
|
||||||
|
+ strncpy(new_id_path, a->id_file_name, PATH_MAX);
|
||||||
|
+ new_id_path[PATH_MAX] = 0;
|
||||||
|
+ strncat(new_id_path, ".d/", PATH_MAX - strnlen(new_id_path, PATH_MAX));
|
||||||
|
+ /* printf("new_id_path is %s\n", new_id_path); */
|
||||||
|
+ pci_ids_dir = opendir(new_id_path);
|
||||||
|
+ if (pci_ids_dir == NULL)
|
||||||
|
+ return 0;
|
||||||
|
+
|
||||||
|
+ do
|
||||||
|
+ {
|
||||||
|
+ if ((dp = readdir(pci_ids_dir)) != NULL)
|
||||||
|
+ {
|
||||||
|
+ if (! strcmp(dp->d_name, "..") || ! strcmp(dp->d_name, "."))
|
||||||
|
+ continue;
|
||||||
|
+ if (strstr(dp->d_name, ".ids"))
|
||||||
|
+ {
|
||||||
|
+ tempsize = strnlen(new_id_path, PATH_MAX) + dp->d_reclen + 1;
|
||||||
|
+ temp = malloc(tempsize); /* This malloced memory is freed in the function pci_set_name_list_path() */
|
||||||
|
+ memset(temp, 0, tempsize);
|
||||||
|
+ strncpy(temp, new_id_path, (strnlen(new_id_path, PATH_MAX))+1);
|
||||||
|
+ strncat(temp, dp->d_name, PATH_MAX - strnlen(temp, PATH_MAX));
|
||||||
|
+ /* printf("Found file %s, processing it\n", temp); */
|
||||||
|
+ pci_set_name_list_path(a, temp, 1);
|
||||||
|
+ if (!(f = pci_open(a)))
|
||||||
|
+ continue;
|
||||||
|
+ err = id_parse_list(a, f, &lino, 0);
|
||||||
|
+ PCI_ERROR(f, err);
|
||||||
|
+ pci_close(f);
|
||||||
|
+ if (err)
|
||||||
|
+ a->error("%s at %s, line %d\n", err, a->id_file_name, lino);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }while (dp != NULL);
|
||||||
|
+ closedir(pci_ids_dir);
|
||||||
|
+ return 1;
|
||||||
|
+}
|
||||||
|
diff -up pciutils-3.0.0/lib/pci.h.dird pciutils-3.0.0/lib/pci.h
|
||||||
|
--- pciutils-3.0.0/lib/pci.h.dird 2008-04-10 21:23:05.000000000 +0200
|
||||||
|
+++ pciutils-3.0.0/lib/pci.h 2008-09-01 15:17:23.000000000 +0200
|
||||||
|
@@ -194,6 +194,7 @@ int pci_load_name_list(struct pci_access
|
||||||
|
void pci_free_name_list(struct pci_access *a) PCI_ABI; /* Called automatically by pci_cleanup() */
|
||||||
|
void pci_set_name_list_path(struct pci_access *a, char *name, int to_be_freed) PCI_ABI;
|
||||||
|
void pci_id_cache_flush(struct pci_access *a) PCI_ABI;
|
||||||
|
+int pci_new_load_name_list(struct pci_access *a);
|
||||||
|
|
||||||
|
enum pci_lookup_mode {
|
||||||
|
PCI_LOOKUP_VENDOR = 1, /* Vendor name (args: vendorID) */
|
||||||
@ -1,13 +1,17 @@
|
|||||||
Name: pciutils
|
Name: pciutils
|
||||||
Version: 3.6.2
|
Version: 3.6.2
|
||||||
Release: 4
|
Release: 5
|
||||||
Summary: PCI bus related utilities
|
Summary: PCI bus related utilities
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
URL: http://atrey.karlin.mff.cuni.cz/~mj/pciutils.shtml
|
URL: http://atrey.karlin.mff.cuni.cz/~mj/pciutils.shtml
|
||||||
Source0: https://mirrors.edge.kernel.org/pub/software/utils/pciutils/%{name}-%{version}.tar.gz
|
Source0: https://mirrors.edge.kernel.org/pub/software/utils/pciutils/%{name}-%{version}.tar.gz
|
||||||
|
|
||||||
|
Patch0: 0000-pciutils-2.2.1-idpath.patch
|
||||||
|
Patch1: 0001-pciutils-dir-d.patch
|
||||||
|
|
||||||
ExclusiveOS: Linux
|
ExclusiveOS: Linux
|
||||||
BuildRequires: gcc git sed kmod-devel pkgconfig zlib-devel
|
BuildRequires: gcc git sed kmod-devel pkgconfig zlib-devel
|
||||||
|
Requires: hwdata
|
||||||
Provides: %{name}-libs
|
Provides: %{name}-libs
|
||||||
Obsoletes: %{name}-libs
|
Obsoletes: %{name}-libs
|
||||||
Provides: %{name}-libs-debuginfo
|
Provides: %{name}-libs-debuginfo
|
||||||
@ -69,7 +73,7 @@ install -p lib/libpci.pc $RPM_BUILD_ROOT%{_libdir}/pkgconfig
|
|||||||
install -D -m 0644 lib/libpci.pc %{buildroot}%{_libdir}/pkgconfig/libpci.pc
|
install -D -m 0644 lib/libpci.pc %{buildroot}%{_libdir}/pkgconfig/libpci.pc
|
||||||
install -p lib/libpci.so.* $RPM_BUILD_ROOT/%{_lib}/
|
install -p lib/libpci.so.* $RPM_BUILD_ROOT/%{_lib}/
|
||||||
ln -s ../../%{_lib}/$(basename $RPM_BUILD_ROOT/%{_lib}/*.so.*.*.*) $RPM_BUILD_ROOT%{_libdir}/libpci.so
|
ln -s ../../%{_lib}/$(basename $RPM_BUILD_ROOT/%{_lib}/*.so.*.*.*) $RPM_BUILD_ROOT%{_libdir}/libpci.so
|
||||||
rm -rf $RPM_BUILD_ROOT/usr/share/pci.ids*
|
rm -rf $RPM_BUILD_ROOT/usr/share/hwdata/pci.ids*
|
||||||
|
|
||||||
%post -n %{name} -p /sbin/ldconfig
|
%post -n %{name} -p /sbin/ldconfig
|
||||||
|
|
||||||
@ -98,6 +102,12 @@ rm -rf $RPM_BUILD_ROOT/usr/share/pci.ids*
|
|||||||
rm -rf $RPM_BUILD_ROOT
|
rm -rf $RPM_BUILD_ROOT
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Tue Mar 17 2020 hy-euler <eulerstoragemt@huawei.com> - 3.6.2-5
|
||||||
|
- Type:enhancemnet
|
||||||
|
- ID:NA
|
||||||
|
- SUG:NA
|
||||||
|
- DESC:add fedora patches for displaying more information while running lspci
|
||||||
|
|
||||||
* Tue Jan 7 2020 openEuler Buildteam <buildteam@openeuler.org> - 3.6.2-4
|
* Tue Jan 7 2020 openEuler Buildteam <buildteam@openeuler.org> - 3.6.2-4
|
||||||
- Type:enhancemnet
|
- Type:enhancemnet
|
||||||
- ID:NA
|
- ID:NA
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user