2018-09-26 13:55:14 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2018, Bin Meng <bmeng.cn@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
|
|
|
#include <asm/csr.h>
|
|
|
|
|
2018-11-22 10:26:29 +00:00
|
|
|
/*
|
|
|
|
* prior_stage_fdt_address must be stored in the data section since it is used
|
|
|
|
* before the bss section is available.
|
|
|
|
*/
|
|
|
|
phys_addr_t prior_stage_fdt_address __attribute__((section(".data")));
|
|
|
|
|
2018-09-26 13:55:14 +00:00
|
|
|
enum {
|
|
|
|
ISA_INVALID = 0,
|
|
|
|
ISA_32BIT,
|
|
|
|
ISA_64BIT,
|
|
|
|
ISA_128BIT
|
|
|
|
};
|
|
|
|
|
|
|
|
static const char * const isa_bits[] = {
|
|
|
|
[ISA_INVALID] = NULL,
|
|
|
|
[ISA_32BIT] = "32",
|
|
|
|
[ISA_64BIT] = "64",
|
|
|
|
[ISA_128BIT] = "128"
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline bool supports_extension(char ext)
|
|
|
|
{
|
|
|
|
return csr_read(misa) & (1 << (ext - 'a'));
|
|
|
|
}
|
|
|
|
|
|
|
|
int print_cpuinfo(void)
|
|
|
|
{
|
|
|
|
char name[32];
|
|
|
|
char *s = name;
|
|
|
|
int bit;
|
|
|
|
|
|
|
|
s += sprintf(name, "rv");
|
|
|
|
bit = csr_read(misa) >> (sizeof(long) * 8 - 2);
|
|
|
|
s += sprintf(s, isa_bits[bit]);
|
|
|
|
|
|
|
|
supports_extension('i') ? *s++ = 'i' : 'r';
|
|
|
|
supports_extension('m') ? *s++ = 'm' : 'i';
|
|
|
|
supports_extension('a') ? *s++ = 'a' : 's';
|
|
|
|
supports_extension('f') ? *s++ = 'f' : 'c';
|
|
|
|
supports_extension('d') ? *s++ = 'd' : '-';
|
|
|
|
supports_extension('c') ? *s++ = 'c' : 'v';
|
|
|
|
*s++ = '\0';
|
|
|
|
|
|
|
|
printf("CPU: %s\n", name);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|