2009-09-20 16:17:37 +00:00
|
|
|
/*
|
2011-03-18 18:38:08 +00:00
|
|
|
ChibiOS/RT - Copyright (C) 2006,2007,2008,2009,2010,
|
|
|
|
2011 Giovanni Di Sirio.
|
2009-09-20 16:17:37 +00:00
|
|
|
|
|
|
|
This file is part of ChibiOS/RT.
|
|
|
|
|
|
|
|
ChibiOS/RT is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
ChibiOS/RT is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
/*
|
2009-10-03 15:58:50 +00:00
|
|
|
* **** This file incorporates work covered by the following copyright and ****
|
|
|
|
* **** permission notice: ****
|
|
|
|
*
|
|
|
|
* Copyright (c) 2001-2004 Swedish Institute of Computer Science.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
|
|
* are permitted provided that the following conditions are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright notice,
|
|
|
|
* this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
|
|
* and/or other materials provided with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
|
|
* derived from this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
|
|
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
|
|
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
|
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
|
|
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
|
|
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
|
|
|
* OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This file is part of the lwIP TCP/IP stack.
|
|
|
|
*
|
|
|
|
* Author: Adam Dunkels <adam@sics.se>
|
|
|
|
*
|
|
|
|
*/
|
2009-09-20 16:17:37 +00:00
|
|
|
|
2009-12-08 17:44:03 +00:00
|
|
|
#include "ch.h"
|
2009-09-20 16:17:37 +00:00
|
|
|
|
|
|
|
#include "lwip/opt.h"
|
|
|
|
#include "lwip/mem.h"
|
|
|
|
#include "lwip/sys.h"
|
2010-04-14 16:07:34 +00:00
|
|
|
#include "lwip/stats.h"
|
2009-09-20 16:17:37 +00:00
|
|
|
|
|
|
|
#include "arch/cc.h"
|
|
|
|
#include "arch/sys_arch.h"
|
|
|
|
|
|
|
|
void sys_init(void) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
sys_sem_t sys_sem_new(u8_t count) {
|
|
|
|
|
2009-10-16 17:45:19 +00:00
|
|
|
sys_sem_t sem = chHeapAlloc(NULL, sizeof(Semaphore));
|
2010-04-14 16:07:34 +00:00
|
|
|
if (sem == 0) {
|
|
|
|
SYS_STATS_INC(sem.err);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
chSemInit(sem, (cnt_t)count);
|
|
|
|
SYS_STATS_INC(sem.used);
|
|
|
|
}
|
2009-09-20 16:17:37 +00:00
|
|
|
return sem;
|
|
|
|
}
|
|
|
|
|
|
|
|
void sys_sem_free(sys_sem_t sem) {
|
|
|
|
|
2009-10-03 19:24:16 +00:00
|
|
|
chHeapFree(sem);
|
2010-04-14 16:07:34 +00:00
|
|
|
SYS_STATS_DEC(sem.used);
|
2009-09-20 16:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void sys_sem_signal(sys_sem_t sem) {
|
|
|
|
|
|
|
|
chSemSignal(sem);
|
|
|
|
}
|
|
|
|
|
|
|
|
u32_t sys_arch_sem_wait(sys_sem_t sem, u32_t timeout) {
|
2011-05-15 13:05:47 +00:00
|
|
|
systime_t time, tmo;
|
2009-09-20 16:17:37 +00:00
|
|
|
|
|
|
|
chSysLock();
|
2011-05-15 13:05:47 +00:00
|
|
|
tmo = timeout > 0 ? (systime_t)timeout : TIME_INFINITE;
|
2009-09-20 16:17:37 +00:00
|
|
|
time = chTimeNow();
|
2011-05-15 13:05:47 +00:00
|
|
|
if (chSemWaitTimeoutS(sem, tmo) != RDY_OK)
|
2009-09-20 18:39:37 +00:00
|
|
|
time = SYS_ARCH_TIMEOUT;
|
|
|
|
else
|
|
|
|
time = chTimeNow() - time;
|
2009-09-20 16:17:37 +00:00
|
|
|
chSysUnlock();
|
|
|
|
return time;
|
|
|
|
}
|
|
|
|
|
|
|
|
sys_mbox_t sys_mbox_new(int size) {
|
2010-04-14 16:07:34 +00:00
|
|
|
|
|
|
|
sys_mbox_t mbox = chHeapAlloc(NULL, sizeof(Mailbox) + sizeof(msg_t) * size);
|
|
|
|
if (mbox == 0) {
|
|
|
|
SYS_STATS_INC(mbox.err);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
chMBInit(mbox, (void *)(((uint8_t *)mbox) + sizeof(Mailbox)), size);
|
|
|
|
SYS_STATS_INC(mbox.used);
|
|
|
|
}
|
2009-09-20 16:17:37 +00:00
|
|
|
return mbox;
|
|
|
|
}
|
|
|
|
|
|
|
|
void sys_mbox_free(sys_mbox_t mbox) {
|
|
|
|
|
2009-10-03 19:24:16 +00:00
|
|
|
chHeapFree(mbox);
|
2010-04-14 16:07:34 +00:00
|
|
|
SYS_STATS_DEC(mbox.used);
|
2009-09-20 16:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void sys_mbox_post(sys_mbox_t mbox, void *msg) {
|
|
|
|
|
|
|
|
chMBPost(mbox, (msg_t)msg, TIME_INFINITE);
|
|
|
|
}
|
|
|
|
|
|
|
|
err_t sys_mbox_trypost(sys_mbox_t mbox, void *msg) {
|
|
|
|
|
|
|
|
if (chMBPost(mbox, (msg_t)msg, TIME_IMMEDIATE) == RDY_TIMEOUT)
|
|
|
|
return ERR_MEM;
|
|
|
|
return ERR_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
u32_t sys_arch_mbox_fetch(sys_mbox_t mbox, void **msg, u32_t timeout) {
|
2011-05-15 13:05:47 +00:00
|
|
|
systime_t time, tmo;
|
2009-09-20 16:17:37 +00:00
|
|
|
|
2009-09-20 18:39:37 +00:00
|
|
|
chSysLock();
|
2011-05-15 13:05:47 +00:00
|
|
|
tmo = timeout > 0 ? (systime_t)timeout : TIME_INFINITE;
|
2009-09-20 18:39:37 +00:00
|
|
|
time = chTimeNow();
|
2011-05-15 13:05:47 +00:00
|
|
|
if (chMBFetchS(mbox, (msg_t *)msg, tmo) != RDY_OK)
|
2009-09-20 18:39:37 +00:00
|
|
|
time = SYS_ARCH_TIMEOUT;
|
|
|
|
else
|
|
|
|
time = chTimeNow() - time;
|
|
|
|
chSysUnlock();
|
|
|
|
return time;
|
2009-09-20 16:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
u32_t sys_arch_mbox_tryfetch(sys_mbox_t mbox, void **msg) {
|
|
|
|
|
2009-09-20 18:39:37 +00:00
|
|
|
if (chMBFetch(mbox, (msg_t *)msg, TIME_IMMEDIATE) == RDY_TIMEOUT)
|
|
|
|
return SYS_MBOX_EMPTY;
|
|
|
|
return 0;
|
2009-09-20 16:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
struct sys_timeouts *sys_arch_timeouts(void) {
|
|
|
|
|
2009-10-03 19:24:16 +00:00
|
|
|
return (struct sys_timeouts *)currp->p_lwipspace;
|
2009-09-20 16:17:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sys_thread_t sys_thread_new(char *name, void (* thread)(void *arg),
|
|
|
|
void *arg, int stacksize, int prio) {
|
2009-10-17 10:33:37 +00:00
|
|
|
(void)name;
|
2009-09-20 16:17:37 +00:00
|
|
|
size_t wsz = THD_WA_SIZE(stacksize);
|
2009-10-16 17:45:19 +00:00
|
|
|
void *wsp = chCoreAlloc(wsz);
|
2009-09-20 16:17:37 +00:00
|
|
|
if (wsp == NULL)
|
|
|
|
return NULL;
|
|
|
|
return (sys_thread_t)chThdCreateStatic(wsp, wsz, prio, (tfunc_t)thread, arg);
|
|
|
|
}
|
|
|
|
|
|
|
|
sys_prot_t sys_arch_protect(void) {
|
|
|
|
|
|
|
|
chSysLock();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void sys_arch_unprotect(sys_prot_t pval) {
|
|
|
|
|
2009-10-17 10:33:37 +00:00
|
|
|
(void)pval;
|
2009-09-20 16:17:37 +00:00
|
|
|
chSysUnlock();
|
|
|
|
}
|