未验证 提交 ee733bab 编写于 作者: B Bernard Xiong 提交者: GitHub

Merge pull request #3975 from mysterywolf/master

[bug fixed] add mb mq value overflow-check code
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
* 2019-05-17 Bernard change version number to v4.0.2 * 2019-05-17 Bernard change version number to v4.0.2
* 2019-12-20 Bernard change version number to v4.0.3 * 2019-12-20 Bernard change version number to v4.0.3
* 2020-08-10 Meco Man add macro for struct rt_device_ops * 2020-08-10 Meco Man add macro for struct rt_device_ops
* 2020-10-23 Meco Man define maximum value of ipc type
*/ */
#ifndef __RT_DEF_H__ #ifndef __RT_DEF_H__
...@@ -102,6 +103,13 @@ typedef rt_base_t rt_off_t; /**< Type for offset */ ...@@ -102,6 +103,13 @@ typedef rt_base_t rt_off_t; /**< Type for offset */
#define RT_UINT32_MAX 0xffffffff /**< Maxium number of UINT32 */ #define RT_UINT32_MAX 0xffffffff /**< Maxium number of UINT32 */
#define RT_TICK_MAX RT_UINT32_MAX /**< Maxium number of tick */ #define RT_TICK_MAX RT_UINT32_MAX /**< Maxium number of tick */
/* maximum value of ipc type */
#define RT_SEM_VALUE_MAX RT_UINT16_MAX /**< Maxium number of semaphore .value */
#define RT_MUTEX_VALUE_MAX RT_UINT16_MAX /**< Maxium number of mutex .value */
#define RT_MUTEX_HOLD_MAX RT_UINT8_MAX /**< Maxium number of mutex .hold */
#define RT_MB_ENTRY_MAX RT_UINT16_MAX /**< Maxium number of mailbox .entry */
#define RT_MQ_ENTRY_MAX RT_UINT16_MAX /**< Maxium number of message queue .entry */
#if defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) #if defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
#define __CLANG_ARM #define __CLANG_ARM
#endif #endif
......
...@@ -36,8 +36,7 @@ ...@@ -36,8 +36,7 @@
* 2019-09-16 tyx add send wait support for message queue * 2019-09-16 tyx add send wait support for message queue
* 2020-07-29 Meco Man fix thread->event_set/event_info when received an * 2020-07-29 Meco Man fix thread->event_set/event_info when received an
* event without pending * event without pending
* 2020-10-11 Meco Man add semaphore values' overflow-check code * 2020-10-11 Meco Man add value overflow-check code
* 2020-10-21 Meco Man add mutex values' overflow-check code
*/ */
#include <rtthread.h> #include <rtthread.h>
...@@ -466,7 +465,7 @@ rt_err_t rt_sem_release(rt_sem_t sem) ...@@ -466,7 +465,7 @@ rt_err_t rt_sem_release(rt_sem_t sem)
} }
else else
{ {
if(sem->value < 65535u) if(sem->value < RT_SEM_VALUE_MAX)
{ {
sem->value ++; /* increase value */ sem->value ++; /* increase value */
} }
...@@ -697,7 +696,7 @@ rt_err_t rt_mutex_take(rt_mutex_t mutex, rt_int32_t time) ...@@ -697,7 +696,7 @@ rt_err_t rt_mutex_take(rt_mutex_t mutex, rt_int32_t time)
if (mutex->owner == thread) if (mutex->owner == thread)
{ {
if(mutex->hold < 255u) if(mutex->hold < RT_MUTEX_HOLD_MAX)
{ {
/* it's the same thread */ /* it's the same thread */
mutex->hold ++; mutex->hold ++;
...@@ -724,7 +723,15 @@ __again: ...@@ -724,7 +723,15 @@ __again:
/* set mutex owner and original priority */ /* set mutex owner and original priority */
mutex->owner = thread; mutex->owner = thread;
mutex->original_priority = thread->current_priority; mutex->original_priority = thread->current_priority;
mutex->hold ++; if(mutex->hold < RT_MUTEX_HOLD_MAX)
{
mutex->hold ++;
}
else
{
rt_hw_interrupt_enable(temp); /* enable interrupt */
return -RT_EFULL; /* value overflowed */
}
} }
else else
{ {
...@@ -881,7 +888,15 @@ rt_err_t rt_mutex_release(rt_mutex_t mutex) ...@@ -881,7 +888,15 @@ rt_err_t rt_mutex_release(rt_mutex_t mutex)
/* set new owner and priority */ /* set new owner and priority */
mutex->owner = thread; mutex->owner = thread;
mutex->original_priority = thread->current_priority; mutex->original_priority = thread->current_priority;
mutex->hold ++; if(mutex->hold < RT_MUTEX_HOLD_MAX)
{
mutex->hold ++;
}
else
{
rt_hw_interrupt_enable(temp); /* enable interrupt */
return -RT_EFULL; /* value overflowed */
}
/* resume thread */ /* resume thread */
rt_ipc_list_resume(&(mutex->parent.suspend_thread)); rt_ipc_list_resume(&(mutex->parent.suspend_thread));
...@@ -890,9 +905,17 @@ rt_err_t rt_mutex_release(rt_mutex_t mutex) ...@@ -890,9 +905,17 @@ rt_err_t rt_mutex_release(rt_mutex_t mutex)
} }
else else
{ {
/* increase value */ if(mutex->value < RT_MUTEX_VALUE_MAX)
mutex->value ++; {
/* increase value */
mutex->value ++;
}
else
{
rt_hw_interrupt_enable(temp); /* enable interrupt */
return -RT_EFULL; /* value overflowed */
}
/* clear owner */ /* clear owner */
mutex->owner = RT_NULL; mutex->owner = RT_NULL;
mutex->original_priority = 0xff; mutex->original_priority = 0xff;
...@@ -1583,9 +1606,18 @@ rt_err_t rt_mb_send_wait(rt_mailbox_t mb, ...@@ -1583,9 +1606,18 @@ rt_err_t rt_mb_send_wait(rt_mailbox_t mb,
++ mb->in_offset; ++ mb->in_offset;
if (mb->in_offset >= mb->size) if (mb->in_offset >= mb->size)
mb->in_offset = 0; mb->in_offset = 0;
/* increase message entry */
mb->entry ++; if(mb->entry < RT_MB_ENTRY_MAX)
{
/* increase message entry */
mb->entry ++;
}
else
{
rt_hw_interrupt_enable(temp); /* enable interrupt */
return -RT_EFULL; /* value overflowed */
}
/* resume suspended thread */ /* resume suspended thread */
if (!rt_list_isempty(&mb->parent.suspend_thread)) if (!rt_list_isempty(&mb->parent.suspend_thread))
{ {
...@@ -2147,8 +2179,16 @@ rt_err_t rt_mq_send_wait(rt_mq_t mq, ...@@ -2147,8 +2179,16 @@ rt_err_t rt_mq_send_wait(rt_mq_t mq,
if (mq->msg_queue_head == RT_NULL) if (mq->msg_queue_head == RT_NULL)
mq->msg_queue_head = msg; mq->msg_queue_head = msg;
/* increase message entry */ if(mq->entry < RT_MQ_ENTRY_MAX)
mq->entry ++; {
/* increase message entry */
mq->entry ++;
}
else
{
rt_hw_interrupt_enable(temp); /* enable interrupt */
return -RT_EFULL; /* value overflowed */
}
/* resume suspended thread */ /* resume suspended thread */
if (!rt_list_isempty(&mq->parent.suspend_thread)) if (!rt_list_isempty(&mq->parent.suspend_thread))
...@@ -2247,9 +2287,17 @@ rt_err_t rt_mq_urgent(rt_mq_t mq, const void *buffer, rt_size_t size) ...@@ -2247,9 +2287,17 @@ rt_err_t rt_mq_urgent(rt_mq_t mq, const void *buffer, rt_size_t size)
if (mq->msg_queue_tail == RT_NULL) if (mq->msg_queue_tail == RT_NULL)
mq->msg_queue_tail = msg; mq->msg_queue_tail = msg;
/* increase message entry */ if(mq->entry < RT_MQ_ENTRY_MAX)
mq->entry ++; {
/* increase message entry */
mq->entry ++;
}
else
{
rt_hw_interrupt_enable(temp); /* enable interrupt */
return -RT_EFULL; /* value overflowed */
}
/* resume suspended thread */ /* resume suspended thread */
if (!rt_list_isempty(&mq->parent.suspend_thread)) if (!rt_list_isempty(&mq->parent.suspend_thread))
{ {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册