Initial attempt at proper cpu detection on RISCV
This commit is contained in:
parent
8f13ab94d2
commit
46d22150de
|
@ -79,6 +79,29 @@ static char *cpuname[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
int detect(void){
|
int detect(void){
|
||||||
|
#ifdef __linux
|
||||||
|
FILE *infile;
|
||||||
|
char buffer[512], *p;
|
||||||
|
|
||||||
|
p = (char *)NULL;
|
||||||
|
infile = fopen("/proc/cpuinfo", "r");
|
||||||
|
while (fgets(buffer, sizeof(buffer), infile)){
|
||||||
|
if (!strncmp("isa", buffer, 3)){
|
||||||
|
p = strchr(buffer, '4') + 1; /* the 4 in rv64ima... */
|
||||||
|
#if 0
|
||||||
|
fprintf(stderr, "%s\n", p);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose(infile);
|
||||||
|
|
||||||
|
if (strchr(p, 'v')) return CPU_C910V;
|
||||||
|
|
||||||
|
return CPU_GENERIC;
|
||||||
|
#endif
|
||||||
|
|
||||||
return CPU_GENERIC;
|
return CPU_GENERIC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -91,6 +114,7 @@ void get_architecture(void){
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_subarchitecture(void){
|
void get_subarchitecture(void){
|
||||||
|
printf("%s",cpuname[detect()]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void get_subdirname(void){
|
void get_subdirname(void){
|
||||||
|
|
Loading…
Reference in New Issue