Add emulation for /proc/cpuinfo for the alpha architecture. alpha output example: (alpha-chroot)root@p100:/# cat /proc/cpuinfo cpu : Alpha cpu model : ev67 cpu variation : 0 cpu revision : 0 cpu serial number : JA00000000 system type : QEMU system variation : QEMU_v8.0.92 system revision : 0 system serial number : AY00000000 cycle frequency [Hz] : 250000000 timer frequency [Hz] : 250.00 page size [bytes] : 8192 phys. address bits : 44 max. addr. space # : 255 BogoMIPS : 2500.00 platform string : AlphaServer QEMU user-mode VM cpus detected : 8 cpus active : 4 cpu active mask : 0000000000000095 L1 Icache : n/a L1 Dcache : n/a L2 cache : n/a L3 cache : n/a Signed-off-by: Helge Deller <deller@gmx.de> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20230803214450.647040-4-deller@gmx.de> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Alpha specific proc functions for linux-user
 | 
						|
 *
 | 
						|
 * SPDX-License-Identifier: GPL-2.0-or-later
 | 
						|
 */
 | 
						|
#ifndef ALPHA_TARGET_PROC_H
 | 
						|
#define ALPHA_TARGET_PROC_H
 | 
						|
 | 
						|
static int open_cpuinfo(CPUArchState *cpu_env, int fd)
 | 
						|
{
 | 
						|
    int max_cpus = sysconf(_SC_NPROCESSORS_CONF);
 | 
						|
    int num_cpus = sysconf(_SC_NPROCESSORS_ONLN);
 | 
						|
    unsigned long cpu_mask;
 | 
						|
    char model[32];
 | 
						|
    const char *p, *q;
 | 
						|
    int t;
 | 
						|
 | 
						|
    p = object_class_get_name(OBJECT_CLASS(CPU_GET_CLASS(env_cpu(cpu_env))));
 | 
						|
    q = strchr(p, '-');
 | 
						|
    t = q - p;
 | 
						|
    assert(t < sizeof(model));
 | 
						|
    memcpy(model, p, t);
 | 
						|
    model[t] = 0;
 | 
						|
 | 
						|
    t = sched_getaffinity(getpid(), sizeof(cpu_mask), (cpu_set_t *)&cpu_mask);
 | 
						|
    if (t < 0) {
 | 
						|
        if (num_cpus >= sizeof(cpu_mask) * 8) {
 | 
						|
            cpu_mask = -1;
 | 
						|
        } else {
 | 
						|
            cpu_mask = (1UL << num_cpus) - 1;
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    dprintf(fd,
 | 
						|
            "cpu\t\t\t: Alpha\n"
 | 
						|
            "cpu model\t\t: %s\n"
 | 
						|
            "cpu variation\t\t: 0\n"
 | 
						|
            "cpu revision\t\t: 0\n"
 | 
						|
            "cpu serial number\t: JA00000000\n"
 | 
						|
            "system type\t\t: QEMU\n"
 | 
						|
            "system variation\t: QEMU_v" QEMU_VERSION "\n"
 | 
						|
            "system revision\t\t: 0\n"
 | 
						|
            "system serial number\t: AY00000000\n"
 | 
						|
            "cycle frequency [Hz]\t: 250000000\n"
 | 
						|
            "timer frequency [Hz]\t: 250.00\n"
 | 
						|
            "page size [bytes]\t: %d\n"
 | 
						|
            "phys. address bits\t: %d\n"
 | 
						|
            "max. addr. space #\t: 255\n"
 | 
						|
            "BogoMIPS\t\t: 2500.00\n"
 | 
						|
            "kernel unaligned acc\t: 0 (pc=0,va=0)\n"
 | 
						|
            "user unaligned acc\t: 0 (pc=0,va=0)\n"
 | 
						|
            "platform string\t\t: AlphaServer QEMU user-mode VM\n"
 | 
						|
            "cpus detected\t\t: %d\n"
 | 
						|
            "cpus active\t\t: %d\n"
 | 
						|
            "cpu active mask\t\t: %016lx\n"
 | 
						|
            "L1 Icache\t\t: n/a\n"
 | 
						|
            "L1 Dcache\t\t: n/a\n"
 | 
						|
            "L2 cache\t\t: n/a\n"
 | 
						|
            "L3 cache\t\t: n/a\n",
 | 
						|
            model, TARGET_PAGE_SIZE, TARGET_PHYS_ADDR_SPACE_BITS,
 | 
						|
            max_cpus, num_cpus, cpu_mask);
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
#define HAVE_ARCH_PROC_CPUINFO
 | 
						|
 | 
						|
#endif /* ALPHA_TARGET_PROC_H */
 |