Compare commits
No commits in common. "c8" and "c10s-private-than" have entirely different histories.
c8
...
c10s-priva
1
.fmf/version
Normal file
1
.fmf/version
Normal file
@ -0,0 +1 @@
|
||||
1
|
30
.gitignore
vendored
30
.gitignore
vendored
@ -1 +1,29 @@
|
||||
SOURCES/powerpc-utils-1.3.10.tar.gz
|
||||
powerpc-utils-1.2.2.tar.gz
|
||||
/powerpc-utils-1.2.6.tar.gz
|
||||
/powerpc-utils-1.2.10.tar.gz
|
||||
/powerpc-utils-1.2.11.tar.gz
|
||||
/powerpc-utils-1.2.12.tar.gz
|
||||
/powerpc-utils-1.2.14.tar.gz
|
||||
/powerpc-utils-1.2.15.tar.gz
|
||||
/powerpc-utils-1.2.16.tar.gz
|
||||
/powerpc-utils-1.2.17.tar.gz
|
||||
/powerpc-utils-1.2.18.tar.gz
|
||||
/powerpc-utils-1.2.19.tar.gz
|
||||
/powerpc-utils-1.2.20.tar.gz
|
||||
/powerpc-utils-1.2.22.tar.gz
|
||||
/powerpc-utils-1.2.23.tar.gz
|
||||
/powerpc-utils-1.2.24.tar.gz
|
||||
/powerpc-utils-1.2.27.tar.gz
|
||||
/v1.3.0.tar.gz
|
||||
/v1.3.1.tar.gz
|
||||
/v1.3.3.tar.gz
|
||||
/powerpc-utils-1.3.4.tar.gz
|
||||
/powerpc-utils-1.3.5.tar.gz
|
||||
/powerpc-utils-1.3.6.tar.gz
|
||||
/powerpc-utils-1.3.7.tar.gz
|
||||
/powerpc-utils-1.3.8.tar.gz
|
||||
/powerpc-utils-1.3.9.tar.gz
|
||||
/powerpc-utils-1.3.10.tar.gz
|
||||
/powerpc-utils-1.3.11.tar.gz
|
||||
/powerpc-utils-1.3.12.tar.gz
|
||||
/powerpc-utils-1.3.13.tar.gz
|
||||
|
@ -1,11 +0,0 @@
|
||||
diff -up powerpc-utils-1.3.10/Makefile.am.me powerpc-utils-1.3.10/Makefile.am
|
||||
--- powerpc-utils-1.3.10/Makefile.am.me 2022-06-03 12:35:01.335312481 +0200
|
||||
+++ powerpc-utils-1.3.10/Makefile.am 2022-06-03 14:11:58.453820076 +0200
|
||||
@@ -229,7 +229,6 @@ install-data-hook:
|
||||
$(INSTALL_DATA) systemd/smtstate.service $(DESTDIR)${systemd_unit_dir}/
|
||||
$(INSTALL_DATA) systemd/hcn-init.service $(DESTDIR)${systemd_unit_dir}/
|
||||
$(INSTALL_DATA) var/lib/powerpc-utils/smt.state $(DESTDIR)/var/lib/@PACKAGE@/
|
||||
- $(INSTALL_SCRIPT) scripts/functions.suse $(DESTDIR)/usr/lib/@PACKAGE@/
|
||||
$(INSTALL_SCRIPT) scripts/smtstate $(DESTDIR)@sbindir@
|
||||
sed -i -e 's,$${exec_prefix},@prefix@,g' $(DESTDIR)${systemd_unit_dir}/smt_off.service
|
||||
sed -i -e 's,$${exec_prefix},@prefix@,g' $(DESTDIR)${systemd_unit_dir}/smtstate.service
|
@ -1,84 +0,0 @@
|
||||
commit 73ba26c1240a25e7699449e82cfc09dad10fed80
|
||||
Author: Sathvika Vasireddy <sv@linux.ibm.com>
|
||||
Date: Fri Dec 9 15:26:46 2022 +0530
|
||||
|
||||
lparstat: Fix negative values seen while running lparstat with -E option
|
||||
|
||||
Negative values are seen while running lparstat with -E option.
|
||||
This is because delta_purr value is less than delta_idle_purr.
|
||||
Given that these values are read from different sources, a
|
||||
small variation in the values is possible. So, in such cases,
|
||||
round down delta_idle_purr to delta_purr.
|
||||
|
||||
Without this patch:
|
||||
=====
|
||||
System Configuration
|
||||
type=Dedicated mode=Capped smt=8 lcpu=240 mem=67033290112 kB cpus=0
|
||||
ent=240.00
|
||||
|
||||
---Actual--- -Normalized-
|
||||
%busy %idle Frequency %busy %idle
|
||||
------ ------ ------------- ------ ------
|
||||
-0.03 100.02 3.93GHz[111%] 0.01 110.97
|
||||
0.00 100.00 3.93GHz[111%] 0.01 110.99
|
||||
-0.04 100.03 3.93GHz[111%] 0.01 110.98
|
||||
0.06 99.95 3.93GHz[111%] 0.01 110.99
|
||||
0.02 99.98 3.93GHz[111%] 0.01 110.99
|
||||
=====
|
||||
|
||||
With this patch:
|
||||
=====
|
||||
System Configuration
|
||||
type=Dedicated mode=Capped smt=8 lcpu=240 mem=67033290112 kB cpus=0
|
||||
ent=240.00
|
||||
|
||||
---Actual--- -Normalized-
|
||||
%busy %idle Frequency %busy %idle
|
||||
------ ------ ------------- ------ ------
|
||||
0.03 99.96 3.93GHz[111%] 0.01 110.98
|
||||
0.00 100.00 3.93GHz[111%] 0.01 110.99
|
||||
0.03 99.97 3.93GHz[111%] 0.01 110.99
|
||||
0.00 100.00 3.93GHz[111%] 0.01 110.99
|
||||
0.09 99.90 3.93GHz[111%] 0.01 110.99
|
||||
=====
|
||||
|
||||
Reported-by: Shirisha Ganta <shirisha.ganta1@ibm.com>
|
||||
Signed-off-by: Sathvika Vasireddy <sv@linux.ibm.com>
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/src/lparstat.c b/src/lparstat.c
|
||||
index 31a4ee8..eebba1f 100644
|
||||
--- a/src/lparstat.c
|
||||
+++ b/src/lparstat.c
|
||||
@@ -492,6 +492,15 @@ void get_cpu_util_purr(struct sysentry *unused_se, char *buf)
|
||||
delta_purr = get_delta_value("purr");
|
||||
delta_idle_purr = get_delta_value("idle_purr");
|
||||
|
||||
+ /*
|
||||
+ * Given that these values are read from different
|
||||
+ * sources (purr from lparcfg and idle_purr from sysfs),
|
||||
+ * a small variation in the values is possible.
|
||||
+ * In such cases, round down delta_idle_purr to delta_purr.
|
||||
+ */
|
||||
+ if (delta_idle_purr > delta_purr)
|
||||
+ delta_idle_purr = delta_purr;
|
||||
+
|
||||
physc = (delta_purr - delta_idle_purr) / delta_tb;
|
||||
physc *= 100.00;
|
||||
|
||||
@@ -507,6 +516,15 @@ void get_cpu_idle_purr(struct sysentry *unused_se, char *buf)
|
||||
delta_purr = get_delta_value("purr");
|
||||
delta_idle_purr = get_delta_value("idle_purr");
|
||||
|
||||
+ /*
|
||||
+ * Given that these values are read from different
|
||||
+ * sources (purr from lparcfg and idle_purr from sysfs),
|
||||
+ * a small variation in the values is possible.
|
||||
+ * In such cases, round down delta_idle_purr to delta_purr.
|
||||
+ */
|
||||
+ if (delta_idle_purr > delta_purr)
|
||||
+ delta_idle_purr = delta_purr;
|
||||
+
|
||||
physc = (delta_purr - delta_idle_purr) / delta_tb;
|
||||
idle = (delta_purr / delta_tb) - physc;
|
||||
idle *= 100.00;
|
@ -1,46 +0,0 @@
|
||||
commit dee15756bcb287ccf39a904be07c90107b13844b
|
||||
Author: Laurent Dufour <ldufour@linux.ibm.com>
|
||||
Date: Wed May 3 10:50:15 2023 +0200
|
||||
|
||||
lparstat: Fix offline threads uninitialized entries
|
||||
|
||||
When some threads are offline, lparstat -E is failing like that:
|
||||
|
||||
$ ppc64_cpu --info # CPU 20 is offline
|
||||
Core 0: 0* 1* 2* 3* 4* 5* 6* 7*
|
||||
Core 1: 8* 9* 10* 11* 12* 13* 14* 15*
|
||||
Core 2: 16* 17* 18* 19* 20 21* 22* 23*
|
||||
Core 3: 24* 25* 26* 27* 28* 29* 30* 31*
|
||||
Core 4: 32* 33* 34* 35* 36* 37* 38* 39*
|
||||
Core 5: 40* 41* 42* 43* 44* 45* 46* 47*
|
||||
$ lparstat -E
|
||||
Failed to read /sys/devices/system/cpu/cpu0/spurr
|
||||
|
||||
The message is complaining about CPU0 but the real issue is that in
|
||||
parse_sysfs_values() the test cpu_sysfs_fds[i].spurr >= 0 is valid even if
|
||||
the entry has not been initialized (cpu_sysfs_fds is alloc cleared). So
|
||||
if the number of threads online seen in assign_cpu_sysfs_fds is lower than
|
||||
threads_in_system, the loop in parse_sysfs_values() will read uninitialized
|
||||
entry, where .cpu=0.
|
||||
|
||||
To prevent that, unset entries in the cpu_sysfs_fds should have the spurr
|
||||
fd set to -1.
|
||||
|
||||
Signed-off-by: Laurent Dufour <ldufour@linux.ibm.com>
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/src/lparstat.c b/src/lparstat.c
|
||||
index a9e7bce..d2fdb3f 100644
|
||||
--- a/src/lparstat.c
|
||||
+++ b/src/lparstat.c
|
||||
@@ -163,6 +163,10 @@ static int assign_cpu_sysfs_fds(int threads_in_system)
|
||||
cpu_idx++;
|
||||
}
|
||||
|
||||
+ /* Mark extra slots for offline threads unset, see parse_sysfs_values */
|
||||
+ for (; cpu_idx < threads_in_system; cpu_idx++)
|
||||
+ cpu_sysfs_fds[cpu_idx].spurr = -1;
|
||||
+
|
||||
return 0;
|
||||
error:
|
||||
fprintf(stderr, "Failed to open %s: %s\n",
|
@ -1,93 +0,0 @@
|
||||
commit b2672fa3d462217ccd057a2cd307af2448e78757
|
||||
Author: Laurent Dufour <ldufour@linux.ibm.com>
|
||||
Date: Wed May 3 10:50:14 2023 +0200
|
||||
|
||||
lparstat: report mixed SMT state
|
||||
|
||||
when SMT state is mixed like this one (CPU 4 is offline):
|
||||
|
||||
$ ppc64_cpu --info
|
||||
Core 0: 0* 1* 2* 3* 4 5* 6* 7*
|
||||
Core 1: 8* 9* 10* 11* 12* 13* 14* 15*
|
||||
Core 2: 16* 17* 18* 19* 20* 21* 22* 23*
|
||||
Core 3: 24* 25* 26* 27* 28* 29* 30* 31*
|
||||
Core 4: 32* 33* 34* 35* 36* 37* 38* 39*
|
||||
Core 5: 40* 41* 42* 43* 44* 45* 46* 47*
|
||||
$ ppc64_cpu --smt
|
||||
SMT=7: 0
|
||||
SMT=8: 1-5
|
||||
|
||||
ppc64_cpu --smt is handling that nicely but lparstat failed reporting the
|
||||
SMT state:
|
||||
$ /usr/sbin/lparstat
|
||||
Failed to get smt state
|
||||
|
||||
System Configuration
|
||||
type=Dedicated mode=Capped smt=Capped lcpu=6 mem=65969728 kB cpus=0 ent=6.00
|
||||
|
||||
%user %sys %wait %idle physc %entc lbusy app vcsw phint
|
||||
----- ----- ----- ----- ----- ----- ----- ----- ----- -----
|
||||
0.02 0.01 0.00 99.97 3.41 56.83 0.02 0.00 4061778 156
|
||||
|
||||
Makes lparstat reporting "smt=mixed" in that case.
|
||||
__do_smt is now returning 0 when the SMT state is mixed instead of -1 which
|
||||
is also reported when an error is detected.
|
||||
This doesn't change the call made by ppc64_cpu which is using
|
||||
print_smt_state=true and so is expecting a returned value equal to 0 or -1.
|
||||
|
||||
With that patch applied, lparstat print that in the above case:
|
||||
$lparstat
|
||||
|
||||
System Configuration
|
||||
type=Dedicated mode=Capped smt=Mixed lcpu=6 mem=65969728 kB cpus=0 ent=6.00
|
||||
|
||||
%user %sys %wait %idle physc %entc lbusy app vcsw phint
|
||||
----- ----- ----- ----- ----- ----- ----- ----- ----- -----
|
||||
0.01 0.01 0.00 99.97 3.43 57.17 0.02 0.00 4105654 156
|
||||
|
||||
Signed-off-by: Laurent Dufour <ldufour@linux.ibm.com>
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/src/common/cpu_info_helpers.c b/src/common/cpu_info_helpers.c
|
||||
index 925f220..c05d96d 100644
|
||||
--- a/src/common/cpu_info_helpers.c
|
||||
+++ b/src/common/cpu_info_helpers.c
|
||||
@@ -245,7 +245,7 @@ int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu,
|
||||
if (smt_state == 0)
|
||||
smt_state = thread + 1;
|
||||
else if (smt_state > 0)
|
||||
- smt_state = -1; /* mix of SMT modes */
|
||||
+ smt_state = 0; /* mix of SMT modes */
|
||||
}
|
||||
}
|
||||
|
||||
@@ -257,7 +257,7 @@ int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu,
|
||||
printf("SMT=1\n");
|
||||
else
|
||||
printf("SMT is off\n");
|
||||
- } else if (smt_state == -1) {
|
||||
+ } else if (smt_state == 0) {
|
||||
for (thread = 0; thread < threads_per_cpu; thread++) {
|
||||
if (CPU_COUNT_S(cpu_state_size,
|
||||
cpu_states[thread])) {
|
||||
diff --git a/src/lparstat.c b/src/lparstat.c
|
||||
index eebba1f..a9e7bce 100644
|
||||
--- a/src/lparstat.c
|
||||
+++ b/src/lparstat.c
|
||||
@@ -884,13 +884,15 @@ void get_smt_mode(struct sysentry *se, char *buf)
|
||||
}
|
||||
|
||||
smt_state = parse_smt_state();
|
||||
- if (smt_state < 0) {
|
||||
+ if (smt_state == -1) {
|
||||
fprintf(stderr, "Failed to get smt state\n");
|
||||
return;
|
||||
}
|
||||
|
||||
if (smt_state == 1)
|
||||
sprintf(buf, "Off");
|
||||
+ else if (smt_state == 0)
|
||||
+ sprintf(buf, "Mixed");
|
||||
else
|
||||
sprintf(buf, "%d", smt_state);
|
||||
}
|
@ -1,98 +0,0 @@
|
||||
commit b1b9e76de0f3ab1dfcd9426779fa20fd77cd5625
|
||||
Author: Luciano Chavez <lnx1138@linux.ibm.com>
|
||||
Date: Wed Aug 24 21:11:32 2022 -0500
|
||||
|
||||
lsslot: Fix lsslot -c mem output when using 4GB LMB size
|
||||
|
||||
When using a LMB size of 4GB, the output of lsslot -c mem would get
|
||||
reported incorrectly as:
|
||||
|
||||
Dynamic Reconfiguration Memory (LMB size 0x0)
|
||||
:
|
||||
DRC Index: 80000001 Address: 100000000
|
||||
Removable: No Associativity: (index: 1) 0 1 4 9
|
||||
Section(s):
|
||||
|
||||
This patch changes the declaration of the _node_u._smem._lmb_size from
|
||||
a uint32_t to uint64_t to store the value properly. Any variables that
|
||||
store the lmb_size are also declared as uint64_t. In addition, we
|
||||
use the PRIx64 macro in printf statements to properly print the
|
||||
lmb_size value.
|
||||
|
||||
The patch also includes a necessary change to declare the global
|
||||
variable block_sz_bytes as a uint64_t to fix an infinite loop in
|
||||
the function get_mem_scns() when the above changes were introduced.
|
||||
|
||||
Signed-off-by: Luciano Chavez <lnx1138@linux.ibm.com>
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/src/drmgr/drmem.h b/src/drmgr/drmem.h
|
||||
index db5a47f..48108c5 100644
|
||||
--- a/src/drmgr/drmem.h
|
||||
+++ b/src/drmgr/drmem.h
|
||||
@@ -58,7 +58,7 @@ struct drconf_mem_v2 {
|
||||
#define LMB_REVERSE_SORT 1
|
||||
#define LMB_RANDOM_SORT 2
|
||||
|
||||
-extern int block_sz_bytes;
|
||||
+extern uint64_t block_sz_bytes;
|
||||
|
||||
struct lmb_list_head *get_lmbs(unsigned int);
|
||||
void free_lmbs(struct lmb_list_head *);
|
||||
diff --git a/src/drmgr/drslot_chrp_mem.c b/src/drmgr/drslot_chrp_mem.c
|
||||
index 3b78723..d37ee80 100644
|
||||
--- a/src/drmgr/drslot_chrp_mem.c
|
||||
+++ b/src/drmgr/drslot_chrp_mem.c
|
||||
@@ -33,7 +33,7 @@
|
||||
#include "drmem.h"
|
||||
#include "common_numa.h"
|
||||
|
||||
-int block_sz_bytes = 0;
|
||||
+uint64_t block_sz_bytes = 0;
|
||||
static char *state_strs[] = {"offline", "online"};
|
||||
|
||||
static char *usagestr = "-c mem {-a | -r} {-q <quantity> -p {variable_weight | ent_capacity} | {-q <quantity> | -s [<drc_name> | <drc_index>]}}";
|
||||
@@ -118,7 +118,7 @@ free_lmbs(struct lmb_list_head *lmb_list)
|
||||
static int
|
||||
get_mem_scns(struct dr_node *lmb)
|
||||
{
|
||||
- uint32_t lmb_sz = lmb->lmb_size;
|
||||
+ uint64_t lmb_sz = lmb->lmb_size;
|
||||
uint64_t phys_addr = lmb->lmb_address;
|
||||
uint32_t mem_scn;
|
||||
int rc = 0;
|
||||
diff --git a/src/drmgr/lsslot.c b/src/drmgr/lsslot.c
|
||||
index 87f876e..83e9e85 100644
|
||||
--- a/src/drmgr/lsslot.c
|
||||
+++ b/src/drmgr/lsslot.c
|
||||
@@ -741,7 +741,7 @@ int print_drconf_mem(struct lmb_list_head *lmb_list)
|
||||
if (usr_drc_name)
|
||||
drc_index = strtol(usr_drc_name, NULL, 0);
|
||||
|
||||
- printf("Dynamic Reconfiguration Memory (LMB size 0x%x)\n",
|
||||
+ printf("Dynamic Reconfiguration Memory (LMB size 0x%"PRIx64")\n",
|
||||
lmb_list->lmbs->lmb_size);
|
||||
|
||||
for (lmb = lmb_list->lmbs; lmb; lmb = lmb->next) {
|
||||
@@ -808,7 +808,7 @@ int lsslot_chrp_mem(void)
|
||||
if (lmb_list->drconf_buf) {
|
||||
print_drconf_mem(lmb_list);
|
||||
} else {
|
||||
- printf("lmb size: 0x%x\n", lmb_list->lmbs->lmb_size);
|
||||
+ printf("lmb size: 0x%"PRIx64"\n", lmb_list->lmbs->lmb_size);
|
||||
printf("%-20s %-5s %c %s\n", "Memory Node", "Name", 'R',
|
||||
"Sections");
|
||||
printf("%-20s %-5s %c %s\n", "-----------", "----", '-',
|
||||
diff --git a/src/drmgr/ofdt.h b/src/drmgr/ofdt.h
|
||||
index 26c943a..bd90810 100644
|
||||
--- a/src/drmgr/ofdt.h
|
||||
+++ b/src/drmgr/ofdt.h
|
||||
@@ -94,7 +94,7 @@ struct dr_node {
|
||||
union {
|
||||
struct mem_info {
|
||||
uint64_t _address;
|
||||
- uint32_t _lmb_size;
|
||||
+ uint64_t _lmb_size;
|
||||
uint32_t _lmb_aa_index;
|
||||
struct mem_scn *_mem_scns;
|
||||
struct of_node *_of_node;
|
@ -1,29 +0,0 @@
|
||||
commit e1f1deb06d9168a95a381a2236e1d8c693d3d229
|
||||
Author: Luciano Chavez <lnx1138@linux.ibm.com>
|
||||
Date: Wed Aug 24 21:17:54 2022 -0500
|
||||
|
||||
lsslot: Explicity declare that lmb_address be displayed in hexadecimal
|
||||
|
||||
A printf statement used is lsslot.c was specifying the macro PRIu64 to
|
||||
display the lmb_address. Depending on the compilation, this would
|
||||
either display as a hexadecimal or decimal value.
|
||||
|
||||
This patch replaces PRIu64 with PRIx64 to explicitly declare to print
|
||||
the value as hexadecimal as that was is normally expected of an address.
|
||||
|
||||
Signed-off-by: Luciano Chavez <lnx1138@linux.ibm.com>
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/src/drmgr/lsslot.c b/src/drmgr/lsslot.c
|
||||
index 7ea0f8b..87f876e 100644
|
||||
--- a/src/drmgr/lsslot.c
|
||||
+++ b/src/drmgr/lsslot.c
|
||||
@@ -756,7 +756,7 @@ int print_drconf_mem(struct lmb_list_head *lmb_list)
|
||||
printf("%s: %s\n", lmb->drc_name,
|
||||
lmb->is_owned ? "" : "Not Owned");
|
||||
|
||||
- printf(" DRC Index: %x Address: %"PRIu64"\n",
|
||||
+ printf(" DRC Index: %x Address: %"PRIx64"\n",
|
||||
lmb->drc_index, lmb->lmb_address);
|
||||
printf(" Removable: %s Associativity: ",
|
||||
lmb->is_removable ? "Yes" : "No ");
|
@ -1,93 +0,0 @@
|
||||
commit f4c2b0d142f623e7dd28a5d685e446d41be75601
|
||||
Author: Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
|
||||
Date: Thu Aug 25 12:19:27 2022 +0530
|
||||
|
||||
lparstat: Fix display of mode for dedicated-donating partition
|
||||
|
||||
From the lparstat man page:
|
||||
mode
|
||||
Indicates whether the partition processor capacity is capped or uncapped
|
||||
allowing it to consume idle cycles from the shared pool. Dedicated LPAR
|
||||
is capped or donating.
|
||||
|
||||
However, on a dedicated partition, lparstat always displays the mode as
|
||||
'Capped' today. Fix this by using 'DedDonMode' field from lparcfg for
|
||||
determining the cycle donation status of a dedicated partition.
|
||||
|
||||
On a dedicated-donating partition:
|
||||
$ grep -e shared -e DedDonMode -e capped /proc/powerpc/lparcfg
|
||||
DedDonMode=1
|
||||
capped=1
|
||||
shared_processor_mode=0
|
||||
|
||||
Before this patch:
|
||||
$ lparstat
|
||||
|
||||
System Configuration
|
||||
type=Dedicated mode=Capped smt=8 lcpu=1 mem=3335424 kB cpus=0 ent=1.00
|
||||
|
||||
After this patch:
|
||||
$ lparstat
|
||||
|
||||
System Configuration
|
||||
type=Dedicated mode=Donating smt=8 lcpu=1 mem=3335424 kB cpus=0 ent=1.00
|
||||
|
||||
Signed-off-by: Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
|
||||
Reviewed-by: Nathan Lynch <nathanl@linux.ibm.com>
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/src/lparstat.c b/src/lparstat.c
|
||||
index 0b30fc9..e998e8c 100644
|
||||
--- a/src/lparstat.c
|
||||
+++ b/src/lparstat.c
|
||||
@@ -718,6 +718,16 @@ void get_capped_mode(struct sysentry *se, char *buf)
|
||||
sprintf(buf, "%s", value);
|
||||
}
|
||||
|
||||
+void get_dedicated_mode(struct sysentry *se, char *buf)
|
||||
+{
|
||||
+ const char *value = "Capped";
|
||||
+
|
||||
+ if (se->value[0] == '1')
|
||||
+ value = "Donating";
|
||||
+
|
||||
+ sprintf(buf, "%s", value);
|
||||
+}
|
||||
+
|
||||
void get_percent_entry(struct sysentry *se, char *buf)
|
||||
{
|
||||
float value;
|
||||
@@ -1057,7 +1067,10 @@ void print_system_configuration(void)
|
||||
get_sysdata("shared_processor_mode", &descr, value);
|
||||
offset = sprintf(buf, "type=%s ", value);
|
||||
sprintf(type, "%s", value);
|
||||
- get_sysdata("capped", &descr, value);
|
||||
+ if (!strcmp(value, "Dedicated"))
|
||||
+ get_sysdata("DedDonMode", &descr, value);
|
||||
+ else
|
||||
+ get_sysdata("capped", &descr, value);
|
||||
offset += sprintf(buf + offset, "mode=%s ", value);
|
||||
get_sysdata("smt_state", &descr, value);
|
||||
offset += sprintf(buf + offset, "smt=%s ", value);
|
||||
diff --git a/src/lparstat.h b/src/lparstat.h
|
||||
index 26ed4ba..b7c88e9 100644
|
||||
--- a/src/lparstat.h
|
||||
+++ b/src/lparstat.h
|
||||
@@ -47,6 +47,7 @@ typedef struct cpu_sysfs_file_desc cpu_sysfs_fd;
|
||||
|
||||
extern void get_smt_state(struct sysentry *, char *);
|
||||
extern void get_capped_mode(struct sysentry *, char *);
|
||||
+extern void get_dedicated_mode(struct sysentry *, char *);
|
||||
extern void get_memory_mode(struct sysentry *, char *);
|
||||
extern void get_percent_entry(struct sysentry *, char *);
|
||||
extern void get_phys_cpu_percentage(struct sysentry *, char *);
|
||||
@@ -110,7 +111,8 @@ struct sysentry system_data[] = {
|
||||
{.name = "DesVarCapWt",
|
||||
.descr = "Desired Variable Capacity Weight"},
|
||||
{.name = "DedDonMode",
|
||||
- .descr = "Dedicated Donation Mode"},
|
||||
+ .descr = "Dedicated Donation Mode",
|
||||
+ .get = &get_dedicated_mode},
|
||||
{.name = "partition_entitled_capacity",
|
||||
.descr = "Partition Entitled Capacity"},
|
||||
{.name = "system_active_processors",
|
@ -1,27 +0,0 @@
|
||||
commit acaf9c45a340f9bb49d6b21ba7ad60c21326ea73
|
||||
Author: Mingming Cao <mmc@linux.vnet.ibm.com>
|
||||
Date: Mon Nov 7 14:39:02 2022 -0800
|
||||
|
||||
hcnmgr: Fix setting primary slave across reboots
|
||||
|
||||
Using nmcli to set bonding of primary slave so that is set correctly
|
||||
across reboots.
|
||||
|
||||
Signed-off-by: Mingming Cao <mmc@linux.vnet.ibm.com>
|
||||
[tyreld: Reworded commit log]
|
||||
Signed-off-by: Tyrel Datwyler <tyreld@linux.ibm.com>
|
||||
|
||||
diff --git a/scripts/hcnmgr b/scripts/hcnmgr
|
||||
index 6946ff9..b5a6bfb 100644
|
||||
--- a/scripts/hcnmgr
|
||||
+++ b/scripts/hcnmgr
|
||||
@@ -375,7 +375,8 @@ do_config_vdevice_nm() {
|
||||
# if the device is primary, and link is up, force it as primary se
|
||||
if [[ $MODE == "primary" ]]; then
|
||||
hcnlog INFO "Change bonding primary slave to $DEVNAME"
|
||||
- echo "$DEVNAME" >"$BOND_PATH"/primary
|
||||
+ nmcli con mod id "$BONDNAME" +bond.options "primary=$DEVNAME"
|
||||
+ nmcli con up "$BONDNAME"
|
||||
fi
|
||||
|
||||
hcnlog DEBUG "do_config_vdevice: exit"
|
6
gating.yaml
Normal file
6
gating.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
--- !Policy
|
||||
product_versions:
|
||||
- rhel-10
|
||||
decision_context: osci_compose_gate
|
||||
rules:
|
||||
- !PassingTestCaseRule {test_case_name: baseos-ci.brew-build.tier1.functional}
|
@ -327,13 +327,13 @@ diff -up powerpc-utils-1.3.5/man/update_flash_nv.8.me powerpc-utils-1.3.5/man/up
|
||||
+.SH SEE ALSO
|
||||
+update_flash(8).
|
||||
+
|
||||
diff -up powerpc-utils-1.3.10/Makefile.am.me powerpc-utils-1.3.10/Makefile.am
|
||||
--- powerpc-utils-1.3.10/Makefile.am.me 2022-06-03 12:35:01.335312481 +0200
|
||||
+++ powerpc-utils-1.3.10/Makefile.am 2022-06-03 12:46:42.460763120 +0200
|
||||
@@ -48,7 +48,17 @@ man_MANS = \
|
||||
man/vcpustat.8 \
|
||||
diff -up powerpc-utils-1.3.11/Makefile.am.orig powerpc-utils-1.3.11/Makefile.am
|
||||
--- powerpc-utils-1.3.11/Makefile.am.orig 2023-01-24 22:20:20.885655802 +0100
|
||||
+++ powerpc-utils-1.3.11/Makefile.am 2023-01-24 22:22:36.291802414 +0100
|
||||
@@ -49,7 +49,18 @@ man_MANS = \
|
||||
man/rtas_dbg.8 \
|
||||
man/drmgr.8 \
|
||||
man/drmgr-hooks.8 \
|
||||
- man/lparnumascore.8
|
||||
+ man/lparnumascore.8 \
|
||||
+ man/lsdevinfo.8 \
|
||||
@ -346,6 +346,7 @@ diff -up powerpc-utils-1.3.10/Makefile.am.me powerpc-utils-1.3.10/Makefile.am
|
||||
+ man/pseries_platform.8 \
|
||||
+ man/update_flash_nv.8 \
|
||||
+ man/hcnmgr.8
|
||||
+
|
||||
|
||||
EXTRA_DIST += $(bin_SCRIPTS) $(sbin_SCRIPTS) $(man_MANS)
|
||||
|
163
powerpc-utils-1.3.13-cpu_info_helpers.patch
Normal file
163
powerpc-utils-1.3.13-cpu_info_helpers.patch
Normal file
@ -0,0 +1,163 @@
|
||||
commit 54cf30c7d274c8aab2a7ae589ab056f52dfffc62
|
||||
Author: Aboorva Devarajan <aboorvad@linux.ibm.com>
|
||||
Date: Sat Dec 7 21:54:44 2024 -0500
|
||||
|
||||
cpu_info_helpers: Add helper function to retrieve present CPU core list
|
||||
|
||||
Introduce get_present_core_list helper function to accurately parse
|
||||
and retrieve the list of present CPU cores, addressing gaps in core
|
||||
numbering caused by dynamic addition or removal of CPUs (via CPU DLPAR
|
||||
operation)
|
||||
|
||||
Utilizes the present CPU list from `sys/devices/system/cpu/present`
|
||||
to handle non-contiguous CPU IDs. Accurately maps core IDs to CPUs
|
||||
considering specified number of threads per CPU, addressing gaps in
|
||||
core numbering.
|
||||
|
||||
Signed-off-by: Aboorva Devarajan <aboorvad@linux.ibm.com>
|
||||
|
||||
diff --git a/src/common/cpu_info_helpers.c b/src/common/cpu_info_helpers.c
|
||||
index 8c57db8..756e792 100644
|
||||
--- a/src/common/cpu_info_helpers.c
|
||||
+++ b/src/common/cpu_info_helpers.c
|
||||
@@ -203,6 +203,113 @@ int __get_one_smt_state(int core, int threads_per_cpu)
|
||||
return smt_state;
|
||||
}
|
||||
|
||||
+int get_present_cpu_count(void)
|
||||
+{
|
||||
+ int start, end, total_cpus = 0;
|
||||
+ size_t len = 0;
|
||||
+ char *line = NULL;
|
||||
+ FILE *fp;
|
||||
+ char *token;
|
||||
+
|
||||
+ fp = fopen(CPU_PRESENT_PATH, "r");
|
||||
+ if (!fp) {
|
||||
+ perror("Error opening CPU_PRESENT_PATH");
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ if (getline(&line, &len, fp) == -1) {
|
||||
+ perror("Error reading CPU_PRESENT_PATH");
|
||||
+ fclose(fp);
|
||||
+ free(line);
|
||||
+ return -1;
|
||||
+ }
|
||||
+ fclose(fp);
|
||||
+
|
||||
+ token = strtok(line, ",");
|
||||
+ while (token) {
|
||||
+ if (sscanf(token, "%d-%d", &start, &end) == 2) {
|
||||
+ total_cpus += (end - start + 1);
|
||||
+ } else if (sscanf(token, "%d", &start) == 1) {
|
||||
+ total_cpus++;
|
||||
+ }
|
||||
+ token = strtok(NULL, ",");
|
||||
+ }
|
||||
+
|
||||
+ free(line);
|
||||
+ return total_cpus;
|
||||
+}
|
||||
+
|
||||
+int get_present_core_list(int **present_cores, int *num_present_cores, int threads_per_cpu)
|
||||
+{
|
||||
+ FILE *fp = NULL;
|
||||
+ char *line = NULL;
|
||||
+ char *token = NULL;
|
||||
+ size_t len = 0;
|
||||
+ ssize_t read;
|
||||
+ int core_count = 0;
|
||||
+ int core_list_size;
|
||||
+ int *cores = NULL;
|
||||
+ int start, end, i;
|
||||
+
|
||||
+ if (threads_per_cpu <= 0) {
|
||||
+ fprintf(stderr, "Invalid threads_per_cpu value, got %d expected >= 1\n", threads_per_cpu);
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ core_list_size = get_present_cpu_count() / threads_per_cpu;
|
||||
+ if (core_list_size <= 0) {
|
||||
+ fprintf(stderr, "Error while calculating core list size\n");
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ cores = malloc(core_list_size * sizeof(int));
|
||||
+ if (!cores) {
|
||||
+ perror("Memory allocation failed");
|
||||
+ goto cleanup;
|
||||
+ }
|
||||
+
|
||||
+ fp = fopen(CPU_PRESENT_PATH, "r");
|
||||
+ if (!fp) {
|
||||
+ perror("Error opening file");
|
||||
+ goto cleanup;
|
||||
+ }
|
||||
+
|
||||
+ read = getline(&line, &len, fp);
|
||||
+ if (read == -1) {
|
||||
+ perror("Error reading file");
|
||||
+ goto cleanup;
|
||||
+ }
|
||||
+
|
||||
+ token = strtok(line, ",");
|
||||
+ while (token) {
|
||||
+ if (sscanf(token, "%d-%d", &start, &end) == 2) {
|
||||
+ for (i = start; i <= end; i++) {
|
||||
+ if (i % threads_per_cpu == 0) {
|
||||
+ cores[core_count++] = i / threads_per_cpu;
|
||||
+ }
|
||||
+ }
|
||||
+ } else if (sscanf(token, "%d", &start) == 1) {
|
||||
+ if (start % threads_per_cpu == 0) {
|
||||
+ cores[core_count++] = start / threads_per_cpu;
|
||||
+ }
|
||||
+ }
|
||||
+ token = strtok(NULL, ",");
|
||||
+ }
|
||||
+
|
||||
+ *present_cores = cores;
|
||||
+ *num_present_cores = core_count;
|
||||
+ free(line);
|
||||
+ return 0;
|
||||
+
|
||||
+cleanup:
|
||||
+ if (fp) {
|
||||
+ fclose(fp);
|
||||
+ }
|
||||
+ free(line);
|
||||
+ free(cores);
|
||||
+ return -1;
|
||||
+}
|
||||
+
|
||||
static void print_cpu_list(const cpu_set_t *cpuset, int cpuset_size,
|
||||
int cpus_in_system)
|
||||
{
|
||||
diff --git a/src/common/cpu_info_helpers.h b/src/common/cpu_info_helpers.h
|
||||
index c063fff..77e6ad7 100644
|
||||
--- a/src/common/cpu_info_helpers.h
|
||||
+++ b/src/common/cpu_info_helpers.h
|
||||
@@ -24,9 +24,10 @@
|
||||
#ifndef _CPU_INFO_HELPERS_H
|
||||
#define _CPU_INFO_HELPERS_H
|
||||
|
||||
-#define SYSFS_CPUDIR "/sys/devices/system/cpu/cpu%d"
|
||||
-#define SYSFS_SUBCORES "/sys/devices/system/cpu/subcores_per_core"
|
||||
-#define INTSERV_PATH "/proc/device-tree/cpus/%s/ibm,ppc-interrupt-server#s"
|
||||
+#define SYSFS_CPUDIR "/sys/devices/system/cpu/cpu%d"
|
||||
+#define SYSFS_SUBCORES "/sys/devices/system/cpu/subcores_per_core"
|
||||
+#define INTSERV_PATH "/proc/device-tree/cpus/%s/ibm,ppc-interrupt-server#s"
|
||||
+#define CPU_PRESENT_PATH "/sys/devices/system/cpu/present"
|
||||
|
||||
#define SYSFS_PATH_MAX 128
|
||||
|
||||
@@ -39,6 +40,8 @@ extern int num_subcores(void);
|
||||
extern int get_attribute(char *path, const char *fmt, int *value);
|
||||
extern int get_cpu_info(int *threads_per_cpu, int *cpus_in_system,
|
||||
int *threads_in_system);
|
||||
+extern int get_present_core_list(int **present_cores, int *num_present_cores,
|
||||
+ int threads_per_cpu);
|
||||
extern int __is_smt_capable(int threads_in_system);
|
||||
extern int __get_one_smt_state(int core, int threads_per_cpu);
|
||||
extern int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu,
|
@ -0,0 +1,749 @@
|
||||
commit e5fd24a6e35c3be78c96d6887e3774852bbe4674
|
||||
Author: Aboorva Devarajan <aboorvad@linux.ibm.com>
|
||||
Date: Wed Jan 1 22:56:07 2025 -0500
|
||||
|
||||
ppc64_cpu: Fix handling of non-contiguous CPU IDs
|
||||
|
||||
In ppc64le environments, adding or removing CPUs dynamically through
|
||||
DLPAR can create gaps in CPU IDs, such as `0-103,120-151`, in this
|
||||
case CPUs 104-119 are missing.
|
||||
|
||||
ppc64_cpu doesn't handles this scenario and always considers CPU IDs
|
||||
to be contiguous causing issues in core numbering, cpu info and SMT
|
||||
mode reporting.
|
||||
|
||||
To illustrate the issues this patch fixes, consider the following
|
||||
system configuration:
|
||||
|
||||
$ lscpu
|
||||
Architecture: ppc64le
|
||||
Byte Order: Little Endian
|
||||
CPU(s): 136
|
||||
On-line CPU(s) list: 0-103,120-151
|
||||
|
||||
**Note: CPU IDs are non-contiguous**
|
||||
|
||||
-----------------------------------------------------------------
|
||||
Before Patch:
|
||||
-----------------------------------------------------------------
|
||||
|
||||
$ ppc64_cpu --info
|
||||
Core 0: 0* 1* 2* 3* 4* 5* 6* 7*
|
||||
Core 1: 8* 9* 10* 11* 12* 13* 14* 15*
|
||||
Core 2: 16* 17* 18* 19* 20* 21* 22* 23*
|
||||
Core 3: 24* 25* 26* 27* 28* 29* 30* 31*
|
||||
Core 4: 32* 33* 34* 35* 36* 37* 38* 39*
|
||||
Core 5: 40* 41* 42* 43* 44* 45* 46* 47*
|
||||
Core 6: 48* 49* 50* 51* 52* 53* 54* 55*
|
||||
Core 7: 56* 57* 58* 59* 60* 61* 62* 63*
|
||||
Core 8: 64* 65* 66* 67* 68* 69* 70* 71*
|
||||
Core 9: 72* 73* 74* 75* 76* 77* 78* 79*
|
||||
Core 10: 80* 81* 82* 83* 84* 85* 86* 87*
|
||||
Core 11: 88* 89* 90* 91* 92* 93* 94* 95*
|
||||
Core 12: 96* 97* 98* 99* 100* 101* 102* 103*
|
||||
........................................................... *gap*
|
||||
Core 13: 120* 121* 122* 123* 124* 125* 126* 127*
|
||||
Core 14: 128* 129* 130* 131* 132* 133* 134* 135*
|
||||
Core 15: 136* 137* 138* 139* 140* 141* 142* 143*
|
||||
Core 16: 144* 145* 146* 147* 148* 149* 150* 151*
|
||||
|
||||
**Although the CPU IDs are non contiguous, associated core IDs are
|
||||
represented in contiguous order, which makes it harder to interpret
|
||||
this clearly.**
|
||||
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
$ ppc64_cpu --cores-on
|
||||
Number of cores online = 15
|
||||
|
||||
**Expected: Number of online cores = 17**
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
$ ppc64_cpu --offline-cores
|
||||
Cores offline = 13, 14
|
||||
|
||||
**Even though no cores are actually offline, two cores (13, 14)
|
||||
are displayed as offline.**
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
$ ppc64_cpu --online-cores
|
||||
Cores online = 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 15, 16
|
||||
|
||||
**The list of online cores is missing two cores (13, 14).**
|
||||
-----------------------------------------------------------------
|
||||
|
||||
To resolve this, use the present CPU list from sysfs to assign
|
||||
numbers to CPUs and cores, which will make this accurate.
|
||||
|
||||
$ cat /sys/devices/system/cpu/present
|
||||
0-103,120-151
|
||||
|
||||
With this patch, the command output correctly reflects the
|
||||
current CPU configuration, providing a more precise representation
|
||||
of the system state.
|
||||
|
||||
-----------------------------------------------------------------
|
||||
After Patch:
|
||||
-----------------------------------------------------------------
|
||||
|
||||
$ ppc64_cpu --info
|
||||
Core 0: 0* 1* 2* 3* 4* 5* 6* 7*
|
||||
Core 1: 8* 9* 10* 11* 12* 13* 14* 15*
|
||||
Core 2: 16* 17* 18* 19* 20* 21* 22* 23*
|
||||
Core 3: 24* 25* 26* 27* 28* 29* 30* 31*
|
||||
Core 4: 32* 33* 34* 35* 36* 37* 38* 39*
|
||||
Core 5: 40* 41* 42* 43* 44* 45* 46* 47*
|
||||
Core 6: 48* 49* 50* 51* 52* 53* 54* 55*
|
||||
Core 7: 56* 57* 58* 59* 60* 61* 62* 63*
|
||||
Core 8: 64* 65* 66* 67* 68* 69* 70* 71*
|
||||
Core 9: 72* 73* 74* 75* 76* 77* 78* 79*
|
||||
Core 10: 80* 81* 82* 83* 84* 85* 86* 87*
|
||||
Core 11: 88* 89* 90* 91* 92* 93* 94* 95*
|
||||
Core 12: 96* 97* 98* 99* 100* 101* 102* 103*
|
||||
........................................................... *gap*
|
||||
Core 15: 120* 121* 122* 123* 124* 125* 126* 127*
|
||||
Core 16: 128* 129* 130* 131* 132* 133* 134* 135*
|
||||
Core 17: 136* 137* 138* 139* 140* 141* 142* 143*
|
||||
Core 18: 144* 145* 146* 147* 148* 149* 150* 151*
|
||||
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
$ ppc64_cpu --cores-on
|
||||
Number of cores online = 17
|
||||
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
$ ppc64_cpu --offline-cores
|
||||
Cores offline =
|
||||
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
$ ppc64_cpu --online-cores
|
||||
Cores online = 0,1,2,3,4,5,6,7,8,9,10,11,12,15,16,17,18
|
||||
|
||||
-----------------------------------------------------------------
|
||||
|
||||
Signed-off-by: Aboorva Devarajan <aboorvad@linux.ibm.com>
|
||||
|
||||
diff --git a/src/common/cpu_info_helpers.c b/src/common/cpu_info_helpers.c
|
||||
index 756e792..e75cf6e 100644
|
||||
--- a/src/common/cpu_info_helpers.c
|
||||
+++ b/src/common/cpu_info_helpers.c
|
||||
@@ -311,67 +311,94 @@ cleanup:
|
||||
}
|
||||
|
||||
static void print_cpu_list(const cpu_set_t *cpuset, int cpuset_size,
|
||||
- int cpus_in_system)
|
||||
+ int threads_per_cpu)
|
||||
{
|
||||
- int core;
|
||||
+ int *present_cores = NULL;
|
||||
+ int num_present_cores;
|
||||
+ int start, end, i = 0;
|
||||
const char *comma = "";
|
||||
|
||||
- for (core = 0; core < cpus_in_system; core++) {
|
||||
- int begin = core;
|
||||
- if (CPU_ISSET_S(core, cpuset_size, cpuset)) {
|
||||
- while (CPU_ISSET_S(core+1, cpuset_size, cpuset))
|
||||
- core++;
|
||||
+ if (get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu) != 0) {
|
||||
+ fprintf(stderr, "Failed to get present_cores list\n");
|
||||
+ return;
|
||||
+ }
|
||||
|
||||
- if (core > begin)
|
||||
- printf("%s%d-%d", comma, begin, core);
|
||||
- else
|
||||
- printf("%s%d", comma, core);
|
||||
+ while (i < num_present_cores) {
|
||||
+ start = present_cores[i];
|
||||
+ if (CPU_ISSET_S(start, cpuset_size, cpuset)) {
|
||||
+ end = start;
|
||||
+ while (i + 1 < num_present_cores &&
|
||||
+ CPU_ISSET_S(present_cores[i + 1], cpuset_size, cpuset) &&
|
||||
+ present_cores[i + 1] == end + 1) {
|
||||
+ end = present_cores[++i];
|
||||
+ }
|
||||
+ if (start == end) {
|
||||
+ printf("%s%d", comma, start);
|
||||
+ } else {
|
||||
+ printf("%s%d-%d", comma, start, end);
|
||||
+ }
|
||||
comma = ",";
|
||||
}
|
||||
+ i++;
|
||||
}
|
||||
+ free(present_cores);
|
||||
}
|
||||
|
||||
-int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu,
|
||||
- bool print_smt_state)
|
||||
+int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu, bool print_smt_state)
|
||||
{
|
||||
- int thread, c, smt_state = 0;
|
||||
cpu_set_t **cpu_states = NULL;
|
||||
- int cpu_state_size = CPU_ALLOC_SIZE(cpus_in_system);
|
||||
- int start_cpu = 0, stop_cpu = cpus_in_system;
|
||||
+ int thread, smt_state = -1;
|
||||
+ int cpu_state_size;
|
||||
int rc = 0;
|
||||
+ int i, core_id, threads_online;
|
||||
+ int *present_cores = NULL;
|
||||
+ int num_present_cores;
|
||||
|
||||
- cpu_states = (cpu_set_t **)calloc(threads_per_cpu, sizeof(cpu_set_t));
|
||||
- if (!cpu_states)
|
||||
+ if (get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu) != 0) {
|
||||
+ fprintf(stderr, "Failed to get present core list\n");
|
||||
return -ENOMEM;
|
||||
+ }
|
||||
+ cpu_state_size = CPU_ALLOC_SIZE(num_present_cores);
|
||||
+ cpu_states = (cpu_set_t **)calloc(threads_per_cpu, sizeof(cpu_set_t *));
|
||||
+ if (!cpu_states) {
|
||||
+ rc = -ENOMEM;
|
||||
+ goto cleanup_present_cores;
|
||||
+ }
|
||||
|
||||
for (thread = 0; thread < threads_per_cpu; thread++) {
|
||||
- cpu_states[thread] = CPU_ALLOC(cpus_in_system);
|
||||
+ cpu_states[thread] = CPU_ALLOC(num_present_cores);
|
||||
+ if (!cpu_states[thread]) {
|
||||
+ rc = -ENOMEM;
|
||||
+ goto cleanup_cpu_states;
|
||||
+ }
|
||||
CPU_ZERO_S(cpu_state_size, cpu_states[thread]);
|
||||
}
|
||||
|
||||
- for (c = start_cpu; c < stop_cpu; c++) {
|
||||
- int threads_online = __get_one_smt_state(c, threads_per_cpu);
|
||||
-
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+ core_id = present_cores[i];
|
||||
+ threads_online = __get_one_smt_state(core_id, threads_per_cpu);
|
||||
if (threads_online < 0) {
|
||||
rc = threads_online;
|
||||
- goto cleanup_get_smt;
|
||||
+ goto cleanup_cpu_states;
|
||||
+ }
|
||||
+ if (threads_online) {
|
||||
+ CPU_SET_S(core_id, cpu_state_size, cpu_states[threads_online - 1]);
|
||||
}
|
||||
- if (threads_online)
|
||||
- CPU_SET_S(c, cpu_state_size,
|
||||
- cpu_states[threads_online - 1]);
|
||||
}
|
||||
|
||||
for (thread = 0; thread < threads_per_cpu; thread++) {
|
||||
if (CPU_COUNT_S(cpu_state_size, cpu_states[thread])) {
|
||||
- if (smt_state == 0)
|
||||
+ if (smt_state == -1)
|
||||
smt_state = thread + 1;
|
||||
else if (smt_state > 0)
|
||||
smt_state = 0; /* mix of SMT modes */
|
||||
}
|
||||
}
|
||||
|
||||
- if (!print_smt_state)
|
||||
- return smt_state;
|
||||
+ if (!print_smt_state) {
|
||||
+ rc = smt_state;
|
||||
+ goto cleanup_cpu_states;
|
||||
+ }
|
||||
|
||||
if (smt_state == 1) {
|
||||
if (numeric)
|
||||
@@ -380,11 +407,9 @@ int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu,
|
||||
printf("SMT is off\n");
|
||||
} else if (smt_state == 0) {
|
||||
for (thread = 0; thread < threads_per_cpu; thread++) {
|
||||
- if (CPU_COUNT_S(cpu_state_size,
|
||||
- cpu_states[thread])) {
|
||||
+ if (CPU_COUNT_S(cpu_state_size, cpu_states[thread])) {
|
||||
printf("SMT=%d: ", thread + 1);
|
||||
- print_cpu_list(cpu_states[thread],
|
||||
- cpu_state_size, cpus_in_system);
|
||||
+ print_cpu_list(cpu_states[thread], cpu_state_size, threads_per_cpu);
|
||||
printf("\n");
|
||||
}
|
||||
}
|
||||
@@ -392,9 +417,12 @@ int __do_smt(bool numeric, int cpus_in_system, int threads_per_cpu,
|
||||
printf("SMT=%d\n", smt_state);
|
||||
}
|
||||
|
||||
-cleanup_get_smt:
|
||||
+cleanup_cpu_states:
|
||||
for (thread = 0; thread < threads_per_cpu; thread++)
|
||||
CPU_FREE(cpu_states[thread]);
|
||||
+ free(cpu_states);
|
||||
+cleanup_present_cores:
|
||||
+ free(present_cores);
|
||||
|
||||
return rc;
|
||||
}
|
||||
diff --git a/src/ppc64_cpu.c b/src/ppc64_cpu.c
|
||||
index 4017240..0233d29 100644
|
||||
--- a/src/ppc64_cpu.c
|
||||
+++ b/src/ppc64_cpu.c
|
||||
@@ -52,7 +52,6 @@
|
||||
|
||||
#define DSCR_DEFAULT_PATH "/sys/devices/system/cpu/dscr_default"
|
||||
|
||||
-#define MAX_NR_CPUS 1024
|
||||
#define DIAGNOSTICS_RUN_MODE 42
|
||||
#define CPU_OFFLINE -1
|
||||
|
||||
@@ -266,21 +265,31 @@ static int get_one_smt_state(int core)
|
||||
static int get_smt_state(void)
|
||||
{
|
||||
int smt_state = -1;
|
||||
- int i;
|
||||
+ int i, rc;
|
||||
+ int *present_cores;
|
||||
+ int num_present_cores;
|
||||
+
|
||||
+ rc = get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu);
|
||||
+ if (rc != 0) {
|
||||
+ return -1;
|
||||
+ }
|
||||
+
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+ int cpu_state = get_one_smt_state(present_cores[i]);
|
||||
|
||||
- for (i = 0; i < cpus_in_system; i++) {
|
||||
- int cpu_state = get_one_smt_state(i);
|
||||
if (cpu_state == 0)
|
||||
continue;
|
||||
|
||||
if (smt_state == -1)
|
||||
smt_state = cpu_state;
|
||||
+
|
||||
if (smt_state != cpu_state) {
|
||||
smt_state = -1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
+ free(present_cores);
|
||||
return smt_state;
|
||||
}
|
||||
|
||||
@@ -313,20 +322,36 @@ static int set_smt_state(int smt_state)
|
||||
{
|
||||
int i, j, rc = 0;
|
||||
int error = 0;
|
||||
+ int cpu_base, cpu_id, core_id;
|
||||
+ int *present_cores = NULL;
|
||||
+ int num_present_cores;
|
||||
|
||||
if (!sysattr_is_writeable("online")) {
|
||||
perror("Cannot set smt state");
|
||||
return -1;
|
||||
}
|
||||
|
||||
- for (i = 0; i < threads_in_system; i += threads_per_cpu) {
|
||||
+ rc = get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu);
|
||||
+
|
||||
+ if (rc != 0) {
|
||||
+ fprintf(stderr, "Failed to retrieve present core list\n");
|
||||
+ return rc;
|
||||
+ }
|
||||
+
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+
|
||||
+ core_id = present_cores[i];
|
||||
+ cpu_base = core_id * threads_per_cpu;
|
||||
+
|
||||
/* Online means any thread on this core running, so check all
|
||||
* threads in the core, not just the first. */
|
||||
for (j = 0; j < threads_per_cpu; j++) {
|
||||
- if (!cpu_online(i + j))
|
||||
+ cpu_id = cpu_base + j;
|
||||
+
|
||||
+ if (!cpu_online(cpu_id))
|
||||
continue;
|
||||
|
||||
- rc = set_one_smt_state(i, smt_state);
|
||||
+ rc = set_one_smt_state(cpu_base, smt_state);
|
||||
/* Record an error, but do not check result: if we
|
||||
* have failed to set this core, keep trying
|
||||
* subsequent ones. */
|
||||
@@ -336,10 +361,13 @@ static int set_smt_state(int smt_state)
|
||||
}
|
||||
}
|
||||
|
||||
+ free(present_cores);
|
||||
+
|
||||
if (error) {
|
||||
- fprintf(stderr, "One or more cpus could not be on/offlined\n");
|
||||
+ fprintf(stderr, "One or more CPUs could not be on/offlined\n");
|
||||
return -1;
|
||||
}
|
||||
+
|
||||
return rc;
|
||||
}
|
||||
|
||||
@@ -459,8 +487,8 @@ static int do_subcores_per_core(char *state)
|
||||
}
|
||||
printf("Subcores per core: %d\n", subcore_state);
|
||||
} else {
|
||||
- /* Kernel decides what values are valid, so no need to
|
||||
- * check here. */
|
||||
+ /* Kernel decides what values are valid, so no need to
|
||||
+ * check here. */
|
||||
subcore_state = strtol(state, NULL, 0);
|
||||
rc = set_attribute(SYSFS_SUBCORES, "%d", subcore_state);
|
||||
if (rc) {
|
||||
@@ -1038,7 +1066,7 @@ static int set_all_threads_off(int cpu, int smt_state)
|
||||
snprintf(path, SYSFS_PATH_MAX, SYSFS_CPUDIR"/%s", i, "online");
|
||||
rc = offline_thread(path);
|
||||
if (rc == -1)
|
||||
- printf("Unable to take cpu%d offline", i);
|
||||
+ printf("Unable to take CPU %d offline\n", i);
|
||||
}
|
||||
|
||||
return rc;
|
||||
@@ -1065,11 +1093,13 @@ static int set_one_core(int smt_state, int core, int state)
|
||||
static int do_online_cores(char *cores, int state)
|
||||
{
|
||||
int smt_state;
|
||||
- int *core_state, *desired_core_state;
|
||||
+ int *core_state = NULL, *desired_core_state = NULL;
|
||||
int i, rc = 0;
|
||||
- int core;
|
||||
+ int core, valid = 0, core_idx = 0;
|
||||
char *str, *token, *end_token;
|
||||
bool first_core = true;
|
||||
+ int *present_cores = NULL;
|
||||
+ int num_present_cores;
|
||||
|
||||
if (cores) {
|
||||
if (!sysattr_is_writeable("online")) {
|
||||
@@ -1083,49 +1113,62 @@ static int do_online_cores(char *cores, int state)
|
||||
}
|
||||
}
|
||||
|
||||
+ rc = get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu);
|
||||
+ if (rc != 0) {
|
||||
+ fprintf(stderr, "Failed to retrieve present core list\n");
|
||||
+ return rc;
|
||||
+ }
|
||||
+
|
||||
smt_state = get_smt_state();
|
||||
|
||||
- core_state = calloc(cpus_in_system, sizeof(int));
|
||||
- if (!core_state)
|
||||
+ core_state = calloc(num_present_cores, sizeof(int));
|
||||
+ if (!core_state) {
|
||||
+ free(present_cores);
|
||||
return -ENOMEM;
|
||||
+ }
|
||||
|
||||
- for (i = 0; i < cpus_in_system ; i++)
|
||||
- core_state[i] = (get_one_smt_state(i) > 0);
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+ core_state[i] = (get_one_smt_state(present_cores[i]) > 0);
|
||||
+ }
|
||||
|
||||
if (!cores) {
|
||||
printf("Cores %s = ", state == 0 ? "offline" : "online");
|
||||
- for (i = 0; i < cpus_in_system; i++) {
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
if (core_state[i] == state) {
|
||||
if (first_core)
|
||||
first_core = false;
|
||||
else
|
||||
printf(",");
|
||||
- printf("%d", i);
|
||||
+ printf("%d", present_cores[i]);
|
||||
}
|
||||
}
|
||||
printf("\n");
|
||||
free(core_state);
|
||||
+ free(present_cores);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (smt_state == -1) {
|
||||
printf("Bad or inconsistent SMT state: use ppc64_cpu --smt=on|off to set all\n"
|
||||
- "cores to have the same number of online threads to continue.\n");
|
||||
+ "cores to have the same number of online threads to continue.\n");
|
||||
do_info();
|
||||
+ free(present_cores);
|
||||
return -1;
|
||||
}
|
||||
|
||||
- desired_core_state = calloc(cpus_in_system, sizeof(int));
|
||||
+ desired_core_state = calloc(num_present_cores, sizeof(int));
|
||||
if (!desired_core_state) {
|
||||
free(core_state);
|
||||
+ free(present_cores);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
- for (i = 0; i < cpus_in_system; i++)
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
/*
|
||||
* Not specified on command-line
|
||||
*/
|
||||
desired_core_state[i] = -1;
|
||||
+ }
|
||||
|
||||
str = cores;
|
||||
while (1) {
|
||||
@@ -1141,42 +1184,57 @@ static int do_online_cores(char *cores, int state)
|
||||
rc = -1;
|
||||
continue;
|
||||
}
|
||||
- if (core >= cpus_in_system || core < 0) {
|
||||
+
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+ if (core == present_cores[i]) {
|
||||
+ valid = 1;
|
||||
+ core_idx = i;
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ if (!valid) {
|
||||
printf("Invalid core to %s: %d\n", state == 0 ? "offline" : "online", core);
|
||||
rc = -1;
|
||||
continue;
|
||||
}
|
||||
- desired_core_state[core] = state;
|
||||
+
|
||||
+ desired_core_state[core_idx] = state;
|
||||
}
|
||||
|
||||
if (rc) {
|
||||
- free(core_state);
|
||||
- free(desired_core_state);
|
||||
- return rc;
|
||||
+ goto cleanup;
|
||||
}
|
||||
|
||||
- for (i = 0; i < cpus_in_system; i++) {
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
if (desired_core_state[i] != -1) {
|
||||
- rc = set_one_core(smt_state, i, state);
|
||||
- if (rc)
|
||||
+ rc = set_one_core(smt_state, present_cores[i], state);
|
||||
+ if (rc) {
|
||||
+ fprintf(stderr, "Failed to set core %d to %s\n", present_cores[i], state == 0 ? "offline" : "online");
|
||||
break;
|
||||
+ }
|
||||
}
|
||||
}
|
||||
|
||||
+cleanup:
|
||||
free(core_state);
|
||||
free(desired_core_state);
|
||||
+ free(present_cores);
|
||||
+
|
||||
return rc;
|
||||
}
|
||||
|
||||
static int do_cores_on(char *state)
|
||||
{
|
||||
int smt_state;
|
||||
- int *core_state;
|
||||
- int cores_now_online = 0;
|
||||
- int i, rc;
|
||||
+ int cores_now_online = 0, core_id = 0;
|
||||
+ int i, rc = 0;
|
||||
int number_to_have, number_to_change = 0, number_changed = 0;
|
||||
+ int *core_state = NULL;
|
||||
int new_state;
|
||||
char *end_state;
|
||||
+ int *present_cores = NULL;
|
||||
+ int num_present_cores;
|
||||
|
||||
if (state) {
|
||||
if (!sysattr_is_writeable("online")) {
|
||||
@@ -1194,24 +1252,33 @@ static int do_cores_on(char *state)
|
||||
if (!core_state)
|
||||
return -ENOMEM;
|
||||
|
||||
- for (i = 0; i < cpus_in_system ; i++) {
|
||||
- core_state[i] = (get_one_smt_state(i) > 0);
|
||||
- if (core_state[i])
|
||||
+ rc = get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu);
|
||||
+ if (rc != 0) {
|
||||
+ fprintf(stderr, "Failed to retrieve present core list\n");
|
||||
+ free(core_state);
|
||||
+ return rc;
|
||||
+ }
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+ int core = present_cores[i];
|
||||
+ core_state[i] = (get_one_smt_state(core) > 0);
|
||||
+ if (core_state[i]) {
|
||||
cores_now_online++;
|
||||
+ }
|
||||
}
|
||||
|
||||
if (!state) {
|
||||
printf("Number of cores online = %d\n", cores_now_online);
|
||||
- free(core_state);
|
||||
- return 0;
|
||||
+ rc = 0;
|
||||
+ goto cleanup;
|
||||
}
|
||||
|
||||
smt_state = get_smt_state();
|
||||
if (smt_state == -1) {
|
||||
printf("Bad or inconsistent SMT state: use ppc64_cpu --smt=on|off to set all\n"
|
||||
- "cores to have the same number of online threads to continue.\n");
|
||||
+ "cores to have the same number of online threads to continue.\n");
|
||||
do_info();
|
||||
- return -1;
|
||||
+ rc = -1;
|
||||
+ goto cleanup;
|
||||
}
|
||||
|
||||
if (!strcmp(state, "all")) {
|
||||
@@ -1227,15 +1294,16 @@ static int do_cores_on(char *state)
|
||||
}
|
||||
|
||||
if (number_to_have == cores_now_online) {
|
||||
- free(core_state);
|
||||
- return 0;
|
||||
+ rc = 0;
|
||||
+ goto cleanup;
|
||||
}
|
||||
|
||||
- if (number_to_have > cpus_in_system) {
|
||||
- printf("Cannot online more cores than are present.\n");
|
||||
+ if (number_to_have <= 0 || number_to_have > cpus_in_system) {
|
||||
+ printf("Error: Invalid number of cores requested: %d, possible values \
|
||||
+ should be in range: (1-%d)\n", number_to_have, cpus_in_system);
|
||||
do_cores_present();
|
||||
- free(core_state);
|
||||
- return -1;
|
||||
+ rc = -1;
|
||||
+ goto cleanup;
|
||||
}
|
||||
|
||||
if (number_to_have > cores_now_online) {
|
||||
@@ -1248,41 +1316,50 @@ static int do_cores_on(char *state)
|
||||
|
||||
if (new_state) {
|
||||
for (i = 0; i < cpus_in_system; i++) {
|
||||
+ core_id = present_cores[i];
|
||||
if (!core_state[i]) {
|
||||
- rc = set_one_core(smt_state, i, new_state);
|
||||
- if (!rc)
|
||||
+ rc = set_one_core(smt_state, core_id, new_state);
|
||||
+ if (!rc) {
|
||||
number_changed++;
|
||||
- if (number_changed >= number_to_change)
|
||||
+ }
|
||||
+ if (number_changed >= number_to_change) {
|
||||
break;
|
||||
+ }
|
||||
}
|
||||
}
|
||||
} else {
|
||||
- for (i = cpus_in_system - 1; i > 0; i--) {
|
||||
+ for (i = cpus_in_system - 1; i >= 0; i--) {
|
||||
+ core_id = present_cores[i];
|
||||
if (core_state[i]) {
|
||||
- rc = set_one_core(smt_state, i, new_state);
|
||||
- if (!rc)
|
||||
+ rc = set_one_core(smt_state, core_id, new_state);
|
||||
+ if (!rc) {
|
||||
number_changed++;
|
||||
- if (number_changed >= number_to_change)
|
||||
+ }
|
||||
+ if (number_changed >= number_to_change) {
|
||||
break;
|
||||
+ }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (number_changed != number_to_change) {
|
||||
cores_now_online = 0;
|
||||
- for (i = 0; i < cpus_in_system ; i++) {
|
||||
- if (cpu_online(i * threads_per_cpu))
|
||||
+ for (i = 0; i < cpus_in_system; i++) {
|
||||
+ core_id = present_cores[i];
|
||||
+ if (cpu_online(core_id * threads_per_cpu)) {
|
||||
cores_now_online++;
|
||||
+ }
|
||||
}
|
||||
printf("Failed to set requested number of cores online.\n"
|
||||
- "Requested: %d cores, Onlined: %d cores\n",
|
||||
- number_to_have, cores_now_online);
|
||||
- free(core_state);
|
||||
- return -1;
|
||||
+ "Requested: %d cores, Onlined: %d cores\n",
|
||||
+ number_to_have, cores_now_online);
|
||||
+ rc = -1;
|
||||
}
|
||||
|
||||
+cleanup:
|
||||
free(core_state);
|
||||
- return 0;
|
||||
+ free(present_cores);
|
||||
+ return rc;
|
||||
}
|
||||
|
||||
static bool core_is_online(int core)
|
||||
@@ -1294,35 +1371,45 @@ static int do_info(void)
|
||||
{
|
||||
int i, j, thread_num;
|
||||
char online;
|
||||
- int core, subcores = 0;
|
||||
+ int subcores = 0, core_id = 0;
|
||||
+ int *present_cores = NULL;
|
||||
+ int num_present_cores;
|
||||
|
||||
- if (is_subcore_capable())
|
||||
+ if (is_subcore_capable()) {
|
||||
subcores = num_subcores();
|
||||
+ }
|
||||
|
||||
- for (i = 0, core = 0; core < cpus_in_system; i++) {
|
||||
+ int rc = get_present_core_list(&present_cores, &num_present_cores, threads_per_cpu);
|
||||
+ if (rc != 0) {
|
||||
+ fprintf(stderr, "Failed to retrieve present core list\n");
|
||||
+ return rc;
|
||||
+ }
|
||||
|
||||
- if (!core_is_online(i))
|
||||
+ for (i = 0; i < num_present_cores; i++) {
|
||||
+ core_id = present_cores[i];
|
||||
+ if (!core_is_online(core_id)) {
|
||||
continue;
|
||||
+ }
|
||||
|
||||
if (subcores > 1) {
|
||||
- if (core % subcores == 0)
|
||||
- printf("Core %3d:\n", core/subcores);
|
||||
- printf(" Subcore %3d: ", core);
|
||||
+ if (core_id % subcores == 0) {
|
||||
+ printf("Core %3d:\n", core_id / subcores);
|
||||
+ }
|
||||
+ printf(" Subcore %3d: ", core_id);
|
||||
} else {
|
||||
- printf("Core %3d: ", core);
|
||||
+ printf("Core %3d: ", core_id);
|
||||
}
|
||||
|
||||
- thread_num = i * threads_per_cpu;
|
||||
- for (j = 0; j < threads_per_cpu; j++, thread_num++) {
|
||||
+ for (j = 0; j < threads_per_cpu; j++) {
|
||||
+ thread_num = core_id * threads_per_cpu + j;
|
||||
online = cpu_online(thread_num) ? '*' : ' ';
|
||||
printf("%4d%c ", thread_num, online);
|
||||
}
|
||||
printf("\n");
|
||||
- core++;
|
||||
}
|
||||
+ free(present_cores);
|
||||
return 0;
|
||||
}
|
||||
-
|
||||
static void usage(void)
|
||||
{
|
||||
printf(
|
@ -1,44 +1,34 @@
|
||||
Name: powerpc-utils
|
||||
Version: 1.3.10
|
||||
Release: 6%{?dist}
|
||||
Summary: PERL-based scripts for maintaining and servicing PowerPC systems
|
||||
Name: powerpc-utils
|
||||
Version: 1.3.13
|
||||
Release: 2%{?dist}
|
||||
Summary: PERL-based scripts for maintaining and servicing PowerPC systems
|
||||
|
||||
Group: System Environment/Base
|
||||
License: GPLv2
|
||||
URL: https://github.com/ibm-power-utilities/powerpc-utils
|
||||
Source0: https://github.com/ibm-power-utilities/%{name}/archive/v%{version}/%{name}-%{version}.tar.gz
|
||||
Source1: nx-gzip.udev
|
||||
Patch0: powerpc-utils-1.3.10-manpages.patch
|
||||
Patch1: powerpc-utils-1.3.10-distro.patch
|
||||
# bz#2121470, Fix lsslot -c mem output when using 4GB LMB size
|
||||
Patch3: powerpc-utils-b1b9e7-LMB_size_4GB.patch
|
||||
Patch4: powerpc-utils-e1f1de-lmb_address_in_hexadecimal.patch
|
||||
Patch5: powerpc-utils-fix_setting_primary_slave_across_reboots.patch
|
||||
Patch6: powerpc-utils-f4c2b0-fix_display_of_mode_for_dedicated_donating_partition.patch
|
||||
License: GPL-2.0-only
|
||||
URL: https://github.com/ibm-power-utilities/powerpc-utils
|
||||
Source0: https://github.com/ibm-power-utilities/%{name}/archive/v%{version}/%{name}-%{version}.tar.gz
|
||||
Source1: nx-gzip.udev
|
||||
Patch0: powerpc-utils-1.3.11-manpages.patch
|
||||
|
||||
# lparstat: Fix-negative-values-seen-while-running-lpar
|
||||
Patch10: powerpc-utils-1.3.10-lparstat-Fix-negative-values-seen-while-running-lpar.patch
|
||||
# report-mixed-SMT-state
|
||||
Patch11: powerpc-utils-1.3.10-lparstat-report-mixed-SMT-state.patch
|
||||
# Fix-offline-threads-uninitialized-entries
|
||||
Patch12: powerpc-utils-1.3.10-lparstat-Fix-offline-threads-uninitialized-entries.patch
|
||||
# upstream patches
|
||||
Patch100: powerpc-utils-1.3.13-cpu_info_helpers.patch
|
||||
Patch101: powerpc-utils-1.3.13-ppc64_cpu-Fix-handling-of-non-contiguous-CPU-IDs.patch
|
||||
|
||||
ExclusiveArch: ppc %{power64}
|
||||
ExclusiveArch: ppc %{power64}
|
||||
|
||||
BuildRequires: gcc
|
||||
BuildRequires: make
|
||||
BuildRequires: automake
|
||||
BuildRequires: doxygen
|
||||
BuildRequires: zlib-devel
|
||||
BuildRequires: librtas-devel >= 1.4.0
|
||||
BuildRequires: libservicelog-devel >= 1.0.1-2
|
||||
BuildRequires: perl-generators
|
||||
BuildRequires: systemd
|
||||
BuildRequires: numactl-devel
|
||||
BuildRequires: gcc
|
||||
BuildRequires: make
|
||||
BuildRequires: automake
|
||||
BuildRequires: doxygen
|
||||
BuildRequires: zlib-devel
|
||||
BuildRequires: librtas-devel >= 1.4.0
|
||||
BuildRequires: libservicelog-devel >= 1.0.1-2
|
||||
BuildRequires: perl-generators
|
||||
BuildRequires: systemd
|
||||
BuildRequires: numactl-devel
|
||||
|
||||
# rtas_dump explicit dependency
|
||||
Requires: perl(Data::Dumper)
|
||||
Requires: %{name}-core = %{version}-%{release}
|
||||
Requires: perl(Data::Dumper)
|
||||
Requires: %{name}-core = %{version}-%{release}
|
||||
|
||||
%description
|
||||
PERL-based scripts for maintaining and servicing PowerPC systems.
|
||||
@ -51,13 +41,22 @@ Requires(preun): systemd
|
||||
Requires(postun): systemd
|
||||
Requires: kmod
|
||||
Requires: which
|
||||
Requires: gawk
|
||||
Requires: bc
|
||||
Requires: findutils
|
||||
Requires: grep
|
||||
Requires: sed
|
||||
Requires: systemd-udev
|
||||
Requires: coreutils
|
||||
Requires: /usr/bin/awk
|
||||
Requires: /usr/bin/basename
|
||||
Requires: /usr/bin/bc
|
||||
Requires: /usr/bin/cat
|
||||
Requires: /usr/bin/cut
|
||||
Requires: /usr/bin/echo
|
||||
Requires: /usr/bin/find
|
||||
Requires: /bin/grep
|
||||
Requires: /usr/bin/head
|
||||
Requires: /usr/bin/ls
|
||||
Requires: /usr/bin/sed
|
||||
Requires: /usr/bin/tr
|
||||
Requires: /usr/bin/udevadm
|
||||
|
||||
# udev rule move
|
||||
Conflicts: libnxz < 0.63-3
|
||||
|
||||
%description core
|
||||
Core utilities for maintaining and servicing PowerPC systems.
|
||||
@ -66,12 +65,10 @@ Core utilities for maintaining and servicing PowerPC systems.
|
||||
%prep
|
||||
%autosetup -p1
|
||||
|
||||
|
||||
%build
|
||||
export CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing"
|
||||
./autogen.sh
|
||||
%configure --with-systemd=%{_unitdir} --disable-werror
|
||||
make %{?_smp_mflags}
|
||||
make %{?_smp_mflags} V=1
|
||||
|
||||
|
||||
%install
|
||||
@ -87,14 +84,11 @@ rm -rf $RPM_BUILD_ROOT/usr/share/doc/packages/powerpc-utils
|
||||
rm -f $RPM_BUILD_ROOT%{_pkgdocdir}/COPYING
|
||||
|
||||
# install udev rule for the nx-gzip accelerator
|
||||
install -pDm 644 %{SOURCE1} %{buildroot}%{_udevrulesdir}/90-nx-gzip.rules
|
||||
install -pDm 644 %{SOURCE1} %{buildroot}%{_udevrulesdir}/90-nx-gzip.rules
|
||||
|
||||
# remove init script and perl script. They are deprecated
|
||||
rm -rf $RPM_BUILD_ROOT/etc/init.d/ibmvscsis.sh $RPM_BUILD_ROOT/usr/sbin/vscsisadmin
|
||||
|
||||
# nvsetenv is just a wrapper to nvram
|
||||
ln -s nvram.8.gz $RPM_BUILD_ROOT/%{_mandir}/man8/nvsetenv.8.gz
|
||||
|
||||
# symlink uspchrp
|
||||
ln -s serv_config %{buildroot}%{_sbindir}/uspchrp
|
||||
ln -s serv_config.8 %{buildroot}%{_mandir}/man8/uspchrp.8
|
||||
@ -102,6 +96,12 @@ ln -s serv_config.8 %{buildroot}%{_mandir}/man8/uspchrp.8
|
||||
# deprecated, use sosreport instead
|
||||
rm -f $RPM_BUILD_ROOT%{_sbindir}/snap $RPM_BUILD_ROOT%{_mandir}/man8/snap.8*
|
||||
|
||||
# drop needless stuffs
|
||||
rm -rf $RPM_BUILD_ROOT%{_prefix}/lib/powerpc-utils
|
||||
|
||||
# keep service name
|
||||
mv $RPM_BUILD_ROOT%{_unitdir}/hcn-init-NetworkManager.service $RPM_BUILD_ROOT%{_unitdir}/hcn-init.service
|
||||
|
||||
%post core
|
||||
%systemd_post hcn-init.service
|
||||
# update the smt.state file with current SMT
|
||||
@ -121,18 +121,25 @@ systemctl enable hcn-init.service >/dev/null 2>&1 || :
|
||||
%files
|
||||
# PERL-based scripts for maintaining and servicing PowerPC systems
|
||||
%doc README Changelog
|
||||
%license COPYING
|
||||
%{_sbindir}/hvcsadmin
|
||||
%{_sbindir}/rtas_dump
|
||||
%{_mandir}/man8/hvcsadmin.8*
|
||||
%{_mandir}/man8/rtas_dump.8*
|
||||
|
||||
%files core
|
||||
%doc README Changelog
|
||||
%license COPYING
|
||||
%dir %{_localstatedir}/lib/powerpc-utils
|
||||
%config(noreplace) %{_localstatedir}/lib/powerpc-utils/smt.state
|
||||
%verify(not md5 size mtime) %config(noreplace) %{_localstatedir}/lib/powerpc-utils/smt.state
|
||||
%{_unitdir}/smtstate.service
|
||||
%{_unitdir}/smt_off.service
|
||||
%{_unitdir}/hcn-init.service
|
||||
%if 0%{?wicked}
|
||||
%{_unitdir}/hcn-init-wicked.service
|
||||
%else
|
||||
%exclude %{_unitdir}/hcn-init-wicked.service
|
||||
%endif
|
||||
%{_bindir}/amsstat
|
||||
%{_sbindir}/activate_firmware
|
||||
%{_sbindir}/bootlist
|
||||
@ -201,123 +208,182 @@ systemctl enable hcn-init.service >/dev/null 2>&1 || :
|
||||
%{_mandir}/man8/nvram.8*
|
||||
%{_mandir}/man8/ofpathname.8*
|
||||
%{_mandir}/man8/drmgr.8*
|
||||
%{_mandir}/man8/drmgr-hooks.8*
|
||||
%{_mandir}/man8/lparnumascore.8*
|
||||
|
||||
|
||||
%changelog
|
||||
* Wed Jul 26 2023 Than Ngo <than@redhat.com> - 1.3.10-6
|
||||
* Sat Feb 01 2025 Than Ngo <than@redhat.com> - 1.3.13-2
|
||||
- Resolves: RHEL-76285, Fix handling of non-contiguous CPU IDs
|
||||
|
||||
* Wed Nov 20 2024 Than Ngo <than@redhat.com> - 1.3.13-1
|
||||
- Update to 1.3.13
|
||||
Resolves: RHEL-24535
|
||||
|
||||
* Mon Nov 18 2024 Than Ngo <than@redhat.com> - 1.3.12-7
|
||||
- Add, multipath - drmgr support
|
||||
- Fix, SMT state is not honored when new CPUs are added dynamically
|
||||
Resolves: RHEL-62938
|
||||
|
||||
* Tue Oct 29 2024 Troy Dawson <tdawson@redhat.com> - 1.3.12-6
|
||||
- Bump release for October 2024 mass rebuild:
|
||||
Resolves: RHEL-64018
|
||||
|
||||
* Thu Jun 27 2024 Than Ngo <than@redhat.com> - 1.3.12-5
|
||||
- add verify attributes for smt.state to ignore the verification
|
||||
Related: RHEL-32262
|
||||
|
||||
* Mon Jun 24 2024 Troy Dawson <tdawson@redhat.com> - 1.3.12-4
|
||||
- Bump release for June 2024 mass rebuild
|
||||
|
||||
* Tue Apr 09 2024 Than Ngo <than@redhat.com> - 1.3.12-3
|
||||
- Resolves: RHEL-32262, update 1.3.12 for rhel-10
|
||||
|
||||
* Sun Apr 07 2024 Than Ngo <than@redhat.com> - 1.3.12-2
|
||||
- conditionally hcn-init-wicked.service
|
||||
|
||||
* Fri Apr 05 2024 Than Ngo <than@redhat.com> - 1.3.12-1
|
||||
- update to 1.3.12
|
||||
|
||||
* Fri Jan 26 2024 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.11-6
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild
|
||||
|
||||
* Sun Jan 21 2024 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.11-5
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild
|
||||
|
||||
* Tue Aug 01 2023 Than Ngo <than@redhat.com> - 1.3.11-4
|
||||
- Fix negative values seen while running lpar
|
||||
- Fix lparstat error with mixed SMT state
|
||||
Resolves: #2225135
|
||||
- Fix negative values seen while running lparstat with -E option
|
||||
|
||||
* Sat Jun 17 2023 Than Ngo <than@redhat.com> - 1.3.10-5
|
||||
- Resolves: #2207649, Add udev rule for the nx-gzip in to the core subpackage
|
||||
* Fri Jul 21 2023 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.11-3
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild
|
||||
|
||||
* Tue Apr 25 2023 Than Ngo <than@redhat.com> - 1.3.10-4
|
||||
- Resolves: #2166871, lparstat showing incorrect mode in a dedicated-donating LPAR
|
||||
* Thu Feb 16 2023 Than Ngo <than@redhat.com> - 1.3.11-2
|
||||
- migrated to SPDX license
|
||||
|
||||
* Mon Nov 28 2022 Than Ngo <than@redhat.com> - 1.3.10-3
|
||||
- Resolves: #2148878, HNV bond fails to come up with sriov interface as active slave
|
||||
* Tue Jan 24 2023 Than Ngo <than@redhat.com> - 1.3.11-1
|
||||
- update to 1.3.11
|
||||
|
||||
* Fri Oct 21 2022 Than Ngo <than@redhat.com> - 1.3.10-2
|
||||
- Resolves: #2121481, Fix lsslot -c mem output when using 4GB LMB size
|
||||
* Fri Jan 20 2023 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.10-6
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild
|
||||
|
||||
* Mon Jun 06 2022 Than Ngo <than@redhat.com> - 1.3.10-1
|
||||
- Resolves: #2051330, Linux Hybrid Network Virtualization update
|
||||
- Resolves: #2083469, smtstate --save command failed
|
||||
* Wed Nov 02 2022 Than Ngo <than@redhat.com> - 1.3.10-5
|
||||
- Fix lsslot -c mem output when using 4GB LMB size
|
||||
- Add NVMf-FC boot support for Power
|
||||
|
||||
* Fri May 13 2022 Than Ngo <than@redhat.com> - 1.3.9-3
|
||||
- Resolves: #2059459, add new DRC type description strings for latest PCIe slot types
|
||||
- Resolves: #2078514, Fix NM HNV setting primary slave
|
||||
- Resolves: #2083469, smtstate test failed as smtstate --save command failed
|
||||
* Fri Jul 22 2022 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.10-4
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild
|
||||
|
||||
* Thu Dec 09 2021 Than Ngo <than@redhat.com> - 1.3.9-1
|
||||
- Resolves: #2028690, rebase to 1.3.9
|
||||
* Tue Jun 14 2022 Jakub Čajka <jcajka@redhat.com> - 1.3.10-3
|
||||
- Add udev rule for the nx-gzip in to the core subpackage
|
||||
|
||||
* Thu Dec 02 2021 Than Ngo <than@redhat.com> - 1.3.8-10
|
||||
- Related: #2022225, increase release
|
||||
* Wed Jun 08 2022 Than Ngo <than@redhat.com> - 1.3.10-2
|
||||
- install smt.state as config file
|
||||
- drop nvsetenv which is included in upstream
|
||||
|
||||
* Thu Nov 11 2021 Than Ngo <than@redhat.com> - 1.3.8-9
|
||||
- Resolves: #2022225, enable support vnic as backend for HNV interfaces
|
||||
* Fri Jun 03 2022 Than Ngo <than@redhat.com> - 1.3.10-1
|
||||
- update to 1.3.10
|
||||
|
||||
* Thu Oct 07 2021 Than Ngo <than@redhat.com> - 1.3.8-8
|
||||
- lsdevinfo: optimize criteria filtering
|
||||
* Thu May 12 2022 Than Ngo <than@redhat.com> - 1.3.9-6
|
||||
- fix smtstate test failure, add default SMT_VALUE=1 in smt.state
|
||||
|
||||
* Fri Jul 16 2021 Than Ngo <than@redhat.com> - 1.3.8-7
|
||||
- Related: #1938420, Fix checking HCNID array size at boot time
|
||||
* Tue Feb 08 2022 Than Ngo <than@redhat.com> - 1.3.9-5
|
||||
- santize devspec output of a newline if one is present
|
||||
- fixed invalid hex number (multipath)
|
||||
|
||||
* Thu Apr 01 2021 Than Ngo <than@redhat.com> - 1.3.8-6
|
||||
* Fri Jan 21 2022 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.9-4
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild
|
||||
|
||||
* Tue Dec 07 2021 Than Ngo <than@redhat.com> - 1.3.9-3
|
||||
- enable support vnic as backend for HNV interface
|
||||
- fixed hexdump format
|
||||
- switch to systemd macros in scriptlets
|
||||
- marked smt.state as %%ghost
|
||||
|
||||
* Fri Jul 23 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.9-2
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild
|
||||
|
||||
* Mon Jul 19 2021 Than Ngo <than@redhat.com> - 1.3.9-1
|
||||
- Rebase to 1.3.9
|
||||
|
||||
* Mon May 31 2021 Than Ngo <than@redhat.com> - 1.3.8-9
|
||||
- Resolves: #1935658, New lparstat -x option to report the security flavor
|
||||
- Resolves: #1953818, Use od instead xxd
|
||||
- Resolves: #1938420, rebase patch fix_boot-time_bonding_interface_cleanup_and_avoid_use_ifcfg
|
||||
- Resolves: #1940358, ppc64_cpu --help does not list --version as an option
|
||||
- Resolves: #1938420, rebase patch fix_boot-time_bonding_interface_cleanup_and_avoid_use_ifcfg
|
||||
- Resolves: #1940358, ppc64_cpu --help does not list --version as an option
|
||||
- Resolves: #1951068, take care of NUMA topology when removing memory (DLPAR)
|
||||
|
||||
* Wed Feb 03 2021 Than Ngo <than@redhat.com> - 1.3.8-5
|
||||
- Resolves: #1924150, Fix boot-time bonding interface cleanup and avoid use ifcfg
|
||||
* Mon May 03 2021 Than Ngo <than@redhat.com> - 1.3.8-8
|
||||
- Use od instead xxd
|
||||
|
||||
* Mon Dec 21 2020 Than Ngo <than@redhat.com> - 1.3.8-4
|
||||
- Resolves: #1909526, additional patches to support Linux Hybrid Network Virtualization
|
||||
- Resolves: #1909135, move commands that dont depend on perl to core subpackage
|
||||
* Mon Feb 08 2021 Than Ngo <than@redhat.com> - 1.3.8-7
|
||||
- updated hcnmgr manpage
|
||||
|
||||
* Tue Oct 06 2020 Than Ngo <than@redhat.com> - 1.3.8-3
|
||||
- Resolves: #1868474, ofpathname: Use NVMe controller physical nsid
|
||||
- Resolves: #1885532, sys_ident: Skip length field from search
|
||||
* Mon Feb 08 2021 Than Ngo <than@redhat.com> - 1.3.8-6
|
||||
- Fix boot-time bonding interface cleanup and avoid use ifcfg
|
||||
|
||||
* Wed Jan 27 2021 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.8-5
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild
|
||||
|
||||
* Tue Dec 22 2020 Than Ngo <than@redhat.com> - 1.3.8-4
|
||||
- additional patches to support Linux Hybrid Network Virtualization
|
||||
- move commands that dont depend on perl to core subpackage
|
||||
- update hcnmgr patch
|
||||
- sys_ident: Skip length field from search
|
||||
- ofpathname: Use NVMe controller physical nsid
|
||||
|
||||
* Thu Oct 01 2020 Than Ngo <than@redhat.com> - 1.3.8-3
|
||||
- add hcnmgr man page
|
||||
|
||||
* Thu Oct 01 2020 Than Ngo <than@redhat.com> - 1.3.8-2
|
||||
- Related: #1853297, add missing hcnmgr manpage and Req on which
|
||||
- clean up systemd service
|
||||
|
||||
* Thu Oct 01 2020 Than Ngo <than@redhat.com> - 1.3.8-1
|
||||
- Resolves: #1853297, rebase to 1.3.8
|
||||
- Resolves: #1802181, SR-IOV - Linux Hybrid Network Virtualization
|
||||
- Resolves: #1844421, Include vcpustat
|
||||
* Fri Sep 04 2020 Than Ngo <than@redhat.com> - 1.3.8-1
|
||||
- update to 1.3.8
|
||||
|
||||
* Wed Jun 24 2020 Than Ngo <than@redhat.com> - 1.3.6-11
|
||||
- Resolves: #1847604, ofpathname: failed to boot
|
||||
* Tue Jul 28 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.7-7
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild
|
||||
|
||||
* Fri Jun 19 2020 Than Ngo <than@redhat.com> - 1.3.6-10
|
||||
- Resolves: #1848839, update lparstat man page with -E option
|
||||
* Thu Jul 09 2020 Than Ngo <than@redhat.com> - 1.3.7-6
|
||||
- Track and expose idle PURR and SPURR ticks
|
||||
- ofpathname: speed up l2of_scsi()
|
||||
- ofpathname: failed to boot
|
||||
- update lparstat man page with -E option
|
||||
- enable support for ibm,drc-info property
|
||||
|
||||
* Fri May 22 2020 Than Ngo <than@redhat.com> - 1.3.6-9
|
||||
- Resolves: #1837751, ofpathname: speed up l2of_scsi()
|
||||
* Sat Mar 28 2020 Than Ngo <than@redhat.com> - 1.3.7-5
|
||||
- move drmgr in core to avoid pulling in Perl
|
||||
|
||||
* Fri May 15 2020 Than Ngo <than@redhat.com> - 1.3.6-8
|
||||
- Related: #1783285, update the patches V4
|
||||
* Mon Mar 09 2020 Than Ngo <than@redhat.com> - 1.3.7-4
|
||||
- update_flash_nv: fixup null byte command substitution warning
|
||||
- drmgr: Fix segfault when running 'drmgr -c pmig -h'
|
||||
|
||||
* Wed May 13 2020 Than Ngo <than@redhat.com> - 1.3.6-7
|
||||
- Resolves: #1783285, Track and expose idle PURR and SPURR ticks
|
||||
* Thu Jan 30 2020 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.7-3
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild
|
||||
|
||||
* Wed Mar 25 2020 Than Ngo <than@redhat.com> - 1.3.6-6
|
||||
- Resolves: #1819566 - move drmgr in core to avoid pulling in Perl
|
||||
- Resolves: #1806870 - ignored null byte in input
|
||||
- Resolves: #1779197 - enable support for ibm,drc-info property
|
||||
* Thu Dec 19 2019 Than Ngo <than@redhat.com> - 1.3.7-2
|
||||
- add systemd service to set default system SMT mode
|
||||
|
||||
* Wed Dec 04 2019 Than Ngo <than@redhat.com> - 1.3.6-5
|
||||
- Resolves: #1779257, Safe bootlist update
|
||||
* Wed Dec 18 2019 Than Ngo <than@redhat.com> - 1.3.7-1
|
||||
- update to 1.3.7
|
||||
|
||||
* Wed Jul 24 2019 Than Ngo <than@redhat.com> - 1.3.6-4
|
||||
- Resolves: #1719372 - wrong disk gets booted after installation
|
||||
* Fri Jul 26 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.6-3
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild
|
||||
|
||||
* Fri Jun 07 2019 Than Ngo <than@redhat.com> - 1.3.6-3
|
||||
- Resolves: #1718254, improve handling of errors from subsidiary scripts
|
||||
* Sat Feb 02 2019 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.6-2
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild
|
||||
|
||||
* Wed Jun 05 2019 Than Ngo <than@redhat.com> - 1.3.6-2
|
||||
- Resolves: #1716425, lparstat and update_flash fixes
|
||||
* Wed Jan 16 2019 Than Ngo <than@redhat.com> - 1.3.6-1
|
||||
- update to 1.3.6
|
||||
|
||||
* Mon Apr 01 2019 Than Ngo <than@redhat.com> - 1.3.6-1
|
||||
- Resolves: #1666618, rebase to 1.3.6
|
||||
* Fri Nov 30 2018 Than Ngo <than@redhat.com> - 1.3.5-4
|
||||
- install missing pseries_platform and update_flash_nv man pages
|
||||
|
||||
* Tue Dec 04 2018 Than Ngo <than@redhat.com> - 1.3.5-5
|
||||
- Related: #1655903, add missing man pages
|
||||
* Thu Nov 29 2018 Than Ngo <than@redhat.com> - 1.3.5-3
|
||||
- added pseries_platform and update_flash_nv man pages
|
||||
|
||||
* Tue Dec 04 2018 Than Ngo <than@redhat.com> - 1.3.5-4
|
||||
- Resolves: #1655903, lsslot -c mem is not displaying any information
|
||||
|
||||
* Tue Nov 27 2018 Than Ngo <than@redhat.com> - 1.3.5-3
|
||||
- Resolves: #1653621, fix to display logical name using bootlist -o option
|
||||
|
||||
* Sat Nov 10 2018 Than Ngo <than@redhat.com> - 1.3.5-2
|
||||
- fix metadate issue detected by rpmdiff
|
||||
Related: #1608172
|
||||
* Fri Jul 13 2018 Fedora Release Engineering <releng@fedoraproject.org> - 1.3.5-2
|
||||
- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild
|
||||
|
||||
* Mon Jun 18 2018 Dan Horák <dan[at]danny.cz> - 1.3.5-1
|
||||
- Rebased to 1.3.5
|
Loading…
Reference in New Issue
Block a user