diff options
author | Giovanni Di Sirio <gdisirio@gmail.com> | 2015-09-26 07:12:22 +0000 |
---|---|---|
committer | Giovanni Di Sirio <gdisirio@gmail.com> | 2015-09-26 07:12:22 +0000 |
commit | 8a1e2ccd721f6b874884d0afe1bc704bbb382ec6 (patch) | |
tree | 89a2d420bd9d8f38fbff8a461c6cac4c3ac8aa21 /os/rt | |
parent | 09b0d9645a7c5b103f53b10eadabc839cde88054 (diff) | |
download | ChibiOS-8a1e2ccd721f6b874884d0afe1bc704bbb382ec6.tar.gz ChibiOS-8a1e2ccd721f6b874884d0afe1bc704bbb382ec6.tar.bz2 ChibiOS-8a1e2ccd721f6b874884d0afe1bc704bbb382ec6.zip |
Fixed bug #644.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@8328 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os/rt')
-rw-r--r-- | os/rt/include/ch.h | 4 | ||||
-rw-r--r-- | os/rt/ports/ARMCMx/cmsis_os/cmsis_os.c | 17 |
2 files changed, 13 insertions, 8 deletions
diff --git a/os/rt/include/ch.h b/os/rt/include/ch.h index cb4db9392..b9a8828a7 100644 --- a/os/rt/include/ch.h +++ b/os/rt/include/ch.h @@ -48,7 +48,7 @@ /**
* @brief Kernel version string.
*/
-#define CH_KERNEL_VERSION "3.0.2"
+#define CH_KERNEL_VERSION "3.0.3"
/**
* @brief Kernel version major number.
@@ -63,7 +63,7 @@ /**
* @brief Kernel version patch number.
*/
-#define CH_KERNEL_PATCH 2
+#define CH_KERNEL_PATCH 3
/** @} */
/* Core headers.*/
diff --git a/os/rt/ports/ARMCMx/cmsis_os/cmsis_os.c b/os/rt/ports/ARMCMx/cmsis_os/cmsis_os.c index 4480bd493..30174405f 100644 --- a/os/rt/ports/ARMCMx/cmsis_os/cmsis_os.c +++ b/os/rt/ports/ARMCMx/cmsis_os/cmsis_os.c @@ -224,7 +224,7 @@ osTimerId osTimerCreate(const osTimerDef_t *timer_def, */
osStatus osTimerStart(osTimerId timer_id, uint32_t millisec) {
- if (millisec == 0)
+ if ((millisec == 0) || (millisec == osWaitForever))
return osErrorValue;
timer_id->millisec = millisec;
@@ -289,7 +289,8 @@ int32_t osSignalClear(osThreadId thread_id, int32_t signals) { */
osEvent osSignalWait(int32_t signals, uint32_t millisec) {
osEvent event;
- systime_t timeout = millisec == 0 ? TIME_INFINITE : MS2ST(millisec);
+ systime_t timeout = ((millisec == 0) || (millisec == osWaitForever)) ?
+ TIME_INFINITE : MS2ST(millisec);
if (signals == 0)
event.value.signals = (uint32_t)chEvtWaitAnyTimeout(ALL_EVENTS, timeout);
@@ -325,7 +326,8 @@ osSemaphoreId osSemaphoreCreate(const osSemaphoreDef_t *semaphore_def, * @brief Wait on a semaphore.
*/
int32_t osSemaphoreWait(osSemaphoreId semaphore_id, uint32_t millisec) {
- systime_t timeout = millisec == 0 ? TIME_INFINITE : MS2ST(millisec);
+ systime_t timeout = ((millisec == 0) || (millisec == osWaitForever)) ?
+ TIME_INFINITE : MS2ST(millisec);
msg_t msg = chSemWaitTimeout((semaphore_t *)semaphore_id, timeout);
switch (msg) {
@@ -380,7 +382,8 @@ osMutexId osMutexCreate(const osMutexDef_t *mutex_def) { * @brief Wait on a mutex.
*/
osStatus osMutexWait(osMutexId mutex_id, uint32_t millisec) {
- systime_t timeout = millisec == 0 ? TIME_INFINITE : MS2ST(millisec);
+ systime_t timeout = ((millisec == 0) || (millisec == osWaitForever)) ?
+ TIME_INFINITE : MS2ST(millisec);
msg_t msg = chBSemWaitTimeout((binary_semaphore_t *)mutex_id, timeout);
switch (msg) {
@@ -494,7 +497,8 @@ osStatus osMessagePut(osMessageQId queue_id, uint32_t info,
uint32_t millisec) {
msg_t msg;
- systime_t timeout = millisec == 0 ? TIME_INFINITE : MS2ST(millisec);
+ systime_t timeout = ((millisec == 0) || (millisec == osWaitForever)) ?
+ TIME_INFINITE : MS2ST(millisec);
if (port_is_isr_context()) {
@@ -520,7 +524,8 @@ osEvent osMessageGet(osMessageQId queue_id, uint32_t millisec) {
msg_t msg;
osEvent event;
- systime_t timeout = millisec == 0 ? TIME_INFINITE : MS2ST(millisec);
+ systime_t timeout = ((millisec == 0) || (millisec == osWaitForever)) ?
+ TIME_INFINITE : MS2ST(millisec);
event.def.message_id = queue_id;
|