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:
parent
94e4ee1611
commit
ef5ec344fd
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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_ */
|
||||||
/** @} */
|
/** @} */
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
*/
|
*/
|
||||||
|
52
core/msg.c
52
core/msg.c
@ -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;
|
||||||
|
27
core/mutex.c
27
core/mutex.c
@ -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();
|
||||||
}
|
}
|
||||||
|
70
core/sched.c
70
core/sched.c
@ -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();
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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 */
|
||||||
|
@ -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)
|
||||||
|
@ -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;
|
||||||
|
@ -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 */
|
||||||
|
@ -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}");
|
||||||
|
@ -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 */
|
||||||
|
@ -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)
|
||||||
|
@ -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 */
|
||||||
|
@ -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();
|
||||||
|
@ -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");
|
||||||
|
@ -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 */
|
||||||
|
@ -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();
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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__);
|
||||||
|
@ -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;
|
||||||
|
@ -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. */
|
||||||
|
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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 */
|
||||||
|
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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");
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user