@@ -1598,13 +1598,15 @@ static void acm_process_timeouts(void)
DLIST_ENTRY *entry;
struct acm_send_msg *msg;
struct acm_resolve_rec *rec;
+ struct acm_mad *mad;
while (!DListEmpty(&timeout_list)) {
entry = timeout_list.Next;
DListRemove(entry);
msg = container_of(entry, struct acm_send_msg, entry);
- rec = (struct acm_resolve_rec *) ((struct acm_mad *) msg->data)->data;
+ mad = (struct acm_mad *) &msg->data[0];
+ rec = (struct acm_resolve_rec *) mad->data;
acm_format_name(0, log_data, sizeof log_data,
rec->dest_type, rec->dest, sizeof rec->dest);
@@ -2647,7 +2649,7 @@ static int acm_parse_osm_fullv1_paths(FILE *f, uint64_t *lid2guid, struct acm_ep
char s[128];
char *p, *ptr, *p_guid, *p_lid;
uint64_t guid;
- uint16_t lid, dlid;
+ uint16_t lid, dlid, net_dlid;
int sl, mtu, rate;
int ret = 1, i;
uint8_t addr[ACM_MAX_ADDRESS];
@@ -2710,6 +2712,7 @@ static int acm_parse_osm_fullv1_paths(FILE *f, uint64_t *lid2guid, struct acm_ep
break;
dlid = strtoul(p, NULL, 0);
+ net_dlid = htons(dlid);
p = strtok_r(NULL, ":", &ptr);
if (!p)
@@ -2740,7 +2743,7 @@ static int acm_parse_osm_fullv1_paths(FILE *f, uint64_t *lid2guid, struct acm_ep
memset(addr, 0, ACM_MAX_ADDRESS);
if (i == 0) {
addr_type = ACM_ADDRESS_LID;
- *((uint16_t *) addr) = htons(dlid);
+ memcpy(addr, &net_dlid, sizeof net_dlid);
} else {
addr_type = ACM_ADDRESS_GID;
memcpy(addr, &dgid, sizeof(dgid));
@@ -2754,7 +2757,7 @@ static int acm_parse_osm_fullv1_paths(FILE *f, uint64_t *lid2guid, struct acm_ep
dest->path.sgid = sgid;
dest->path.slid = htons(ep->port->lid);
dest->path.dgid = dgid;
- dest->path.dlid = htons(dlid);
+ dest->path.dlid = net_dlid;
dest->path.reversible_numpath = IBV_PATH_RECORD_REVERSIBLE;
dest->path.pkey = htons(ep->pkey);
dest->path.mtu = (uint8_t) mtu;