Some minor updates:

arch_cpu: could have used the TLS_SIZE macro in one place, removed
a now unused variable, assignments to tss_loaded are now booleans.
thread.c: added the new fields to _dump_thread_info().


git-svn-id: file:///srv/svn/repos/haiku/trunk/current@2393 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2003-01-08 09:27:55 +00:00
parent dd8e42a8b4
commit 4fff689f48
2 changed files with 20 additions and 19 deletions

View File

@ -11,8 +11,8 @@
#include <smp.h> #include <smp.h>
#include <arch/x86/selector.h> #include <arch/x86/selector.h>
#include <Errors.h> #include <Errors.h>
#include <TLS.h>
#include <kerrors.h> #include <kerrors.h>
#include <tls.h>
#include <stage2.h> #include <stage2.h>
@ -62,18 +62,17 @@ arch_cpu_init2(kernel_args *ka)
tss = malloc(sizeof(struct tss *) * ka->num_cpus); tss = malloc(sizeof(struct tss *) * ka->num_cpus);
if (tss == NULL) { if (tss == NULL) {
panic("arch_cpu_init2: could not allocate buffer for tss pointers\n"); panic("arch_cpu_init2: could not allocate buffer for tss pointers\n");
return ENOMEM; return B_NO_MEMORY;
} }
tss_loaded = malloc(sizeof(int) * ka->num_cpus); tss_loaded = malloc(sizeof(int) * ka->num_cpus);
if (tss == NULL) { if (tss == NULL) {
panic("arch_cpu_init2: could not allocate buffer for tss booleans\n"); panic("arch_cpu_init2: could not allocate buffer for tss booleans\n");
return ENOMEM; return B_NO_MEMORY;
} }
memset(tss_loaded, 0, sizeof(int) * ka->num_cpus); memset(tss_loaded, 0, sizeof(int) * ka->num_cpus);
for (i = 0; i < ka->num_cpus; i++) { for (i = 0; i < ka->num_cpus; i++) {
struct segment_descriptor *tss_d;
char tss_name[16]; char tss_name[16];
region_id rid; region_id rid;
@ -82,7 +81,7 @@ arch_cpu_init2(kernel_args *ka)
REGION_ADDR_ANY_ADDRESS, PAGE_SIZE, REGION_WIRING_WIRED, LOCK_RW|LOCK_KERNEL); REGION_ADDR_ANY_ADDRESS, PAGE_SIZE, REGION_WIRING_WIRED, LOCK_RW|LOCK_KERNEL);
if (rid < 0) { if (rid < 0) {
panic("arch_cpu_init2: unable to create region for tss\n"); panic("arch_cpu_init2: unable to create region for tss\n");
return ENOMEM; return B_NO_MEMORY;
} }
// initialize TSS // initialize TSS
@ -96,7 +95,7 @@ arch_cpu_init2(kernel_args *ka)
// setup TLS descriptors (one for every CPU) // setup TLS descriptors (one for every CPU)
for (i = 0; i < ka->num_cpus; i++) { for (i = 0; i < ka->num_cpus; i++) {
set_segment_descriptor(&gGDT[TLS_BASE_SEGMENT + i], 0, TLS_MAX_KEYS * sizeof(void *), set_segment_descriptor(&gGDT[TLS_BASE_SEGMENT + i], 0, TLS_SIZE,
DT_DATA_WRITEABLE, DPL_USER); DT_DATA_WRITEABLE, DPL_USER);
} }
@ -110,11 +109,11 @@ i386_set_tss_and_kstack(addr kstack)
int currentCPU = smp_get_current_cpu(); int currentCPU = smp_get_current_cpu();
// dprintf("i386_set_kstack: kstack 0x%x, cpu %d\n", kstack, currentCPU); // dprintf("i386_set_kstack: kstack 0x%x, cpu %d\n", kstack, currentCPU);
if (tss_loaded[currentCPU] == 0) { if (!tss_loaded[currentCPU]) {
short seg = ((TSS_BASE_SEGMENT + currentCPU) << 3) | DPL_KERNEL; short seg = ((TSS_BASE_SEGMENT + currentCPU) << 3) | DPL_KERNEL;
asm("movw %0, %%ax;" asm("movw %0, %%ax;"
"ltr %%ax;" : : "r" (seg) : "eax"); "ltr %%ax;" : : "r" (seg) : "eax");
tss_loaded[currentCPU] = 1; tss_loaded[currentCPU] = true;
} }
tss[currentCPU]->sp0 = kstack; tss[currentCPU]->sp0 = kstack;

View File

@ -519,21 +519,23 @@ _dump_thread_info(struct thread *t)
else else
dprintf("\n"); dprintf("\n");
dprintf("sig_pending: 0x%lx\n", t->sig_pending); dprintf("sig_pending: 0x%lx\n", t->sig_pending);
dprintf("in_kernel: %d\n", t->in_kernel); dprintf("in_kernel: %d\n", t->in_kernel);
dprintf("sem_blocking:0x%lx\n", t->sem_blocking); dprintf("sem_blocking: 0x%lx\n", t->sem_blocking);
dprintf("sem_count: 0x%x\n", t->sem_count); dprintf("sem_count: 0x%x\n", t->sem_count);
dprintf("sem_deleted_retcode: 0x%x\n", t->sem_deleted_retcode); dprintf("sem_deleted_retcode: 0x%x\n", t->sem_deleted_retcode);
dprintf("sem_errcode: 0x%x\n", t->sem_errcode); dprintf("sem_errcode: 0x%x\n", t->sem_errcode);
dprintf("sem_flags: 0x%x\n", t->sem_flags); dprintf("sem_flags: 0x%x\n", t->sem_flags);
dprintf("fault_handler: 0x%lx\n", t->fault_handler); dprintf("fault_handler: %p\n", (void *)t->fault_handler);
dprintf("args: %p\n", t->args); dprintf("args: %p\n", t->args);
dprintf("entry: 0x%lx\n", t->entry); dprintf("entry: %p\n", (void *)t->entry);
dprintf("team: %p\n", t->team); dprintf("team: %p\n", t->team);
dprintf("return_code_sem: 0x%lx\n", t->return_code_sem); dprintf("return_code_sem: 0x%lx\n", t->return_code_sem);
dprintf("kernel_stack_region_id: 0x%lx\n", t->kernel_stack_region_id); dprintf("kernel_stack_region_id: 0x%lx\n", t->kernel_stack_region_id);
dprintf("kernel_stack_base: 0x%lx\n", t->kernel_stack_base); dprintf("kernel_stack_base: %p\n", (void *)t->kernel_stack_base);
dprintf("user_stack_region_id: 0x%lx\n", t->user_stack_region_id); dprintf("user_stack_region_id: 0x%lx\n", t->user_stack_region_id);
dprintf("user_stack_base: 0x%lx\n", t->user_stack_base); dprintf("user_stack_base: %p\n", (void *)t->user_stack_base);
dprintf("user_local_storage: %p\n", (void *)t->user_local_storage);
dprintf("kernel_errno: %d\n", t->kernel_errno);
dprintf("kernel_time: %Ld\n", t->kernel_time); dprintf("kernel_time: %Ld\n", t->kernel_time);
dprintf("user_time: %Ld\n", t->user_time); dprintf("user_time: %Ld\n", t->user_time);
dprintf("architecture dependant section:\n"); dprintf("architecture dependant section:\n");