author | peter |
Fri, 14 Mar 2008 10:55:34 +0100 | |
changeset 417 | ae068232859c |
parent 381 | 854c43cdc24a |
child 475 | 4b63ea646964 |
permissions | -rw-r--r-- |
0 | 1 |
/* |
208 | 2 |
This file is part of CanFestival, a library implementing CanOpen |
3 |
Stack. |
|
0 | 4 |
|
208 | 5 |
Copyright (C): Edouard TISSERANT and Francis DUPIN |
0 | 6 |
|
208 | 7 |
See COPYING file for copyrights details. |
0 | 8 |
|
208 | 9 |
This library is free software; you can redistribute it and/or |
10 |
modify it under the terms of the GNU Lesser General Public |
|
11 |
License as published by the Free Software Foundation; either |
|
12 |
version 2.1 of the License, or (at your option) any later version. |
|
0 | 13 |
|
208 | 14 |
This library is distributed in the hope that it will be useful, |
15 |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
16 |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
17 |
Lesser General Public License for more details. |
|
0 | 18 |
|
208 | 19 |
You should have received a copy of the GNU Lesser General Public |
20 |
License along with this library; if not, write to the Free Software |
|
21 |
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 |
|
22 |
USA |
|
0 | 23 |
*/ |
208 | 24 |
/*! |
25 |
** @file nmtSlave.c |
|
26 |
** @author Edouard TISSERANT and Francis DUPIN |
|
27 |
** @date Tue Jun 5 08:50:53 2007 |
|
28 |
** |
|
29 |
** @brief |
|
30 |
** |
|
31 |
** |
|
32 |
*/ |
|
0 | 33 |
#include "nmtSlave.h" |
34 |
#include "states.h" |
|
150
d2fc5d5f8a36
Some win32 fixes following yesterday's API changes.
etisserant
parents:
149
diff
changeset
|
35 |
#include "canfestival.h" |
370
6fecf36df407
Fixed some endianization problems caused by switch to UNS16 for cob_id member in CAN messages. To be continued.
etisserant
parents:
365
diff
changeset
|
36 |
#include "sysdep.h" |
0 | 37 |
|
208 | 38 |
/*! |
39 |
** put the slave in the state wanted by the master |
|
40 |
** |
|
41 |
** @param d |
|
42 |
** @param m |
|
43 |
**/ |
|
0 | 44 |
void proceedNMTstateChange(CO_Data* d, Message *m) |
45 |
{ |
|
46 |
if( d->nodeState == Pre_operational || |
|
47 |
d->nodeState == Operational || |
|
48 |
d->nodeState == Stopped ) { |
|
208 | 49 |
|
0 | 50 |
MSG_WAR(0x3400, "NMT received. for node : ", (*m).data[1]); |
208 | 51 |
|
215 | 52 |
/* Check if this NMT-message is for this node */ |
53 |
/* byte 1 = 0 : all the nodes are concerned (broadcast) */ |
|
208 | 54 |
|
0 | 55 |
if( ( (*m).data[1] == 0 ) || ( (*m).data[1] == *d->bDeviceNodeId ) ){ |
208 | 56 |
|
215 | 57 |
switch( (*m).data[0]){ /* command specifier (cs) */ |
0 | 58 |
case NMT_Start_Node: |
59 |
if ( (d->nodeState == Pre_operational) || (d->nodeState == Stopped) ) |
|
60 |
setState(d,Operational); |
|
208 | 61 |
break; |
62 |
||
0 | 63 |
case NMT_Stop_Node: |
64 |
if ( d->nodeState == Pre_operational || |
|
208 | 65 |
d->nodeState == Operational ) |
0 | 66 |
setState(d,Stopped); |
67 |
break; |
|
208 | 68 |
|
0 | 69 |
case NMT_Enter_PreOperational: |
208 | 70 |
if ( d->nodeState == Operational || |
71 |
d->nodeState == Stopped ) |
|
72 |
setState(d,Pre_operational); |
|
0 | 73 |
break; |
208 | 74 |
|
0 | 75 |
case NMT_Reset_Node: |
381 | 76 |
#ifdef CO_ENABLE_LSS |
77 |
if(getNodeId(d)!=d->lss_transfer.nodeID) |
|
78 |
setNodeId(d, d->lss_transfer.nodeID); |
|
79 |
#endif |
|
208 | 80 |
setState(d,Initialisation); |
0 | 81 |
break; |
208 | 82 |
|
0 | 83 |
case NMT_Reset_Comunication: |
381 | 84 |
#ifdef CO_ENABLE_LSS |
85 |
if(getNodeId(d)!=d->lss_transfer.nodeID && getNodeId(d)>0 && getNodeId(d)<=127) |
|
86 |
setNodeId(d, d->lss_transfer.nodeID); |
|
87 |
#endif |
|
208 | 88 |
setState(d,Initialisation); |
0 | 89 |
break; |
208 | 90 |
|
215 | 91 |
}/* end switch */ |
208 | 92 |
|
215 | 93 |
}/* end if( ( (*m).data[1] == 0 ) || ( (*m).data[1] == |
208 | 94 |
bDeviceNodeId ) ) */ |
0 | 95 |
} |
96 |
} |
|
97 |
||
98 |
||
208 | 99 |
/*! |
100 |
** |
|
101 |
** |
|
102 |
** @param d |
|
103 |
** |
|
104 |
** @return |
|
105 |
**/ |
|
0 | 106 |
UNS8 slaveSendBootUp(CO_Data* d) |
107 |
{ |
|
108 |
Message m; |
|
208 | 109 |
|
343 | 110 |
#ifdef CO_ENABLE_LSS |
111 |
if(*d->bDeviceNodeId==0xFF)return 0; |
|
112 |
#endif |
|
113 |
||
0 | 114 |
MSG_WAR(0x3407, "Send a Boot-Up msg ", 0); |
208 | 115 |
|
215 | 116 |
/* message configuration */ |
370
6fecf36df407
Fixed some endianization problems caused by switch to UNS16 for cob_id member in CAN messages. To be continued.
etisserant
parents:
365
diff
changeset
|
117 |
{ |
6fecf36df407
Fixed some endianization problems caused by switch to UNS16 for cob_id member in CAN messages. To be continued.
etisserant
parents:
365
diff
changeset
|
118 |
UNS16 tmp = NODE_GUARD << 7 | *d->bDeviceNodeId; |
6fecf36df407
Fixed some endianization problems caused by switch to UNS16 for cob_id member in CAN messages. To be continued.
etisserant
parents:
365
diff
changeset
|
119 |
m.cob_id = UNS16_LE(tmp); |
6fecf36df407
Fixed some endianization problems caused by switch to UNS16 for cob_id member in CAN messages. To be continued.
etisserant
parents:
365
diff
changeset
|
120 |
} |
0 | 121 |
m.rtr = NOT_A_REQUEST; |
122 |
m.len = 1; |
|
123 |
m.data[0] = 0x00; |
|
208 | 124 |
|
149 | 125 |
return canSend(d->canHandle,&m); |
0 | 126 |
} |
127 |