#include "strv.h"
#include "cctype.h"
-static int riscv_cmp_func(const void *a, const void *b)
-{
- return strcmp(*(const char **)a, *(const char **)b);
-}
-
bool is_riscv(struct lscpu_cputype *ct)
{
const char *base_isa[] = {"rv32", "rv64", "rv128"};
split = ul_strv_split(ct->isa, "_");
- /* Sort multi-letter extensions alphabetically */
- if (ul_strv_length(split) > 1)
- qsort(&split[1], ul_strv_length(split) - 1, sizeof(char *), riscv_cmp_func);
-
- /* Keep Base ISA and single-letter extensions at the start */
+ /* Keep the kernel-provided ISA extension order. */
strcpy(ct->isa, split[0]);
for (i = 1; i < ul_strv_length(split); i++) {
Thread(s) per core: 1
Core(s) per socket: 4
Socket(s): 1
-ISA: rv64imafdc zba zbb zicntr zicsr zifencei zihpm
+ISA: rv64imafdc zicntr zicsr zifencei zihpm zba zbb
MMU: sv39
L1d cache: 128 KiB (4 instances)
L1i cache: 128 KiB (4 instances)