Statistics
| Branch: | Tag: | Revision:

amiro-os / components / ControllerAreaNetworkRx.cpp @ bc91a128

History | View | Annotate | Download (6.372 KB)

1 58fe0e0b Thomas Schöpping
#include <ch.hpp>
2
#include <hal.h>
3
#include <string.h>  // memcpy
4
5
#include <amiro/Constants.h>
6
#include <amiro/ControllerAreaNetworkRx.h>
7
8
using namespace chibios_rt;
9
using namespace amiro;
10
11
using namespace types;
12
using namespace amiro::constants;
13
14
ControllerAreaNetworkRx::ControllerAreaNetworkRx(CANDriver *can, const uint8_t boardId)
15
    : BaseStaticThread<128>(),
16
      boardId(boardId),
17
      canDriver(can) {
18
#ifdef STM32F4XX
19
  this->canConfig.mcr = CAN_MCR_ABOM | CAN_MCR_AWUM | CAN_MCR_TXFP;
20
  this->canConfig.btr = CAN_BTR_SJW(1) | CAN_BTR_TS2(3) | CAN_BTR_TS1(15)
21
                        | CAN_BTR_BRP(1);
22
#else
23
  this->canConfig.mcr = CAN_MCR_ABOM | CAN_MCR_AWUM | CAN_MCR_TXFP;
24
  this->canConfig.btr = CAN_BTR_SJW(1) | CAN_BTR_TS2(2) | CAN_BTR_TS1(13)
25
                        | CAN_BTR_BRP(1);
26
#endif
27
}
28
29
ControllerAreaNetworkRx::
30
~ControllerAreaNetworkRx() {
31
32
}
33
34
//----------------------------------------------------------------
35
36
msg_t ControllerAreaNetworkRx::receiveSensorVal(CANRxFrame *frame) {
37
  int deviceId = this->decodeDeviceId(frame);
38
39
  // chprintf((BaseSequentialStream*) &SD1, "DeviceId: %d\r\n",deviceId);
40
41
  switch (deviceId) {
42
    case CAN::PROXIMITY_RING_ID(0):
43
    case CAN::PROXIMITY_RING_ID(1):
44
    case CAN::PROXIMITY_RING_ID(2):
45
    case CAN::PROXIMITY_RING_ID(3):
46
    case CAN::PROXIMITY_RING_ID(4):
47
    case CAN::PROXIMITY_RING_ID(5):
48
    case CAN::PROXIMITY_RING_ID(6):
49
    case CAN::PROXIMITY_RING_ID(7):
50
      if (frame->DLC == 2) {
51
        int index = deviceId & 0x7;
52
        proximityRingValue[index] = frame->data16[0];
53
        return RDY_OK;
54
      }
55
      break;
56
57
    case CAN::ACTUAL_SPEED_ID:
58
      if (frame->DLC == 8) {
59
        actualSpeed[0] = frame->data32[0];
60
        actualSpeed[1] = frame->data32[1];
61
        return RDY_OK;
62
      }
63
      break;
64
65
    case CAN::ODOMETRY_ID:
66
      if (frame->DLC == 8) {
67
        this->robotPosition.x = (frame->data8[0] << 8 | frame->data8[1] << 16 | frame->data8[2] << 24);
68
        this->robotPosition.y = (frame->data8[3] << 8 | frame->data8[4] << 16 | frame->data8[5] << 24);
69
        this->robotPosition.f_z = (frame->data8[6] << 8 | frame->data8[7] << 16);
70
        return RDY_OK;
71
      }
72
      break;
73
74
    case CAN::PROXIMITY_FLOOR_ID:
75
      // chprintf((BaseSequentialStream*) &SD1, "CAN::PROXIMITY_FLOOR_ID");
76
      if (frame->DLC == 8) {
77
        proximityFloorValue[0] = frame->data16[0];
78
        proximityFloorValue[1] = frame->data16[1];
79
        proximityFloorValue[2] = frame->data16[2];
80
        proximityFloorValue[3] = frame->data16[3];
81
        return RDY_OK;
82
      }
83
      break;
84
85
    case CAN::POWER_STATUS_ID:
86
      if (frame->DLC == 6) {
87
        powerStatus.charging_flags.value = frame->data8[0];
88
        powerStatus.state_of_charge = frame->data8[1];
89
        powerStatus.minutes_remaining = frame->data16[1];
90
        powerStatus.power_consumption = frame->data16[2];
91
        return RDY_OK;
92
      }
93
      break;
94
95
    case CAN::ROBOT_ID:
96
      if (frame->DLC == 1) {
97
        robotId = frame->data8[0];
98
        return RDY_OK;
99
      }
100
      break;
101
102 b4885314 Thomas Schöpping
    case CAN::MAGNETOMETER_X_ID:
103
      if (frame->DLC == 4) {
104
        magnetometerValue[0] = frame->data32[0];
105
        return RDY_OK;
106
      }
107
      break;
108
109
    case CAN::MAGNETOMETER_Y_ID:
110
      if (frame->DLC == 4) {
111
        magnetometerValue[1] = frame->data32[0];
112
        return RDY_OK;
113
      }
114
      break;
115
116
    case CAN::MAGNETOMETER_Z_ID:
117
      if (frame->DLC == 4) {
118
        magnetometerValue[2] = frame->data32[0];
119
        return RDY_OK;
120
      }
121
      break;
122
123
    case CAN::GYROSCOPE_ID:
124
      if (frame->DLC == 6) {
125
        gyroscopeValue[0] = frame->data16[0];
126
        gyroscopeValue[1] = frame->data16[1];
127
        gyroscopeValue[2] = frame->data16[2];
128
        return RDY_OK;
129
      }
130
      break;
131
132 58fe0e0b Thomas Schöpping
    default:
133
      break;
134
  }
135
136
  return RDY_RESET;
137
}
138
139
uint16_t ControllerAreaNetworkRx::getProximityRingValue(int index) {
140
  return this->proximityRingValue[index];
141
}
142
143
void ControllerAreaNetworkRx::getActualSpeed(types::kinematic &targetSpeed) {
144
  targetSpeed.x = this->actualSpeed[0];
145
  targetSpeed.w_z = this->actualSpeed[1];
146
}
147
148
types::position ControllerAreaNetworkRx::getOdometry() {
149
  return this->robotPosition;
150
}
151
152
power_status &ControllerAreaNetworkRx::getPowerStatus() {
153
  return this->powerStatus;
154
}
155
156
uint8_t ControllerAreaNetworkRx::getRobotID() {
157
  return this->robotId;
158
}
159
160 b4885314 Thomas Schöpping
int32_t ControllerAreaNetworkRx::getMagnetometerValue(int axis)
161
{
162
  return this->magnetometerValue[axis];
163
}
164
165
int16_t ControllerAreaNetworkRx::getGyroscopeValue(int axis)
166
{
167
  return this->gyroscopeValue[axis];
168
}
169
170 58fe0e0b Thomas Schöpping
171
uint16_t ControllerAreaNetworkRx::getProximityFloorValue(int index) {
172
  return this->proximityFloorValue[index];
173
}
174
175
//----------------------------------------------------------------
176
177
msg_t ControllerAreaNetworkRx::main(void) {
178
179
  this->rxFullCanEvtSource = reinterpret_cast<EvtSource *>(&this->canDriver->rxfull_event);
180
181
  this->rxFullCanEvtSource->registerOne(&this->rxFullCanEvtListener, CAN::RECEIVED_ID);
182
183
  canStart(this->canDriver, &this->canConfig);
184
185
  this->setName("ControllerAreaNetworkRx");
186
187
  while (!this->shouldTerminate()) {
188
    eventmask_t eventMask = this->waitOneEventTimeout(ALL_EVENTS, MS2ST(10000));
189
    switch (eventMask) {
190
191
      case EVENT_MASK(CAN::RECEIVED_ID):
192
        CANRxFrame rxframe;
193
        msg_t message = canReceive(this->canDriver, CAN_ANY_MAILBOX, &rxframe, TIME_IMMEDIATE);
194
        if (message == RDY_OK) {
195
          // chprintf((BaseSequentialStream*) &SD1, "Rx Message");
196
          message = this->receiveMessage(&rxframe);
197
          if (message != RDY_OK)
198
            this->receiveSensorVal(&rxframe);
199
        }
200
        break;
201
    }
202
  }
203
204
  canStop(this->canDriver);
205
  this->rxFullCanEvtSource->unregister(&this->rxFullCanEvtListener);
206
207
  return RDY_OK;
208
}
209
210
msg_t ControllerAreaNetworkRx::receiveMessage(CANRxFrame *frame) {
211
  (void)frame;
212
  return RDY_OK;
213
}
214
215
//----------------------------------------------------------------
216
217
int ControllerAreaNetworkRx::decodeBoardId(CANRxFrame *frame) {
218
  return (frame->SID >> CAN::BOARD_ID_SHIFT) & CAN::BOARD_ID_MASK;
219
}
220
221
int ControllerAreaNetworkRx::decodeDeviceId(CANRxFrame *frame) {
222
  return (frame->SID >> CAN::DEVICE_ID_SHIFT) & CAN::DEVICE_ID_MASK;
223
}
224
225
int ControllerAreaNetworkRx::decodeIndexId(CANRxFrame *frame) {
226
  return (frame->SID >> CAN::INDEX_ID_SHIFT) & CAN::INDEX_ID_MASK;
227
}
228
229
//----------------------------------------------------------------
230
231
int ControllerAreaNetworkRx::rxCmdShell(CANRxFrame *frame) {
232
  return (frame->SID >> CAN::BOARD_ID_SHIFT) & CAN::BOARD_ID_MASK;
233
}