[PATCH 1/2] mpci: Avoid Giant lock
Sebastian Huber
sebastian.huber at embedded-brains.de
Fri Mar 18 14:48:39 UTC 2016
Update #2555.
---
cpukit/score/src/mpci.c | 19 +++++++++++--------
1 file changed, 11 insertions(+), 8 deletions(-)
diff --git a/cpukit/score/src/mpci.c b/cpukit/score/src/mpci.c
index c191bbe..3929d78 100644
--- a/cpukit/score/src/mpci.c
+++ b/cpukit/score/src/mpci.c
@@ -237,16 +237,19 @@ uint32_t _MPCI_Send_request_packet (
uint32_t timeout_code
)
{
- Thread_Control *executing = _Thread_Executing;
+ Per_CPU_Control *cpu_self;
+ Thread_Control *executing;
- the_packet->source_tid = executing->Object.id;
- the_packet->source_priority = executing->current_priority;
- the_packet->to_convert =
- ( the_packet->to_convert - sizeof(MP_packet_Prefix) ) / sizeof(uint32_t);
+ cpu_self = _Thread_Dispatch_disable();
+
+ executing = _Per_CPU_Get_executing( cpu_self );
- executing->Wait.id = the_packet->id;
+ the_packet->source_tid = executing->Object.id;
+ the_packet->source_priority = executing->current_priority;
+ the_packet->to_convert =
+ ( the_packet->to_convert - sizeof(MP_packet_Prefix) ) / sizeof(uint32_t);
- _Thread_Disable_dispatch();
+ executing->Wait.id = the_packet->id;
(*_MPCI_table->send_packet)( destination, the_packet );
@@ -265,7 +268,7 @@ uint32_t _MPCI_Send_request_packet (
timeout_code
);
- _Thread_Enable_dispatch();
+ _Thread_Dispatch_enable( cpu_self );
return executing->Wait.return_code;
}
--
1.8.4.5
More information about the devel
mailing list