Commit e7b8508a authored by Marcus Nordenberg's avatar Marcus Nordenberg Committed by Esteban Blanc

profinet: add termination of supervision thread

Terminate the supervision thread in a controlled manner.

(cherry picked from commit fc937470b68f2e58f87047fbbc1de132ba149f23)
parent 8703ee24
...@@ -327,18 +327,39 @@ static pwr_tStatus IoAgentWrite(io_tCtx ctx, io_sAgent* ap) ...@@ -327,18 +327,39 @@ static pwr_tStatus IoAgentWrite(io_tCtx ctx, io_sAgent* ap)
static pwr_tStatus IoAgentClose(io_tCtx ctx, io_sAgent* ap) static pwr_tStatus IoAgentClose(io_tCtx ctx, io_sAgent* ap)
{ {
io_sAgentLocal* local; io_sAgentLocal* local;
int *exitcodep;
int error;
pwr_tStatus sts = PB__NOTINIT; pwr_tStatus sts = PB__NOTINIT;
local = (io_sAgentLocal*)ap->Local; local = (io_sAgentLocal*)ap->Local;
if (ctx->Node->EmergBreakTrue == 1)
errh_Fatal("Emergency break detected shutting down PROFINET");
/* Stop profistack */ /* Stop profistack */
pnak_init(); // Stop the supervision thread before shutting down PROFINET.
local = (io_sAgentLocal*)ap->Local;
if (!local) return IO__SUCCESS;
sts = pnak_stop_profistack(0); if ((error = pthread_cancel(local->handle_events)))
errh_Warning("Unsuccessful cancelation of PROFINET supervision thread");
else
errh_Info("Canceled PROFINET supervision thread");
// Wait for the thread to exit
if ((error = pthread_join(local->handle_events, (void**)&exitcodep)))
errh_Warning("Unable to wait for PROFINET thread! Might cause undefined behaviour...");
else
errh_Info("PROFINET supervision thread has exited. Stopping PROFINET...");
sts = pnak_stop_stack(0);
pnak_term(); pnak_term();
free(local);
local = NULL;
/* Clean data areas .... */ /* Clean data areas .... */
return sts; return sts;
...@@ -349,7 +370,6 @@ static pwr_tStatus IoAgentSwap(io_tCtx ctx, io_sAgent* ap, io_eEvent event) ...@@ -349,7 +370,6 @@ static pwr_tStatus IoAgentSwap(io_tCtx ctx, io_sAgent* ap, io_eEvent event)
switch (event) { switch (event) {
case io_eEvent_EmergencyBreak: case io_eEvent_EmergencyBreak:
case io_eEvent_IoCommEmergencyBreak: case io_eEvent_IoCommEmergencyBreak:
errh_Fatal("Emergency break detected shutting down profinet");
IoAgentClose(ctx, ap); IoAgentClose(ctx, ap);
break; break;
default: default:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment