1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

core: prefix API functions correctly

Also changed names for bitarithm functions and rename thread_pid to sched_active_pid.
This commit is contained in:
Oleg Hahm 2014-04-10 22:28:35 +02:00
parent 94e4ee1611
commit ef5ec344fd
39 changed files with 209 additions and 212 deletions

View File

@ -173,7 +173,7 @@ uint8_t SMB380_init_simple(uint16_t samplerate, uint8_t bandwidth, uint8_t
{ {
SSP0Init(); SSP0Init();
interruptTicksSMB380 = 0; interruptTicksSMB380 = 0;
simple_pid = active_thread->pid; simple_pid = sched_active_thread->pid;
gpioint_set(0, BIT1, GPIOINT_RISING_EDGE, &SMB380_simple_interrupthandler); gpioint_set(0, BIT1, GPIOINT_RISING_EDGE, &SMB380_simple_interrupthandler);
SMB380_softReset(); SMB380_softReset();
hwtimer_wait(HWTIMER_TICKS(100000)); hwtimer_wait(HWTIMER_TICKS(100000));
@ -305,7 +305,7 @@ uint8_t getRingReadPointerforCurrentThread(void)
{ {
uint8_t pointerNo = 0; uint8_t pointerNo = 0;
while ((PointerList[pointerNo] != active_thread->pid) && while ((PointerList[pointerNo] != sched_active_thread->pid) &&
(pointerNo < SMB380_RING_BUFF_MAX_THREADS)) { (pointerNo < SMB380_RING_BUFF_MAX_THREADS)) {
pointerNo++; pointerNo++;
} }
@ -327,7 +327,7 @@ uint8_t initRingReadPointerforCurrentThread(void)
return 0; return 0;
} }
else { else {
PointerList[pointerNo] = active_thread->pid; PointerList[pointerNo] = sched_active_thread->pid;
readPointerPos[pointerNo] = settings.writePointerPos; readPointerPos[pointerNo] = settings.writePointerPos;
return 1; return 1;
} }

View File

@ -21,8 +21,7 @@
#include <stdio.h> #include <stdio.h>
unsigned unsigned bitarithm_msb(unsigned v)
number_of_highest_bit(unsigned v)
{ {
register unsigned r; // result of log2(v) will go here register unsigned r; // result of log2(v) will go here
@ -45,8 +44,7 @@ number_of_highest_bit(unsigned v)
return r; return r;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
unsigned unsigned bitarithm_lsb(register unsigned v)
number_of_lowest_bit(register unsigned v)
{ {
register unsigned r = 0; register unsigned r = 0;
@ -58,8 +56,7 @@ number_of_lowest_bit(register unsigned v)
return r; return r;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
unsigned unsigned bitarithm_bits_set(unsigned v)
number_of_bits_set(unsigned v)
{ {
unsigned c; // c accumulates the total bits set in v unsigned c; // c accumulates the total bits set in v

View File

@ -94,7 +94,7 @@
* *
* Source: http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious * Source: http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious
*/ */
unsigned number_of_highest_bit(unsigned v); unsigned bitarithm_msb(unsigned v);
/** /**
* @brief Returns the number of the lowest '1' bit in a value * @brief Returns the number of the lowest '1' bit in a value
@ -104,7 +104,7 @@ unsigned number_of_highest_bit(unsigned v);
* *
* Source: http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious * Source: http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious
*/ */
unsigned number_of_lowest_bit(register unsigned v); unsigned bitarithm_lsb(register unsigned v);
/** /**
* @brief Returns the number of bits set in a value * @brief Returns the number of bits set in a value
@ -113,7 +113,7 @@ unsigned number_of_lowest_bit(register unsigned v);
* *
* Source: http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious * Source: http://graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious
*/ */
unsigned number_of_bits_set(unsigned v); unsigned bitarithm_bits_set(unsigned v);
#endif /* BITARITHM_H_ */ #endif /* BITARITHM_H_ */
/** @} */ /** @} */

View File

@ -39,7 +39,7 @@
#include "cpu-conf.h" #include "cpu-conf.h"
#define DEBUG_PRINT(...) \ #define DEBUG_PRINT(...) \
do { \ do { \
if ((active_thread == NULL) || (active_thread->stack_size > KERNEL_CONF_STACKSIZE_PRINTF)) { \ if ((sched_active_thread == NULL) || (sched_active_thread->stack_size > KERNEL_CONF_STACKSIZE_PRINTF)) { \
printf(__VA_ARGS__); \ printf(__VA_ARGS__); \
} \ } \
else { \ else { \
@ -70,7 +70,7 @@
#define DEBUGF(...) \ #define DEBUGF(...) \
do { \ do { \
DEBUG_PRINT("DEBUG(%s): %s:%d in %s: ", \ DEBUG_PRINT("DEBUG(%s): %s:%d in %s: ", \
active_thread ? active_thread->name : "NO THREAD", \ sched_active_thread ? sched_active_thread->name : "NO THREAD", \
__FILE__, __LINE__, __func__); \ __FILE__, __LINE__, __func__); \
DEBUG_PRINT(__VA_ARGS__); \ DEBUG_PRINT(__VA_ARGS__); \
} while (0) } while (0)

View File

@ -82,17 +82,17 @@ extern volatile tcb_t *sched_threads[MAXTHREADS];
/** /**
* Currently active thread * Currently active thread
*/ */
extern volatile tcb_t *active_thread; extern volatile tcb_t *sched_active_thread;
/** /**
* Number of running (non-terminated) threads * Number of running (non-terminated) threads
*/ */
extern volatile int num_tasks; extern volatile int sched_num_threads;
/** /**
* Process ID of active thread * Process ID of active thread
*/ */
extern volatile int thread_pid; extern volatile int sched_active_pid;
/** /**
* Process ID of the thread that was active before the current one * Process ID of the thread that was active before the current one

View File

@ -142,7 +142,7 @@ int thread_getlastpid(void);
* *
* Only works if the thread was created with the flag CREATE_STACKTEST. * Only works if the thread was created with the flag CREATE_STACKTEST.
* *
* @param[in] stack the stack you want to measure. try `active_thread->stack_start` * @param[in] stack the stack you want to measure. try `sched_active_thread->stack_start`
* *
* @return the amount of unused space of the thread's stack * @return the amount of unused space of the thread's stack
*/ */

View File

@ -60,7 +60,7 @@ int msg_send(msg_t *m, unsigned int target_pid, bool block)
tcb_t *target = (tcb_t*) sched_threads[target_pid]; tcb_t *target = (tcb_t*) sched_threads[target_pid];
m->sender_pid = thread_pid; m->sender_pid = sched_active_pid;
if (m->sender_pid == target_pid) { if (m->sender_pid == target_pid) {
return msg_send_to_self(m); return msg_send_to_self(m);
@ -72,51 +72,51 @@ int msg_send(msg_t *m, unsigned int target_pid, bool block)
dINT(); dINT();
DEBUG("msg_send() %s:%i: Sending from %i to %i. block=%i src->state=%i target->state=%i\n", __FILE__, __LINE__, thread_pid, target_pid, block, active_thread->status, target->status); DEBUG("msg_send() %s:%i: Sending from %i to %i. block=%i src->state=%i target->state=%i\n", __FILE__, __LINE__, sched_active_pid, target_pid, block, sched_active_thread->status, target->status);
if (target->status != STATUS_RECEIVE_BLOCKED) { if (target->status != STATUS_RECEIVE_BLOCKED) {
DEBUG("msg_send() %s:%i: Target %i is not RECEIVE_BLOCKED.\n", __FILE__, __LINE__, target_pid); DEBUG("msg_send() %s:%i: Target %i is not RECEIVE_BLOCKED.\n", __FILE__, __LINE__, target_pid);
if (target->msg_array && queue_msg(target, m)) { if (target->msg_array && queue_msg(target, m)) {
DEBUG("msg_send() %s:%i: Target %i has a msg_queue. Queueing message.\n", __FILE__, __LINE__, target_pid); DEBUG("msg_send() %s:%i: Target %i has a msg_queue. Queueing message.\n", __FILE__, __LINE__, target_pid);
eINT(); eINT();
if (active_thread->status == STATUS_REPLY_BLOCKED) { if (sched_active_thread->status == STATUS_REPLY_BLOCKED) {
thread_yield(); thread_yield();
} }
return 1; return 1;
} }
if (!block) { if (!block) {
DEBUG("msg_send: %s: Receiver not waiting, block=%u\n", active_thread->name, block); DEBUG("msg_send: %s: Receiver not waiting, block=%u\n", sched_active_thread->name, block);
eINT(); eINT();
return 0; return 0;
} }
DEBUG("msg_send: %s: send_blocked.\n", active_thread->name); DEBUG("msg_send: %s: send_blocked.\n", sched_active_thread->name);
queue_node_t n; queue_node_t n;
n.priority = active_thread->priority; n.priority = sched_active_thread->priority;
n.data = (unsigned int) active_thread; n.data = (unsigned int) sched_active_thread;
n.next = NULL; n.next = NULL;
DEBUG("msg_send: %s: Adding node to msg_waiters:\n", active_thread->name); DEBUG("msg_send: %s: Adding node to msg_waiters:\n", sched_active_thread->name);
queue_priority_add(&(target->msg_waiters), &n); queue_priority_add(&(target->msg_waiters), &n);
active_thread->wait_data = (void*) m; sched_active_thread->wait_data = (void*) m;
int newstatus; int newstatus;
if (active_thread->status == STATUS_REPLY_BLOCKED) { if (sched_active_thread->status == STATUS_REPLY_BLOCKED) {
newstatus = STATUS_REPLY_BLOCKED; newstatus = STATUS_REPLY_BLOCKED;
} }
else { else {
newstatus = STATUS_SEND_BLOCKED; newstatus = STATUS_SEND_BLOCKED;
} }
sched_set_status((tcb_t*) active_thread, newstatus); sched_set_status((tcb_t*) sched_active_thread, newstatus);
DEBUG("msg_send: %s: Back from send block.\n", active_thread->name); DEBUG("msg_send: %s: Back from send block.\n", sched_active_thread->name);
} }
else { else {
DEBUG("msg_send: %s: Direct msg copy from %i to %i.\n", active_thread->name, thread_getpid(), target_pid); DEBUG("msg_send: %s: Direct msg copy from %i to %i.\n", sched_active_thread->name, thread_getpid(), target_pid);
/* copy msg to target */ /* copy msg to target */
msg_t *target_message = (msg_t*) target->wait_data; msg_t *target_message = (msg_t*) target->wait_data;
*target_message = *m; *target_message = *m;
@ -133,7 +133,7 @@ int msg_send_to_self(msg_t *m)
{ {
unsigned int state = disableIRQ(); unsigned int state = disableIRQ();
int res = queue_msg((tcb_t *) active_thread, m); int res = queue_msg((tcb_t *) sched_active_thread, m);
restoreIRQ(state); restoreIRQ(state);
return res; return res;
@ -165,7 +165,7 @@ int msg_send_int(msg_t *m, unsigned int target_pid)
int msg_send_receive(msg_t *m, msg_t *reply, unsigned int target_pid) int msg_send_receive(msg_t *m, msg_t *reply, unsigned int target_pid)
{ {
dINT(); dINT();
tcb_t *me = (tcb_t*) sched_threads[thread_pid]; tcb_t *me = (tcb_t*) sched_threads[sched_active_pid];
sched_set_status(me, STATUS_REPLY_BLOCKED); sched_set_status(me, STATUS_REPLY_BLOCKED);
me->wait_data = (void*) reply; me->wait_data = (void*) reply;
@ -181,17 +181,17 @@ int msg_reply(msg_t *m, msg_t *reply)
tcb_t *target = (tcb_t*) sched_threads[m->sender_pid]; tcb_t *target = (tcb_t*) sched_threads[m->sender_pid];
if (!target) { if (!target) {
DEBUG("msg_reply(): %s: Target \"%" PRIu16 "\" not existing...dropping msg!\n", active_thread->name, m->sender_pid); DEBUG("msg_reply(): %s: Target \"%" PRIu16 "\" not existing...dropping msg!\n", sched_active_thread->name, m->sender_pid);
return -1; return -1;
} }
if (target->status != STATUS_REPLY_BLOCKED) { if (target->status != STATUS_REPLY_BLOCKED) {
DEBUG("msg_reply(): %s: Target \"%s\" not waiting for reply.", active_thread->name, target->name); DEBUG("msg_reply(): %s: Target \"%s\" not waiting for reply.", sched_active_thread->name, target->name);
restoreIRQ(state); restoreIRQ(state);
return -1; return -1;
} }
DEBUG("msg_reply(): %s: Direct msg copy.\n", active_thread->name); DEBUG("msg_reply(): %s: Direct msg copy.\n", sched_active_thread->name);
/* copy msg to target */ /* copy msg to target */
msg_t *target_message = (msg_t*) target->wait_data; msg_t *target_message = (msg_t*) target->wait_data;
*target_message = *reply; *target_message = *reply;
@ -207,7 +207,7 @@ int msg_reply_int(msg_t *m, msg_t *reply)
tcb_t *target = (tcb_t*) sched_threads[m->sender_pid]; tcb_t *target = (tcb_t*) sched_threads[m->sender_pid];
if (target->status != STATUS_REPLY_BLOCKED) { if (target->status != STATUS_REPLY_BLOCKED) {
DEBUG("msg_reply_int(): %s: Target \"%s\" not waiting for reply.", active_thread->name, target->name); DEBUG("msg_reply_int(): %s: Target \"%s\" not waiting for reply.", sched_active_thread->name, target->name);
return -1; return -1;
} }
@ -231,9 +231,9 @@ int msg_receive(msg_t *m)
static int _msg_receive(msg_t *m, int block) static int _msg_receive(msg_t *m, int block)
{ {
dINT(); dINT();
DEBUG("_msg_receive: %s: _msg_receive.\n", active_thread->name); DEBUG("_msg_receive: %s: _msg_receive.\n", sched_active_thread->name);
tcb_t *me = (tcb_t*) sched_threads[thread_pid]; tcb_t *me = (tcb_t*) sched_threads[sched_active_pid];
int queue_index = -1; int queue_index = -1;
@ -247,7 +247,7 @@ static int _msg_receive(msg_t *m, int block)
} }
if (queue_index >= 0) { if (queue_index >= 0) {
DEBUG("_msg_receive: %s: _msg_receive(): We've got a queued message.\n", active_thread->name); DEBUG("_msg_receive: %s: _msg_receive(): We've got a queued message.\n", sched_active_thread->name);
*m = me->msg_array[queue_index]; *m = me->msg_array[queue_index];
} }
else { else {
@ -257,10 +257,10 @@ static int _msg_receive(msg_t *m, int block)
queue_node_t *node = queue_remove_head(&(me->msg_waiters)); queue_node_t *node = queue_remove_head(&(me->msg_waiters));
if (node == NULL) { if (node == NULL) {
DEBUG("_msg_receive: %s: _msg_receive(): No thread in waiting list.\n", active_thread->name); DEBUG("_msg_receive: %s: _msg_receive(): No thread in waiting list.\n", sched_active_thread->name);
if (queue_index < 0) { if (queue_index < 0) {
DEBUG("_msg_receive(): %s: No msg in queue. Going blocked.\n", active_thread->name); DEBUG("_msg_receive(): %s: No msg in queue. Going blocked.\n", sched_active_thread->name);
sched_set_status(me, STATUS_RECEIVE_BLOCKED); sched_set_status(me, STATUS_RECEIVE_BLOCKED);
eINT(); eINT();
@ -272,7 +272,7 @@ static int _msg_receive(msg_t *m, int block)
return 1; return 1;
} }
else { else {
DEBUG("_msg_receive: %s: _msg_receive(): Waking up waiting thread.\n", active_thread->name); DEBUG("_msg_receive: %s: _msg_receive(): Waking up waiting thread.\n", sched_active_thread->name);
tcb_t *sender = (tcb_t*) node->data; tcb_t *sender = (tcb_t*) node->data;
if (queue_index >= 0) { if (queue_index >= 0) {
@ -301,7 +301,7 @@ int msg_init_queue(msg_t *array, int num)
{ {
/* check if num is a power of two by comparing to its complement */ /* check if num is a power of two by comparing to its complement */
if (num && (num & (num - 1)) == 0) { if (num && (num & (num - 1)) == 0) {
tcb_t *me = (tcb_t*) active_thread; tcb_t *me = (tcb_t*) sched_active_thread;
me->msg_array = array; me->msg_array = array;
cib_init(&(me->msg_queue), num); cib_init(&(me->msg_queue), num);
return 0; return 0;

View File

@ -48,13 +48,13 @@ int mutex_init(struct mutex_t *mutex)
int mutex_trylock(struct mutex_t *mutex) int mutex_trylock(struct mutex_t *mutex)
{ {
DEBUG("%s: trylocking to get mutex. val: %u\n", active_thread->name, mutex->val); DEBUG("%s: trylocking to get mutex. val: %u\n", sched_active_thread->name, mutex->val);
return (atomic_set_return(&mutex->val, 1) == 0); return (atomic_set_return(&mutex->val, 1) == 0);
} }
int mutex_lock(struct mutex_t *mutex) int mutex_lock(struct mutex_t *mutex)
{ {
DEBUG("%s: trying to get mutex. val: %u\n", active_thread->name, mutex->val); DEBUG("%s: trying to get mutex. val: %u\n", sched_active_thread->name, mutex->val);
if (atomic_set_return(&mutex->val, 1) != 0) { if (atomic_set_return(&mutex->val, 1) != 0) {
/* mutex was locked. */ /* mutex was locked. */
@ -67,24 +67,24 @@ int mutex_lock(struct mutex_t *mutex)
static void mutex_wait(struct mutex_t *mutex) static void mutex_wait(struct mutex_t *mutex)
{ {
int irqstate = disableIRQ(); int irqstate = disableIRQ();
DEBUG("%s: Mutex in use. %u\n", active_thread->name, mutex->val); DEBUG("%s: Mutex in use. %u\n", sched_active_thread->name, mutex->val);
if (mutex->val == 0) { if (mutex->val == 0) {
/* somebody released the mutex. return. */ /* somebody released the mutex. return. */
mutex->val = 1; mutex->val = 1;
DEBUG("%s: mutex_wait early out. %u\n", active_thread->name, mutex->val); DEBUG("%s: mutex_wait early out. %u\n", sched_active_thread->name, mutex->val);
restoreIRQ(irqstate); restoreIRQ(irqstate);
return; return;
} }
sched_set_status((tcb_t *) active_thread, STATUS_MUTEX_BLOCKED); sched_set_status((tcb_t*) sched_active_thread, STATUS_MUTEX_BLOCKED);
queue_node_t n; queue_node_t n;
n.priority = (unsigned int) active_thread->priority; n.priority = (unsigned int) sched_active_thread->priority;
n.data = (unsigned int) active_thread; n.data = (unsigned int) sched_active_thread;
n.next = NULL; n.next = NULL;
DEBUG("%s: Adding node to mutex queue: prio: %" PRIu32 "\n", active_thread->name, n.priority); DEBUG("%s: Adding node to mutex queue: prio: %" PRIu32 "\n", sched_active_thread->name, n.priority);
queue_priority_add(&(mutex->queue), &n); queue_priority_add(&(mutex->queue), &n);
@ -97,7 +97,7 @@ static void mutex_wait(struct mutex_t *mutex)
void mutex_unlock(struct mutex_t *mutex) void mutex_unlock(struct mutex_t *mutex)
{ {
DEBUG("%s: unlocking mutex. val: %u pid: %u\n", active_thread->name, mutex->val, thread_pid); DEBUG("%s: unlocking mutex. val: %u pid: %u\n", sched_active_thread->name, mutex->val, sched_active_pid);
int irqstate = disableIRQ(); int irqstate = disableIRQ();
if (mutex->val != 0) { if (mutex->val != 0) {
@ -107,7 +107,7 @@ void mutex_unlock(struct mutex_t *mutex)
DEBUG("%s: waking up waiter.\n", process->name); DEBUG("%s: waking up waiter.\n", process->name);
sched_set_status(process, STATUS_PENDING); sched_set_status(process, STATUS_PENDING);
sched_switch(active_thread->priority, process->priority); sched_switch(sched_active_thread->priority, process->priority);
} }
else { else {
mutex->val = 0; mutex->val = 0;
@ -119,7 +119,7 @@ void mutex_unlock(struct mutex_t *mutex)
void mutex_unlock_and_sleep(struct mutex_t *mutex) void mutex_unlock_and_sleep(struct mutex_t *mutex)
{ {
DEBUG("%s: unlocking mutex. val: %u pid: %u, and taking a nap\n", active_thread->name, mutex->val, thread_pid); DEBUG("%s: unlocking mutex. val: %u pid: %u, and taking a nap\n", sched_active_thread->name, mutex->val, sched_active_pid);
int irqstate = disableIRQ(); int irqstate = disableIRQ();
if (mutex->val != 0) { if (mutex->val != 0) {
@ -133,9 +133,8 @@ void mutex_unlock_and_sleep(struct mutex_t *mutex)
mutex->val = 0; mutex->val = 0;
} }
} }
DEBUG("%s: going to sleep.\n", sched_active_thread->name);
DEBUG("%s: going to sleep.\n", active_thread->name); sched_set_status((tcb_t*) sched_active_thread, STATUS_SLEEPING);
sched_set_status((tcb_t *) active_thread, STATUS_SLEEPING);
restoreIRQ(irqstate); restoreIRQ(irqstate);
thread_yield(); thread_yield();
} }

View File

@ -39,29 +39,29 @@
#define ENABLE_DEBUG (0) #define ENABLE_DEBUG (0)
#include "debug.h" #include "debug.h"
volatile int num_tasks = 0; volatile int sched_num_threads = 0;
volatile unsigned int sched_context_switch_request; volatile unsigned int sched_context_switch_request;
volatile tcb_t *sched_threads[MAXTHREADS]; volatile tcb_t *sched_threads[MAXTHREADS];
volatile tcb_t *active_thread; volatile tcb_t *sched_active_thread;
volatile int thread_pid = -1; volatile int sched_active_pid = -1;
volatile int last_pid = -1; volatile int thread_last_pid = -1;
clist_node_t *runqueues[SCHED_PRIO_LEVELS]; clist_node_t *sched_runqueues[SCHED_PRIO_LEVELS];
static uint32_t runqueue_bitcache = 0; static uint32_t runqueue_bitcache = 0;
#if SCHEDSTATISTICS #if SCHEDSTATISTICS
static void (*sched_cb) (uint32_t timestamp, uint32_t value) = NULL; static void (*sched_cb) (uint32_t timestamp, uint32_t value) = NULL;
schedstat pidlist[MAXTHREADS]; schedstat sched_pidlist[MAXTHREADS];
#endif #endif
void sched_run(void) void sched_run(void)
{ {
sched_context_switch_request = 0; sched_context_switch_request = 0;
tcb_t *my_active_thread = (tcb_t *)active_thread; tcb_t *my_active_thread = (tcb_t *)sched_active_thread;
if (my_active_thread) { if (my_active_thread) {
if (my_active_thread->status == STATUS_RUNNING) { if (my_active_thread->status == STATUS_RUNNING) {
@ -81,18 +81,18 @@ void sched_run(void)
#ifdef SCHEDSTATISTICS #ifdef SCHEDSTATISTICS
unsigned long time = hwtimer_now(); unsigned long time = hwtimer_now();
if (my_active_thread && (pidlist[my_active_thread->pid].laststart)) { if (my_active_thread && (sched_pidlist[my_active_thread->pid].laststart)) {
pidlist[my_active_thread->pid].runtime_ticks += time - pidlist[my_active_thread->pid].laststart; sched_pidlist[my_active_thread->pid].runtime_ticks += time - sched_pidlist[my_active_thread->pid].laststart;
} }
#endif #endif
DEBUG("\nscheduler: previous task: %s\n", (my_active_thread == NULL) ? "none" : my_active_thread->name); DEBUG("\nscheduler: previous task: %s\n", (my_active_thread == NULL) ? "none" : my_active_thread->name);
if (num_tasks == 0) { if (sched_num_threads == 0) {
DEBUG("scheduler: no tasks left.\n"); DEBUG("scheduler: no tasks left.\n");
while (!num_tasks) { while (!sched_num_threads) {
/* loop until a new task arrives */ /* loop until a new task arrives */
; ;
} }
@ -103,24 +103,24 @@ void sched_run(void)
my_active_thread = NULL; my_active_thread = NULL;
while (!my_active_thread) { while (!my_active_thread) {
int nextrq = number_of_lowest_bit(runqueue_bitcache); int nextrq = bitarithm_lsb(runqueue_bitcache);
clist_node_t next = *(runqueues[nextrq]); clist_node_t next = *(sched_runqueues[nextrq]);
DEBUG("scheduler: first in queue: %s\n", ((tcb_t *)next.data)->name); DEBUG("scheduler: first in queue: %s\n", ((tcb_t *)next.data)->name);
clist_advance(&(runqueues[nextrq])); clist_advance(&(sched_runqueues[nextrq]));
my_active_thread = (tcb_t *)next.data; my_active_thread = (tcb_t *)next.data;
thread_pid = (volatile int) my_active_thread->pid; sched_active_pid = (volatile int) my_active_thread->pid;
#if SCHEDSTATISTICS #if SCHEDSTATISTICS
pidlist[my_active_thread->pid].laststart = time; sched_pidlist[my_active_thread->pid].laststart = time;
pidlist[my_active_thread->pid].schedules++; sched_pidlist[my_active_thread->pid].schedules++;
if ((sched_cb) && (my_active_thread->pid != last_pid)) { if ((sched_cb) && (my_active_thread->pid != thread_last_pid)) {
sched_cb(hwtimer_now(), my_active_thread->pid); sched_cb(hwtimer_now(), my_active_thread->pid);
last_pid = my_active_thread->pid; thread_last_pid = my_active_thread->pid;
} }
#endif #endif
#ifdef MODULE_NSS #ifdef MODULE_NSS
if (active_thread && active_thread->pid != last_pid) { if (sched_active_thread && sched_active_thread->pid != thread_last_pid) {
last_pid = active_thread->pid; thread_last_pid = sched_active_thread->pid;
} }
#endif #endif
@ -128,17 +128,17 @@ void sched_run(void)
DEBUG("scheduler: next task: %s\n", my_active_thread->name); DEBUG("scheduler: next task: %s\n", my_active_thread->name);
if (my_active_thread != active_thread) { if (my_active_thread != sched_active_thread) {
if (active_thread != NULL) { /* TODO: necessary? */ if (sched_active_thread != NULL) { /* TODO: necessary? */
if (active_thread->status == STATUS_RUNNING) { if (sched_active_thread->status == STATUS_RUNNING) {
active_thread->status = STATUS_PENDING ; sched_active_thread->status = STATUS_PENDING ;
} }
} }
sched_set_status((tcb_t *)my_active_thread, STATUS_RUNNING); sched_set_status((tcb_t *)my_active_thread, STATUS_RUNNING);
} }
active_thread = (volatile tcb_t *) my_active_thread; sched_active_thread = (volatile tcb_t *) my_active_thread;
DEBUG("scheduler: done.\n"); DEBUG("scheduler: done.\n");
} }
@ -155,16 +155,16 @@ void sched_set_status(tcb_t *process, unsigned int status)
if (status >= STATUS_ON_RUNQUEUE) { if (status >= STATUS_ON_RUNQUEUE) {
if (!(process->status >= STATUS_ON_RUNQUEUE)) { if (!(process->status >= STATUS_ON_RUNQUEUE)) {
DEBUG("adding process %s to runqueue %u.\n", process->name, process->priority); DEBUG("adding process %s to runqueue %u.\n", process->name, process->priority);
clist_add(&runqueues[process->priority], &(process->rq_entry)); clist_add(&sched_runqueues[process->priority], &(process->rq_entry));
runqueue_bitcache |= 1 << process->priority; runqueue_bitcache |= 1 << process->priority;
} }
} }
else { else {
if (process->status >= STATUS_ON_RUNQUEUE) { if (process->status >= STATUS_ON_RUNQUEUE) {
DEBUG("removing process %s from runqueue %u.\n", process->name, process->priority); DEBUG("removing process %s from runqueue %u.\n", process->name, process->priority);
clist_remove(&runqueues[process->priority], &(process->rq_entry)); clist_remove(&sched_runqueues[process->priority], &(process->rq_entry));
if (!runqueues[process->priority]) { if (!sched_runqueues[process->priority]) {
runqueue_bitcache &= ~(1 << process->priority); runqueue_bitcache &= ~(1 << process->priority);
} }
} }
@ -177,7 +177,7 @@ void sched_switch(uint16_t current_prio, uint16_t other_prio)
{ {
int in_isr = inISR(); int in_isr = inISR();
DEBUG("%s: %i %i %i\n", active_thread->name, (int)current_prio, (int)other_prio, in_isr); DEBUG("%s: %i %i %i\n", sched_active_thread->name, (int)current_prio, (int)other_prio, in_isr);
if (current_prio >= other_prio) { if (current_prio >= other_prio) {
if (in_isr) { if (in_isr) {
@ -191,14 +191,14 @@ void sched_switch(uint16_t current_prio, uint16_t other_prio)
NORETURN void sched_task_exit(void) NORETURN void sched_task_exit(void)
{ {
DEBUG("sched_task_exit(): ending task %s...\n", active_thread->name); DEBUG("sched_task_exit(): ending task %s...\n", sched_active_thread->name);
dINT(); dINT();
sched_threads[active_thread->pid] = NULL; sched_threads[sched_active_thread->pid] = NULL;
num_tasks--; sched_num_threads--;
sched_set_status((tcb_t *)active_thread, STATUS_STOPPED); sched_set_status((tcb_t *)sched_active_thread, STATUS_STOPPED);
active_thread = NULL; sched_active_thread = NULL;
cpu_switch_context_exit(); cpu_switch_context_exit();
} }

View File

@ -34,12 +34,13 @@
inline int thread_getpid(void) inline int thread_getpid(void)
{ {
return active_thread->pid; return sched_active_thread->pid;
} }
int thread_getlastpid(void) int thread_getlastpid(void)
{ {
return last_pid; extern int thread_last_pid;
return thread_last_pid;
} }
int thread_getstatus(int pid) int thread_getstatus(int pid)
@ -67,7 +68,7 @@ void thread_sleep(void)
} }
dINT(); dINT();
sched_set_status((tcb_t *)active_thread, STATUS_SLEEPING); sched_set_status((tcb_t *)sched_active_thread, STATUS_SLEEPING);
eINT(); eINT();
thread_yield(); thread_yield();
} }
@ -85,7 +86,7 @@ int thread_wakeup(int pid)
sched_set_status(other_thread, STATUS_RUNNING); sched_set_status(other_thread, STATUS_RUNNING);
restoreIRQ(old_state); restoreIRQ(old_state);
sched_switch(active_thread->priority, other_thread->priority); sched_switch(sched_active_thread->priority, other_thread->priority);
return 1; return 1;
} }
@ -199,7 +200,7 @@ int thread_create(char *stack, int stacksize, char priority, int flags, void (*f
cib_init(&(cb->msg_queue), 0); cib_init(&(cb->msg_queue), 0);
cb->msg_array = NULL; cb->msg_array = NULL;
num_tasks++; sched_num_threads++;
DEBUG("Created thread %s. PID: %u. Priority: %u.\n", name, cb->pid, priority); DEBUG("Created thread %s. PID: %u. Priority: %u.\n", name, cb->pid, priority);
@ -220,7 +221,7 @@ int thread_create(char *stack, int stacksize, char priority, int flags, void (*f
} }
} }
if (!inISR() && active_thread != NULL) { if (!inISR() && sched_active_thread != NULL) {
eINT(); eINT();
} }

View File

@ -73,7 +73,7 @@ void thread_print_stack(void)
asm("mov %0, sp" : "=r"(stack)); asm("mov %0, sp" : "=r"(stack));
register unsigned int *s = (unsigned int *)stack; register unsigned int *s = (unsigned int *)stack;
printf("task: %X SP: %X\n", (unsigned int) active_thread, (unsigned int) stack); printf("task: %X SP: %X\n", (unsigned int) sched_active_thread, (unsigned int) stack);
register int i = 0; register int i = 0;
s += 5; s += 5;

View File

@ -22,7 +22,7 @@
/* External references */ /* External references */
.extern active_thread .extern sched_active_thread
.extern sched_context_switch_request .extern sched_context_switch_request
.extern sched_run .extern sched_run
.extern DEBUG_Routine .extern DEBUG_Routine
@ -79,15 +79,15 @@ ctx_switch2:
/* store return address and spsr on user mode stack */ /* store return address and spsr on user mode stack */
stmfd lr!, {r0, r1} stmfd lr!, {r0, r1}
/* save user mode stack pointer in *active_thread */ /* save user mode stack pointer in *sched_active_thread */
ldr r1, =active_thread /* r1 = &active_thread */ ldr r1, =sched_active_thread /* r1 = &sched_active_thread */
ldr r1, [r1] /* r1 = *r1 = active_thread */ ldr r1, [r1] /* r1 = *r1 = sched_active_thread */
str lr, [r1] /* store stack pointer in tasks tcb*/ str lr, [r1] /* store stack pointer in tasks tcb*/
/* now the calling task has all its registers saved on its stack and it's SP is saved in its tcb */ /* now the calling task has all its registers saved on its stack and it's SP is saved in its tcb */
/* call scheduler so active_thread points to the next task */ /* call scheduler so sched_active_thread points to the next task */
bl sched_run bl sched_run
b task_return b task_return
/* never coming back */ /* never coming back */
@ -96,15 +96,15 @@ cpu_switch_context_exit:
mov r0, #NOINT|SVCMODE mov r0, #NOINT|SVCMODE
msr cpsr, r0 msr cpsr, r0
/* call scheduler so active_thread points to the next task */ /* call scheduler so sched_active_thread points to the next task */
bl sched_run bl sched_run
/* continue in task_return: */ /* continue in task_return: */
task_return: task_return:
/* load tcb->stackpointer in r0 */ /* load tcb->stackpointer in r0 */
ldr r0, =active_thread /* r0 = &active_thread */ ldr r0, =sched_active_thread /* r0 = &sched_active_thread */
ldr r0, [r0] /* r0 = *r0 = active_thread */ ldr r0, [r0] /* r0 = *r0 = sched_active_thread */
ldr r0, [r0] ldr r0, [r0]
/* restore saved spsr and return address from tasks stack */ /* restore saved spsr and return address from tasks stack */

View File

@ -265,7 +265,7 @@ void _exit(int n)
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
int _getpid(void) int _getpid(void)
{ {
return active_thread->pid; return sched_active_thread->pid;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
int _kill_r(struct _reent *r, int pid, int sig) int _kill_r(struct _reent *r, int pid, int sig)

View File

@ -68,7 +68,7 @@ bool gpioint_set(int port, uint32_t bitmask, int flags, fp_irqcb callback)
if ((port >= PORTINT_MIN) && (port <= PORTINT_MAX)) { if ((port >= PORTINT_MIN) && (port <= PORTINT_MAX)) {
/* set the callback function */ /* set the callback function */
base = number_of_highest_bit(bitmask); base = bitarithm_msb(bitmask);
if (base >= 0) { if (base >= 0) {
cb[port - PORTINT_MIN][base] = callback; cb[port - PORTINT_MIN][base] = callback;

View File

@ -143,8 +143,8 @@ void enter_thread_mode(void)
__set_CONTROL(mode.w); __set_CONTROL(mode.w);
/* load pdc->stackpointer in r0 */ /* load pdc->stackpointer in r0 */
asm("ldr r0, =active_thread" ); /* r0 = &active_thread */ asm("ldr r0, =sched_active_thread" ); /* r0 = &sched_active_thread */
asm("ldr r0, [r0]" ); /* r0 = *r0 = active_thread */ asm("ldr r0, [r0]" ); /* r0 = *r0 = sched_active_thread */
asm("ldr sp, [r0]" ); /* sp = r0 restore stack pointer*/ asm("ldr sp, [r0]" ); /* sp = r0 restore stack pointer*/
asm("pop {r4}" ); /* skip exception return */ asm("pop {r4}" ); /* skip exception return */
asm("pop {r4-r11}" ); asm("pop {r4-r11}" );
@ -189,14 +189,14 @@ __attribute__((always_inline)) static __INLINE void context_save(void)
asm("stmdb r0!,{r4-r11}" ); /* save regs */ asm("stmdb r0!,{r4-r11}" ); /* save regs */
asm("stmdb r0!,{lr}" ); /* exception return value */ asm("stmdb r0!,{lr}" ); /* exception return value */
/* asm("vstmdb sp!, {s16-s31}" ); */ /* TODO save FPU registers if needed */ /* asm("vstmdb sp!, {s16-s31}" ); */ /* TODO save FPU registers if needed */
asm("ldr r1, =active_thread" ); /* load address of current tcb */ asm("ldr r1, =sched_active_thread" ); /* load address of current tcb */
asm("ldr r1, [r1]" ); /* dereference pdc */ asm("ldr r1, [r1]" ); /* dereference pdc */
asm("str r0, [r1]" ); /* write r0 to pdc->sp means current threads stack pointer */ asm("str r0, [r1]" ); /* write r0 to pdc->sp means current threads stack pointer */
} }
__attribute__((always_inline)) static __INLINE void context_restore(void) __attribute__((always_inline)) static __INLINE void context_restore(void)
{ {
asm("ldr r0, =active_thread" ); /* load address of current TCB */ asm("ldr r0, =sched_active_thread" ); /* load address of current TCB */
asm("ldr r0, [r0]" ); /* dereference TCB */ asm("ldr r0, [r0]" ); /* dereference TCB */
asm("ldr r1, [r0]" ); /* load tcb->sp to register 1 */ asm("ldr r1, [r0]" ); /* load tcb->sp to register 1 */
asm("ldmia r1!, {r0}" ); /* restore exception return value from stack */ asm("ldmia r1!, {r0}" ); /* restore exception return value from stack */

View File

@ -48,7 +48,7 @@ void SVC_Handler(void)
{ {
save_context(); save_context();
asm("bl sched_run"); asm("bl sched_run");
/* call scheduler update active_thread variable with pdc of next thread /* call scheduler update sched_active_thread variable with pdc of next thread
* the thread that has higest priority and is in PENDING state */ * the thread that has higest priority and is in PENDING state */
restore_context(); restore_context();
} }
@ -70,19 +70,19 @@ void ctx_switch(void)
asm("mov r12, sp"); asm("mov r12, sp");
asm("stmfd r12!, {r4-r11}"); asm("stmfd r12!, {r4-r11}");
/* save user mode stack pointer in *active_thread */ /* save user mode stack pointer in *sched_active_thread */
asm("ldr r1, =active_thread"); /* r1 = &active_thread */ asm("ldr r1, =sched_active_thread"); /* r1 = &sched_active_thread */
asm("ldr r1, [r1]"); /* r1 = *r1 = active_thread */ asm("ldr r1, [r1]"); /* r1 = *r1 = sched_active_thread */
asm("str r12, [r1]"); /* store stack pointer in tasks pdc*/ asm("str r12, [r1]"); /* store stack pointer in tasks pdc*/
sched_task_return(); sched_task_return();
} }
/* call scheduler so active_thread points to the next task */ /* call scheduler so sched_active_thread points to the next task */
NORETURN void sched_task_return(void) NORETURN void sched_task_return(void)
{ {
/* load pdc->stackpointer in r0 */ /* load pdc->stackpointer in r0 */
asm("ldr r0, =active_thread"); /* r0 = &active_thread */ asm("ldr r0, =sched_active_thread"); /* r0 = &sched_active_thread */
asm("ldr r0, [r0]"); /* r0 = *r0 = active_thread */ asm("ldr r0, [r0]"); /* r0 = *r0 = sched_active_thread */
asm("ldr sp, [r0]"); /* sp = r0 restore stack pointer*/ asm("ldr sp, [r0]"); /* sp = r0 restore stack pointer*/
asm("pop {r4}"); /* skip exception return */ asm("pop {r4}"); /* skip exception return */
asm(" pop {r4-r11}"); asm(" pop {r4-r11}");

View File

@ -89,7 +89,7 @@ void save_context(void)
asm("push {LR}"); asm("push {LR}");
/* save exception return value */ /* save exception return value */
asm("ldr r1, =active_thread"); asm("ldr r1, =sched_active_thread");
/* load address of currend pdc */ /* load address of currend pdc */
asm("ldr r1, [r1]"); asm("ldr r1, [r1]");
/* deref pdc */ /* deref pdc */
@ -99,7 +99,7 @@ void save_context(void)
void restore_context(void) void restore_context(void)
{ {
asm("ldr r0, =active_thread"); asm("ldr r0, =sched_active_thread");
/* load address of currend pdc */ /* load address of currend pdc */
asm("ldr r0, [r0]"); asm("ldr r0, [r0]");
/* deref pdc */ /* deref pdc */

View File

@ -221,7 +221,7 @@ void _exit(int n)
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
int _getpid(void) int _getpid(void)
{ {
return active_thread->pid; return sched_active_thread->pid;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
int _kill_r(struct _reent *r, int pid, int sig) int _kill_r(struct _reent *r, int pid, int sig)

View File

@ -61,7 +61,7 @@ gpioint_set(int port, uint32_t bitmask, int flags, fp_irqcb callback)
volatile unsigned long *en_clr; volatile unsigned long *en_clr;
/* lookup registers */ /* lookup registers */
bit = number_of_highest_bit(bitmask); /* get irq mapping table index */ bit = bitarithm_msb(bitmask); /* get irq mapping table index */
switch(port) { switch(port) {
case 0: /* PORT0 */ case 0: /* PORT0 */

View File

@ -25,7 +25,7 @@ void thread_yield(void)
__save_context(); __save_context();
dINT(); dINT();
/* have active_thread point to the next thread */ /* have sched_active_thread point to the next thread */
sched_run(); sched_run();
eINT(); eINT();
@ -34,7 +34,7 @@ void thread_yield(void)
NORETURN void cpu_switch_context_exit(void) NORETURN void cpu_switch_context_exit(void)
{ {
active_thread = sched_threads[0]; sched_active_thread = sched_threads[0];
sched_run(); sched_run();
__restore_context(); __restore_context();

View File

@ -57,12 +57,12 @@ inline void __save_context_isr(void)
__asm__("push r5"); __asm__("push r5");
__asm__("push r4"); __asm__("push r4");
__asm__("mov.w r1,%0" : "=r"(active_thread->sp)); __asm__("mov.w r1,%0" : "=r"(sched_active_thread->sp));
} }
inline void __restore_context_isr(void) inline void __restore_context_isr(void)
{ {
__asm__("mov.w %0,r1" : : "m"(active_thread->sp)); __asm__("mov.w %0,r1" : : "m"(sched_active_thread->sp));
__asm__("pop r4"); __asm__("pop r4");
__asm__("pop r5"); __asm__("pop r5");

View File

@ -45,7 +45,7 @@
#define ENABLE_DEBUG (0) #define ENABLE_DEBUG (0)
#include "debug.h" #include "debug.h"
extern volatile tcb_t *active_thread; extern volatile tcb_t *sched_active_thread;
volatile int native_interrupts_enabled; volatile int native_interrupts_enabled;
volatile int _native_in_isr; volatile int _native_in_isr;
@ -303,9 +303,9 @@ void native_isr_entry(int sig, siginfo_t *info, void *context)
if (context == NULL) { if (context == NULL) {
errx(EXIT_FAILURE, "native_isr_entry: context is null - unhandled"); errx(EXIT_FAILURE, "native_isr_entry: context is null - unhandled");
} }
if (active_thread == NULL) { if (sched_active_thread == NULL) {
_native_in_isr++; _native_in_isr++;
warnx("native_isr_entry: active_thread is null - unhandled"); warnx("native_isr_entry: sched_active_thread is null - unhandled");
_native_in_isr--; _native_in_isr--;
return; return;
} }
@ -330,7 +330,7 @@ void native_isr_entry(int sig, siginfo_t *info, void *context)
native_isr_context.uc_stack.ss_size = SIGSTKSZ; native_isr_context.uc_stack.ss_size = SIGSTKSZ;
native_isr_context.uc_stack.ss_flags = 0; native_isr_context.uc_stack.ss_flags = 0;
makecontext(&native_isr_context, native_irq_handler, 0); makecontext(&native_isr_context, native_irq_handler, 0);
_native_cur_ctx = (ucontext_t *)active_thread->sp; _native_cur_ctx = (ucontext_t *)sched_active_thread->sp;
DEBUG("\n\n\t\treturn to _native_sig_leave_tramp\n\n"); DEBUG("\n\n\t\treturn to _native_sig_leave_tramp\n\n");
/* disable interrupts in context */ /* disable interrupts in context */

View File

@ -54,7 +54,7 @@
#define ENABLE_DEBUG (0) #define ENABLE_DEBUG (0)
#include "debug.h" #include "debug.h"
extern volatile tcb_t *active_thread; extern volatile tcb_t *sched_active_thread;
ucontext_t end_context; ucontext_t end_context;
char __end_stack[SIGSTKSZ]; char __end_stack[SIGSTKSZ];
@ -129,12 +129,12 @@ void isr_cpu_switch_context_exit(void)
ucontext_t *ctx; ucontext_t *ctx;
DEBUG("XXX: cpu_switch_context_exit()\n"); DEBUG("XXX: cpu_switch_context_exit()\n");
if ((sched_context_switch_request == 1) || (active_thread == NULL)) { if ((sched_context_switch_request == 1) || (sched_active_thread == NULL)) {
sched_run(); sched_run();
} }
DEBUG("XXX: cpu_switch_context_exit(): calling setcontext(%s)\n\n", active_thread->name); DEBUG("XXX: cpu_switch_context_exit(): calling setcontext(%s)\n\n", sched_active_thread->name);
ctx = (ucontext_t *)(active_thread->sp); ctx = (ucontext_t *)(sched_active_thread->sp);
/* the next context will have interrupts enabled due to ucontext */ /* the next context will have interrupts enabled due to ucontext */
DEBUG("XXX: cpu_switch_context_exit: native_interrupts_enabled = 1;\n"); DEBUG("XXX: cpu_switch_context_exit: native_interrupts_enabled = 1;\n");
@ -150,7 +150,7 @@ void isr_cpu_switch_context_exit(void)
void cpu_switch_context_exit(void) void cpu_switch_context_exit(void)
{ {
#ifdef NATIVE_AUTO_EXIT #ifdef NATIVE_AUTO_EXIT
if (num_tasks <= 1) { if (sched_num_threads <= 1) {
DEBUG("cpu_switch_context_exit(): last task has ended. exiting.\n"); DEBUG("cpu_switch_context_exit(): last task has ended. exiting.\n");
exit(EXIT_SUCCESS); exit(EXIT_SUCCESS);
} }
@ -179,8 +179,8 @@ void isr_thread_yield(void)
DEBUG("isr_thread_yield()\n"); DEBUG("isr_thread_yield()\n");
sched_run(); sched_run();
ucontext_t *ctx = (ucontext_t *)(active_thread->sp); ucontext_t *ctx = (ucontext_t *)(sched_active_thread->sp);
DEBUG("isr_thread_yield(): switching to(%s)\n\n", active_thread->name); DEBUG("isr_thread_yield(): switching to(%s)\n\n", sched_active_thread->name);
native_interrupts_enabled = 1; native_interrupts_enabled = 1;
_native_in_isr = 0; _native_in_isr = 0;
@ -191,7 +191,7 @@ void isr_thread_yield(void)
void thread_yield(void) void thread_yield(void)
{ {
ucontext_t *ctx = (ucontext_t *)(active_thread->sp); ucontext_t *ctx = (ucontext_t *)(sched_active_thread->sp);
if (_native_in_isr == 0) { if (_native_in_isr == 0) {
_native_in_isr = 1; _native_in_isr = 1;
dINT(); dINT();

View File

@ -46,7 +46,7 @@
#endif #endif
#include "debug.h" #include "debug.h"
extern volatile tcb_t *active_thread; extern volatile tcb_t *sched_active_thread;
ssize_t (*real_read)(int fd, void *buf, size_t count); ssize_t (*real_read)(int fd, void *buf, size_t count);
ssize_t (*real_write)(int fd, const void *buf, size_t count); ssize_t (*real_write)(int fd, const void *buf, size_t count);
@ -74,12 +74,12 @@ void _native_syscall_leave(void)
&& (_native_in_isr == 0) && (_native_in_isr == 0)
&& (_native_in_syscall == 0) && (_native_in_syscall == 0)
&& (native_interrupts_enabled == 1) && (native_interrupts_enabled == 1)
&& (active_thread != NULL) && (sched_active_thread != NULL)
) )
{ {
_native_in_isr = 1; _native_in_isr = 1;
dINT(); dINT();
_native_cur_ctx = (ucontext_t *)active_thread->sp; _native_cur_ctx = (ucontext_t *)sched_active_thread->sp;
native_isr_context.uc_stack.ss_sp = __isr_stack; native_isr_context.uc_stack.ss_sp = __isr_stack;
native_isr_context.uc_stack.ss_size = SIGSTKSZ; native_isr_context.uc_stack.ss_size = SIGSTKSZ;
native_isr_context.uc_stack.ss_flags = 0; native_isr_context.uc_stack.ss_flags = 0;

View File

@ -99,7 +99,7 @@ caddr_t _sbrk_r(struct _reent *r, size_t incr)
*/ */
int _getpid(void) int _getpid(void)
{ {
return active_thread->pid; return sched_active_thread->pid;
} }
/** /**

View File

@ -197,9 +197,9 @@ void cc1100_phy_init(void)
void cc1100_phy_mutex_lock(void) void cc1100_phy_mutex_lock(void)
{ {
if (active_thread->pid != cc1100_mutex_pid) { if (sched_active_thread->pid != cc1100_mutex_pid) {
mutex_lock(&cc1100_mutex); mutex_lock(&cc1100_mutex);
cc1100_mutex_pid = active_thread->pid; cc1100_mutex_pid = sched_active_thread->pid;
} }
} }

View File

@ -427,7 +427,7 @@ int ccnl_io_loop(struct ccnl_relay_s *ccnl)
void ccnl_riot_relay_start(int max_cache_entries, int fib_threshold_prefix, int fib_threshold_aggregate) void ccnl_riot_relay_start(int max_cache_entries, int fib_threshold_prefix, int fib_threshold_aggregate)
{ {
ccnl_get_timeval(&theRelay.startup_time); ccnl_get_timeval(&theRelay.startup_time);
theRelay.riot_pid = thread_pid; theRelay.riot_pid = sched_active_pid;
DEBUGMSG(1, "This is ccn-lite-relay, starting at %lu:%lu\n", theRelay.startup_time.tv_sec, theRelay.startup_time.tv_usec); DEBUGMSG(1, "This is ccn-lite-relay, starting at %lu:%lu\n", theRelay.startup_time.tv_sec, theRelay.startup_time.tv_usec);
DEBUGMSG(1, " compile time: %s %s\n", __DATE__, __TIME__); DEBUGMSG(1, " compile time: %s %s\n", __DATE__, __TIME__);

View File

@ -158,7 +158,7 @@ int pthread_create(pthread_t *newthread, const pthread_attr_t *attr, void *(*sta
return -1; return -1;
} }
sched_switch(active_thread->priority, PRIORITY_MAIN); sched_switch(sched_active_thread->priority, PRIORITY_MAIN);
return 0; return 0;
} }
@ -217,7 +217,7 @@ int pthread_join(pthread_t th, void **thread_return)
switch (other->status) { switch (other->status) {
case (PTS_RUNNING): case (PTS_RUNNING):
other->joining_thread = thread_pid; other->joining_thread = sched_active_pid;
/* go blocked, I'm waking up if other thread exits */ /* go blocked, I'm waking up if other thread exits */
thread_sleep(); thread_sleep();
/* no break */ /* no break */
@ -265,7 +265,7 @@ pthread_t pthread_self(void)
{ {
pthread_t result = 0; pthread_t result = 0;
mutex_lock(&pthread_mutex); mutex_lock(&pthread_mutex);
int pid = thread_pid; /* thread_pid is volatile */ int pid = sched_active_pid; /* sched_active_pid is volatile */
for (int i = 0; i < MAXTHREADS; i++) { for (int i = 0; i < MAXTHREADS; i++) {
if (pthread_sched_threads[i] && pthread_sched_threads[i]->thread_pid == pid) { if (pthread_sched_threads[i] && pthread_sched_threads[i]->thread_pid == pid) {
result = i+1; result = i+1;

View File

@ -48,16 +48,16 @@ int pthread_barrier_wait(pthread_barrier_t *barrier)
mutex_lock(&barrier->mutex); mutex_lock(&barrier->mutex);
DEBUG("%s: hit a synchronization barrier. pid=%u\n", DEBUG("%s: hit a synchronization barrier. pid=%u\n",
active_thread->name, active_thread->pid); sched_active_thread->name, sched_active_thread->pid);
if (--barrier->count > 0) { if (--barrier->count > 0) {
/* need to wait for further threads */ /* need to wait for further threads */
DEBUG("%s: waiting for %u threads. pid=%u\n", DEBUG("%s: waiting for %u threads. pid=%u\n",
active_thread->name, barrier->count, active_thread->pid); sched_active_thread->name, barrier->count, sched_active_thread->pid);
pthread_barrier_waiting_node_t node; pthread_barrier_waiting_node_t node;
node.pid = thread_pid; node.pid = sched_active_pid;
node.next = barrier->next; node.next = barrier->next;
node.cont = 0; node.cont = 0;
@ -80,7 +80,7 @@ int pthread_barrier_wait(pthread_barrier_t *barrier)
/* all threads have arrived, wake everybody up */ /* all threads have arrived, wake everybody up */
DEBUG("%s: waking every other thread up. pid=%u\n", DEBUG("%s: waking every other thread up. pid=%u\n",
active_thread->name, active_thread->pid); sched_active_thread->name, sched_active_thread->pid);
int count = 1; /* Count number of woken up threads. int count = 1; /* Count number of woken up threads.
* The first thread is the current thread. */ * The first thread is the current thread. */

View File

@ -99,8 +99,8 @@ int pthread_cond_destroy(struct pthread_cond_t *cond)
int pthread_cond_wait(struct pthread_cond_t *cond, struct mutex_t *mutex) int pthread_cond_wait(struct pthread_cond_t *cond, struct mutex_t *mutex)
{ {
queue_node_t n; queue_node_t n;
n.priority = active_thread->priority; n.priority = sched_active_thread->priority;
n.data = active_thread->pid; n.data = sched_active_thread->pid;
n.next = NULL; n.next = NULL;
/* the signaling thread may not hold the mutex, the queue is not thread safe */ /* the signaling thread may not hold the mutex, the queue is not thread safe */
@ -132,7 +132,7 @@ int pthread_cond_timedwait(struct pthread_cond_t *cond, struct mutex_t *mutex, c
reltime = timex_sub(then, now); reltime = timex_sub(then, now);
vtimer_t timer; vtimer_t timer;
vtimer_set_wakeup(&timer, reltime, active_thread->pid); vtimer_set_wakeup(&timer, reltime, sched_active_thread->pid);
int result = pthread_cond_wait(cond, mutex); int result = pthread_cond_wait(cond, mutex);
vtimer_remove(&timer); vtimer_remove(&timer);
@ -157,7 +157,7 @@ int pthread_cond_signal(struct pthread_cond_t *cond)
restoreIRQ(old_state); restoreIRQ(old_state);
if (other_prio >= 0) { if (other_prio >= 0) {
sched_switch(active_thread->priority, other_prio); sched_switch(sched_active_thread->priority, other_prio);
} }
return 0; return 0;
@ -191,7 +191,7 @@ int pthread_cond_broadcast(struct pthread_cond_t *cond)
restoreIRQ(old_state); restoreIRQ(old_state);
if (other_prio >= 0) { if (other_prio >= 0) {
sched_switch(active_thread->priority, other_prio); sched_switch(sched_active_thread->priority, other_prio);
} }
return 0; return 0;

View File

@ -81,7 +81,7 @@ bool __pthread_rwlock_blocked_readingly(const pthread_rwlock_t *rwlock)
} }
queue_node_t *qnode = rwlock->queue.next; queue_node_t *qnode = rwlock->queue.next;
if (qnode->priority > active_thread->priority) { if (qnode->priority > sched_active_thread->priority) {
/* the waiting thread has a lower priority */ /* the waiting thread has a lower priority */
return false; return false;
} }
@ -122,11 +122,11 @@ static int pthread_rwlock_lock(pthread_rwlock_t *rwlock,
/* queue for the lock */ /* queue for the lock */
__pthread_rwlock_waiter_node_t waiting_node = { __pthread_rwlock_waiter_node_t waiting_node = {
.is_writer = is_writer, .is_writer = is_writer,
.thread = (tcb_t *) active_thread, .thread = (tcb_t *) sched_active_thread,
.qnode = { .qnode = {
.next = NULL, .next = NULL,
.data = (uintptr_t) &waiting_node, .data = (uintptr_t) &waiting_node,
.priority = active_thread->priority, .priority = sched_active_thread->priority,
}, },
.continue_ = false, .continue_ = false,
}; };
@ -200,7 +200,7 @@ static int pthread_rwlock_timedlock(pthread_rwlock_t *rwlock,
timex_t reltime = timex_sub(then, now); timex_t reltime = timex_sub(then, now);
vtimer_t timer; vtimer_t timer;
vtimer_set_wakeup(&timer, reltime, active_thread->pid); vtimer_set_wakeup(&timer, reltime, sched_active_thread->pid);
int result = pthread_rwlock_lock(rwlock, is_blocked, is_writer, incr_when_held, true); int result = pthread_rwlock_lock(rwlock, is_blocked, is_writer, incr_when_held, true);
if (result != ETIMEDOUT) { if (result != ETIMEDOUT) {
vtimer_remove(&timer); vtimer_remove(&timer);
@ -315,6 +315,6 @@ int pthread_rwlock_unlock(pthread_rwlock_t *rwlock)
mutex_unlock(&rwlock->mutex); mutex_unlock(&rwlock->mutex);
/* yield if a woken up thread had a higher priority */ /* yield if a woken up thread had a higher priority */
sched_switch(active_thread->priority, prio); sched_switch(sched_active_thread->priority, prio);
return 0; return 0;
} }

View File

@ -49,7 +49,7 @@ int sem_init(sem_t *sem, int pshared, unsigned int value)
int sem_destroy(sem_t *sem) int sem_destroy(sem_t *sem)
{ {
if (sem->queue.next) { if (sem->queue.next) {
DEBUG("%s: tried to destroy active semaphore.\n", active_thread->name); DEBUG("%s: tried to destroy active semaphore.\n", sched_active_thread->name);
return -1; return -1;
} }
return 0; return 0;
@ -77,15 +77,15 @@ int sem_unlink(const char *name)
static void sem_thread_blocked(sem_t *sem) static void sem_thread_blocked(sem_t *sem)
{ {
/* I'm going blocked */ /* I'm going blocked */
sched_set_status((tcb_t*) active_thread, STATUS_MUTEX_BLOCKED); sched_set_status((tcb_t*) sched_active_thread, STATUS_MUTEX_BLOCKED);
queue_node_t n; queue_node_t n;
n.priority = (uint32_t) active_thread->priority; n.priority = (uint32_t) sched_active_thread->priority;
n.data = (size_t) active_thread; n.data = (size_t) sched_active_thread;
n.next = NULL; n.next = NULL;
DEBUG("%s: Adding node to mutex queue: prio: %" PRIu32 "\n", DEBUG("%s: Adding node to mutex queue: prio: %" PRIu32 "\n",
active_thread->name, n.priority); sched_active_thread->name, n.priority);
/* add myself to the waiters queue */ /* add myself to the waiters queue */
queue_priority_add(&sem->queue, &n); queue_priority_add(&sem->queue, &n);
@ -147,9 +147,9 @@ int sem_post(sem_t *sem)
queue_node_t *next = queue_remove_head(&sem->queue); queue_node_t *next = queue_remove_head(&sem->queue);
if (next) { if (next) {
tcb_t *next_process = (tcb_t*) next->data; tcb_t *next_process = (tcb_t*) next->data;
DEBUG("%s: waking up %s\n", active_thread->name, next_process->name); DEBUG("%s: waking up %s\n", sched_active_thread->name, next_process->name);
sched_set_status(next_process, STATUS_PENDING); sched_set_status(next_process, STATUS_PENDING);
sched_switch(active_thread->priority, next_process->priority); sched_switch(sched_active_thread->priority, next_process->priority);
} }
restoreIRQ(old_state); restoreIRQ(old_state);

View File

@ -60,8 +60,8 @@ void thread_print_all(void)
const char *queued = &queued_name[(int)(state >= STATUS_ON_RUNQUEUE)]; // get queued flag const char *queued = &queued_name[(int)(state >= STATUS_ON_RUNQUEUE)]; // get queued flag
int stacksz = p->stack_size; // get stack size int stacksz = p->stack_size; // get stack size
#if SCHEDSTATISTICS #if SCHEDSTATISTICS
double runtime_ticks = pidlist[i].runtime_ticks / (double) hwtimer_now() * 100; double runtime_ticks = sched_pidlist[i].runtime_ticks / (double) hwtimer_now() * 100;
int switches = pidlist[i].schedules; int switches = sched_pidlist[i].schedules;
#endif #endif
overall_stacksz += stacksz; overall_stacksz += stacksz;
stacksz -= thread_measure_stack_free(p->stack_start); stacksz -= thread_measure_stack_free(p->stack_start);

View File

@ -374,7 +374,7 @@ int vtimer_msg_receive_timeout(msg_t *m, timex_t timeout) {
timeout_message.content.ptr = (char *) &timeout_message; timeout_message.content.ptr = (char *) &timeout_message;
vtimer_t t; vtimer_t t;
vtimer_set_msg(&t, timeout, thread_pid, &timeout_message); vtimer_set_msg(&t, timeout, sched_active_pid, &timeout_message);
msg_receive(m); msg_receive(m);
if (m->type == MSG_TIMER && m->content.ptr == (char *) &timeout_message) { if (m->type == MSG_TIMER && m->content.ptr == (char *) &timeout_message) {
/* we hit the timeout */ /* we hit the timeout */

View File

@ -55,7 +55,7 @@ static pthread_rwlock_t rwlock;
static volatile unsigned counter; static volatile unsigned counter;
#define PRINTF(FMT, ...) \ #define PRINTF(FMT, ...) \
printf("%c%u (prio=%u): " FMT "\n", active_thread->name[0], thread_pid, active_thread->priority, __VA_ARGS__) printf("%c%u (prio=%u): " FMT "\n", sched_active_thread->name[0], sched_active_pid, sched_active_thread->priority, __VA_ARGS__)
static void do_sleep(int factor) static void do_sleep(int factor)
{ {

View File

@ -37,22 +37,22 @@ static int parent_pid;
static void child_fun(void) static void child_fun(void)
{ {
printf("Start of %s.\n", active_thread->name); printf("Start of %s.\n", sched_active_thread->name);
for (int i = 0; i < NUM_ITERATIONS; ++i) { for (int i = 0; i < NUM_ITERATIONS; ++i) {
msg_t m; msg_t m;
m.type = i + 1; m.type = i + 1;
m.content.ptr = (void *) active_thread->name; m.content.ptr = (void *) sched_active_thread->name;
msg_send(&m, parent_pid, true); msg_send(&m, parent_pid, true);
} }
printf("End of %s.\n", active_thread->name); printf("End of %s.\n", sched_active_thread->name);
} }
int main(void) int main(void)
{ {
puts("Start."); puts("Start.");
parent_pid = thread_pid; parent_pid = sched_active_pid;
for (int i = 0; i < NUM_CHILDREN; ++i) { for (int i = 0; i < NUM_CHILDREN; ++i) {
snprintf(names[i], sizeof (names[i]), "child%2u", i + 1); snprintf(names[i], sizeof (names[i]), "child%2u", i + 1);

View File

@ -50,7 +50,7 @@ void thread1(void)
int main(void) int main(void)
{ {
msg_t msg; msg_t msg;
p_main = thread_pid; p_main = sched_active_pid;
msg_t msg_q[1]; msg_t msg_q[1];
msg_init_queue(msg_q, 1); msg_init_queue(msg_q, 1);

View File

@ -50,7 +50,7 @@ void thread1(void)
int main(void) int main(void)
{ {
msg_t msg; msg_t msg;
p_main = thread_pid; p_main = sched_active_pid;
p1 = thread_create(t1_stack, KERNEL_CONF_STACKSIZE_PRINTF, PRIORITY_MAIN - 1, p1 = thread_create(t1_stack, KERNEL_CONF_STACKSIZE_PRINTF, PRIORITY_MAIN - 1,
CREATE_WOUT_YIELD | CREATE_STACKTEST, thread1, "nr1"); CREATE_WOUT_YIELD | CREATE_STACKTEST, thread1, "nr1");

View File

@ -140,58 +140,58 @@ static void test_CLRBIT_one_random(void)
TEST_ASSERT_EQUAL_INT(0x00, res); TEST_ASSERT_EQUAL_INT(0x00, res);
} }
static void test_number_of_highest_bit_one(void) static void test_bitarithm_msb_one(void)
{ {
TEST_ASSERT_EQUAL_INT(0, number_of_highest_bit(1)); TEST_ASSERT_EQUAL_INT(0, bitarithm_msb(1));
} }
static void test_number_of_highest_bit_limit(void) static void test_bitarithm_msb_limit(void)
{ {
TEST_ASSERT_EQUAL_INT(sizeof(unsigned) * 8 - 1, TEST_ASSERT_EQUAL_INT(sizeof(unsigned) * 8 - 1,
number_of_highest_bit(UINT_MAX)); bitarithm_msb(UINT_MAX));
} }
static void test_number_of_highest_bit_random(void) static void test_bitarithm_msb_random(void)
{ {
TEST_ASSERT_EQUAL_INT(2, number_of_highest_bit(4)); /* randomized by fair TEST_ASSERT_EQUAL_INT(2, bitarithm_msb(4)); /* randomized by fair
dice roll ;-) */ dice roll ;-) */
} }
static void test_number_of_lowest_bit_one(void) static void test_bitarithm_lsb_one(void)
{ {
TEST_ASSERT_EQUAL_INT(0, number_of_lowest_bit(1)); TEST_ASSERT_EQUAL_INT(0, bitarithm_lsb(1));
} }
static void test_number_of_lowest_bit_limit(void) static void test_bitarithm_lsb_limit(void)
{ {
TEST_ASSERT_EQUAL_INT(0, number_of_lowest_bit(UINT_MAX)); TEST_ASSERT_EQUAL_INT(0, bitarithm_lsb(UINT_MAX));
} }
static void test_number_of_lowest_bit_random(void) static void test_bitarithm_lsb_random(void)
{ {
TEST_ASSERT_EQUAL_INT(3, number_of_lowest_bit(8)); /* randomized by fair TEST_ASSERT_EQUAL_INT(3, bitarithm_lsb(8)); /* randomized by fair
dice roll ;-) */ dice roll ;-) */
} }
static void test_number_of_bits_set_null(void) static void test_bitarithm_bits_set_null(void)
{ {
TEST_ASSERT_EQUAL_INT(0, number_of_bits_set(0)); TEST_ASSERT_EQUAL_INT(0, bitarithm_bits_set(0));
} }
static void test_number_of_bits_set_one(void) static void test_bitarithm_bits_set_one(void)
{ {
TEST_ASSERT_EQUAL_INT(1, number_of_bits_set(1)); TEST_ASSERT_EQUAL_INT(1, bitarithm_bits_set(1));
} }
static void test_number_of_bits_set_limit(void) static void test_bitarithm_bits_set_limit(void)
{ {
TEST_ASSERT_EQUAL_INT(sizeof(unsigned) * 8, TEST_ASSERT_EQUAL_INT(sizeof(unsigned) * 8,
number_of_bits_set(UINT_MAX)); bitarithm_bits_set(UINT_MAX));
} }
static void test_number_of_bits_set_random(void) static void test_bitarithm_bits_set_random(void)
{ {
TEST_ASSERT_EQUAL_INT(3, number_of_bits_set(7)); /* randomized by fair TEST_ASSERT_EQUAL_INT(3, bitarithm_bits_set(7)); /* randomized by fair
dice roll ;-) */ dice roll ;-) */
} }
@ -212,16 +212,16 @@ Test *tests_core_bitarithm_tests(void)
new_TestFixture(test_CLRBIT_null_one), new_TestFixture(test_CLRBIT_null_one),
new_TestFixture(test_CLRBIT_one_null), new_TestFixture(test_CLRBIT_one_null),
new_TestFixture(test_CLRBIT_one_random), new_TestFixture(test_CLRBIT_one_random),
new_TestFixture(test_number_of_highest_bit_one), new_TestFixture(test_bitarithm_msb_one),
new_TestFixture(test_number_of_highest_bit_limit), new_TestFixture(test_bitarithm_msb_limit),
new_TestFixture(test_number_of_highest_bit_random), new_TestFixture(test_bitarithm_msb_random),
new_TestFixture(test_number_of_lowest_bit_one), new_TestFixture(test_bitarithm_lsb_one),
new_TestFixture(test_number_of_lowest_bit_limit), new_TestFixture(test_bitarithm_lsb_limit),
new_TestFixture(test_number_of_lowest_bit_random), new_TestFixture(test_bitarithm_lsb_random),
new_TestFixture(test_number_of_bits_set_null), new_TestFixture(test_bitarithm_bits_set_null),
new_TestFixture(test_number_of_bits_set_one), new_TestFixture(test_bitarithm_bits_set_one),
new_TestFixture(test_number_of_bits_set_limit), new_TestFixture(test_bitarithm_bits_set_limit),
new_TestFixture(test_number_of_bits_set_random), new_TestFixture(test_bitarithm_bits_set_random),
}; };
EMB_UNIT_TESTCALLER(core_bitarithm_tests, NULL, NULL, fixtures); EMB_UNIT_TESTCALLER(core_bitarithm_tests, NULL, NULL, fixtures);