1*4882a593SmuzhiyunFrom a5a4bb4254b2109bd3e272174946f0bb36ee99a8 Mon Sep 17 00:00:00 2001
2*4882a593SmuzhiyunFrom: Leon Anavi <leon.anavi@konsulko.com>
3*4882a593SmuzhiyunDate: Tue, 25 Aug 2020 11:45:45 +0300
4*4882a593SmuzhiyunSubject: [PATCH] Fix musl build
5*4882a593Smuzhiyun
6*4882a593SmuzhiyunApply the following fixes for musl:
7*4882a593Smuzhiyun
8*4882a593Smuzhiyun- Fix basename() is in libgen.h
9*4882a593Smuzhiyun- Fix wrong usage of LONG_BIT
10*4882a593Smuzhiyun
11*4882a593SmuzhiyunSame fixes have been submitted to the upstream of lshw by Sergio
12*4882a593SmuzhiyunPrado but they have not been merged yet.
13*4882a593Smuzhiyun
14*4882a593SmuzhiyunUpstream-Status: Submitted
15*4882a593Smuzhiyun
16*4882a593SmuzhiyunCo-Authored-By: Sergio Prado <sergio.prado@e-labworks.com>
17*4882a593SmuzhiyunSigned-off-by: Leon Anavi <leon.anavi@konsulko.com>
18*4882a593Smuzhiyun---
19*4882a593Smuzhiyun src/core/abi.cc   |  4 +---
20*4882a593Smuzhiyun src/core/sysfs.cc | 19 ++++++++++---------
21*4882a593Smuzhiyun 2 files changed, 11 insertions(+), 12 deletions(-)
22*4882a593Smuzhiyun
23*4882a593Smuzhiyundiff --git a/src/core/abi.cc b/src/core/abi.cc
24*4882a593Smuzhiyunindex adff7b5..76c664c 100644
25*4882a593Smuzhiyun--- a/src/core/abi.cc
26*4882a593Smuzhiyun+++ b/src/core/abi.cc
27*4882a593Smuzhiyun@@ -20,9 +20,7 @@ __ID("@(#) $Id: mem.cc 1352 2006-05-27 23:54:13Z ezix $");
28*4882a593Smuzhiyun bool scan_abi(hwNode & system)
29*4882a593Smuzhiyun {
30*4882a593Smuzhiyun   // are we compiled as 32- or 64-bit process ?
31*4882a593Smuzhiyun-  long sc = sysconf(LONG_BIT);
32*4882a593Smuzhiyun-  if(sc==-1) sc = sysconf(_SC_LONG_BIT);
33*4882a593Smuzhiyun-  if(sc!=-1) system.setWidth(sc);
34*4882a593Smuzhiyun+  system.setWidth(LONG_BIT);
35*4882a593Smuzhiyun
36*4882a593Smuzhiyun   pushd(PROC_SYS);
37*4882a593Smuzhiyun
38*4882a593Smuzhiyundiff --git a/src/core/sysfs.cc b/src/core/sysfs.cc
39*4882a593Smuzhiyunindex 32d6564..c2fa84f 100644
40*4882a593Smuzhiyun--- a/src/core/sysfs.cc
41*4882a593Smuzhiyun+++ b/src/core/sysfs.cc
42*4882a593Smuzhiyun@@ -16,6 +16,7 @@
43*4882a593Smuzhiyun #include <sys/stat.h>
44*4882a593Smuzhiyun #include <sys/types.h>
45*4882a593Smuzhiyun #include <sys/mount.h>
46*4882a593Smuzhiyun+#include <libgen.h>
47*4882a593Smuzhiyun
48*4882a593Smuzhiyun
49*4882a593Smuzhiyun __ID("@(#) $Id$");
50*4882a593Smuzhiyun@@ -100,7 +101,7 @@ static string sysfs_getbustype(const string & path)
51*4882a593Smuzhiyun   {
52*4882a593Smuzhiyun     devname =
53*4882a593Smuzhiyun       string(fs.path + "/bus/") + string(namelist[i]->d_name) +
54*4882a593Smuzhiyun-      "/devices/" + basename(path.c_str());
55*4882a593Smuzhiyun+      "/devices/" + basename(const_cast<char*>(path.c_str()));
56*4882a593Smuzhiyun
57*4882a593Smuzhiyun     if (samefile(devname, path))
58*4882a593Smuzhiyun       return string(namelist[i]->d_name);
59*4882a593Smuzhiyun@@ -140,7 +141,7 @@ static string sysfstobusinfo(const string & path)
60*4882a593Smuzhiyun
61*4882a593Smuzhiyun   if (bustype == "usb")
62*4882a593Smuzhiyun   {
63*4882a593Smuzhiyun-    string name = basename(path.c_str());
64*4882a593Smuzhiyun+    string name = basename(const_cast<char*>(path.c_str()));
65*4882a593Smuzhiyun     if (matches(name, "^[0-9]+-[0-9]+(\\.[0-9]+)*:[0-9]+\\.[0-9]+$"))
66*4882a593Smuzhiyun     {
67*4882a593Smuzhiyun       size_t colon = name.rfind(":");
68*4882a593Smuzhiyun@@ -151,7 +152,7 @@ static string sysfstobusinfo(const string & path)
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun   if (bustype == "virtio")
71*4882a593Smuzhiyun   {
72*4882a593Smuzhiyun-    string name = basename(path.c_str());
73*4882a593Smuzhiyun+    string name = basename(const_cast<char*>(path.c_str()));
74*4882a593Smuzhiyun     if (name.compare(0, 6, "virtio") == 0)
75*4882a593Smuzhiyun       return "virtio@" + name.substr(6);
76*4882a593Smuzhiyun     else
77*4882a593Smuzhiyun@@ -159,10 +160,10 @@ static string sysfstobusinfo(const string & path)
78*4882a593Smuzhiyun   }
79*4882a593Smuzhiyun
80*4882a593Smuzhiyun   if (bustype == "vio")
81*4882a593Smuzhiyun-    return string("vio@") + basename(path.c_str());
82*4882a593Smuzhiyun+    return string("vio@") + basename(const_cast<char*>(path.c_str()));
83*4882a593Smuzhiyun
84*4882a593Smuzhiyun   if (bustype == "ccw")
85*4882a593Smuzhiyun-    return string("ccw@") + basename(path.c_str());
86*4882a593Smuzhiyun+    return string("ccw@") + basename(const_cast<char*>(path.c_str()));
87*4882a593Smuzhiyun
88*4882a593Smuzhiyun   if (bustype == "ccwgroup")
89*4882a593Smuzhiyun   {
90*4882a593Smuzhiyun@@ -240,7 +241,7 @@ string entry::driver() const
91*4882a593Smuzhiyun   string driverlink = This->devpath + "/driver";
92*4882a593Smuzhiyun   if (!exists(driverlink))
93*4882a593Smuzhiyun     return "";
94*4882a593Smuzhiyun-  return basename(readlink(driverlink).c_str());
95*4882a593Smuzhiyun+  return basename(const_cast<char*>(readlink(driverlink).c_str()));
96*4882a593Smuzhiyun }
97*4882a593Smuzhiyun
98*4882a593Smuzhiyun
99*4882a593Smuzhiyun@@ -328,7 +329,7 @@ string entry::name_in_class(const string & classname) const
100*4882a593Smuzhiyun
101*4882a593Smuzhiyun string entry::name() const
102*4882a593Smuzhiyun {
103*4882a593Smuzhiyun-  return basename(This->devpath.c_str());
104*4882a593Smuzhiyun+  return basename(const_cast<char*>(This->devpath.c_str()));
105*4882a593Smuzhiyun }
106*4882a593Smuzhiyun
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun@@ -340,12 +341,12 @@ entry entry::parent() const
109*4882a593Smuzhiyun
110*4882a593Smuzhiyun string entry::classname() const
111*4882a593Smuzhiyun {
112*4882a593Smuzhiyun-  return basename(dirname(This->devpath).c_str());
113*4882a593Smuzhiyun+  return basename(const_cast<char*>(dirname(This->devpath).c_str()));
114*4882a593Smuzhiyun }
115*4882a593Smuzhiyun
116*4882a593Smuzhiyun bool entry::isvirtual() const
117*4882a593Smuzhiyun {
118*4882a593Smuzhiyun-  return string(basename(dirname(dirname(This->devpath)).c_str())) == "virtual";
119*4882a593Smuzhiyun+  return string(basename(const_cast<char*>(dirname(dirname(This->devpath)).c_str()))) == "virtual";
120*4882a593Smuzhiyun }
121*4882a593Smuzhiyun
122*4882a593Smuzhiyun string entry::string_attr(const string & name, const string & def) const
123*4882a593Smuzhiyun--
124*4882a593Smuzhiyun2.17.1
125*4882a593Smuzhiyun
126