summaryrefslogtreecommitdiff
path: root/kern
diff options
context:
space:
mode:
authorAbel Romero Pérez <romeroperezabel@gmail.com>2018-06-28 02:09:24 -0400
committerAbel Romero Pérez <romeroperezabel@gmail.com>2018-06-28 02:09:24 -0400
commit371df36e565f4408737948ccc3d25acf2e1ccb57 (patch)
tree81383a8771d3aea315f8ce7d7320de632ad94318 /kern
parent0d490ef21c156907f3f26a6cdc00842f462a877a (diff)
moved cpu_number() to cpu_number.c, created CPU_NUMBER ASM macro
Diffstat (limited to 'kern')
-rw-r--r--kern/cpu_number.c28
-rw-r--r--kern/cpu_number.h6
2 files changed, 33 insertions, 1 deletions
diff --git a/kern/cpu_number.c b/kern/cpu_number.c
new file mode 100644
index 00000000..0b2e2f1c
--- /dev/null
+++ b/kern/cpu_number.c
@@ -0,0 +1,28 @@
+int apic2kernel[255];
+int cpu_number_start = 0, cpu_number_counter = 0;
+
+int cpu_number(void) {
+ int eax = 1, ebx = 0, ecx = 0, edx = 0;
+ unsigned int i = 0;
+ int apic_id = 0;
+
+ if (!cpu_number_start) {
+ for (i = 0; i < 255; i++) {
+ apic2kernel[i] = -1;
+ }
+ cpu_number_start = 1;
+ }
+
+ asm("cpuid" : "=a" (eax), "=b" (ebx), "=c" (ecx), "=d" (edx) : "a" (eax));
+ apic_id = (char) (ebx >> 24) & 0xff;
+ //printf("apic_id = %d\n", apic_id);
+
+ if (apic2kernel[apic_id] != -1) {
+ return apic2kernel[apic_id];
+ } else {
+ apic2kernel[apic_id] = cpu_number_counter;
+ cpu_number_counter++;
+ }
+
+ return apic2kernel[apic_id];
+}
diff --git a/kern/cpu_number.h b/kern/cpu_number.h
index 5d3e4bd1..2ea510e4 100644
--- a/kern/cpu_number.h
+++ b/kern/cpu_number.h
@@ -37,7 +37,11 @@ int master_cpu; /* 'master' processor - keeps time */
/* cpu number is always 0 on a single processor system */
#define cpu_number() (0)
-#endif /* NCPUS == 1 */
+#else /* NCPUS == 1 */
+
+extern int cpu_number(void);
+
+#endif /* NCPUS != 1 */
#define CPU_L1_SIZE (1 << CPU_L1_SHIFT)