|  | /* | 
|  | * 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 */ |