memcpy(&tx_header->eth803_hdr, skb_src->data, dt_offset);
 
        /* Copy SNAP header */
-       snap.snap_type = *(u16 *) ((u8 *)skb_src->data + dt_offset);
+       snap.snap_type = le16_to_cpu(*(__le16 *) ((u8 *)skb_src->data + dt_offset));
        dt_offset += sizeof(u16);
 
        memcpy(&tx_header->rfc1042_hdr, &snap, sizeof(struct rfc_1042_hdr));
 
  */
 static inline bool mwifiex_is_skb_mgmt_frame(struct sk_buff *skb)
 {
-       return (*(u32 *)skb->data == PKT_TYPE_MGMT);
+       return (le32_to_cpu(*(__le32 *)skb->data) == PKT_TYPE_MGMT);
 }
 
 /* This function retrieves channel closed for operation by Channel
 
 
        case MWIFIEX_TYPE_EVENT:
                dev_dbg(adapter->dev, "info: --- Rx: Event ---\n");
-               adapter->event_cause = *(u32 *) skb->data;
+               adapter->event_cause = le32_to_cpu(*(__le32 *) skb->data);
 
                if ((skb->len > 0) && (skb->len  < MAX_EVENT_SIZE))
                        memcpy(adapter->event_body,
                for (pind = 0; pind < card->mpa_rx.pkt_cnt; pind++) {
 
                        /* get curr PKT len & type */
-                       pkt_len = *(u16 *) &curr_ptr[0];
-                       pkt_type = *(u16 *) &curr_ptr[2];
+                       pkt_len = le16_to_cpu(*(__le16 *) &curr_ptr[0]);
+                       pkt_type = le16_to_cpu(*(__le16 *) &curr_ptr[2]);
 
                        /* copy pkt to deaggr buf */
                        skb_deaggr = card->mpa_rx.skb_arr[pind];
 
 
        tlv_buf = ((u8 *)rate_cfg) +
                        sizeof(struct host_cmd_ds_tx_rate_cfg);
-       tlv_buf_len = *(u16 *) (tlv_buf + sizeof(u16));
+       tlv_buf_len = le16_to_cpu(*(__le16 *) (tlv_buf + sizeof(u16)));
 
        while (tlv_buf && tlv_buf_len > 0) {
                tlv = (*tlv_buf);