u8 *lunaddrbytes, int *bus, int *target, int *lun,
        struct hpsa_scsi_dev_t *device)
 {
-
        u32 lunid;
 
        if (is_logical_dev_addr_mode(lunaddrbytes)) {
                /* logical device */
-               memcpy(&lunid, lunaddrbytes, sizeof(lunid));
-               lunid = le32_to_cpu(lunid);
-
+               lunid = le32_to_cpu(*((__le32 *) lunaddrbytes));
                if (is_msa2xxx(h, device)) {
                        *bus = 1;
                        *target = (lunid >> 16) & 0x3fff;
                dev_err(&h->pdev->dev, "report physical LUNs failed.\n");
                return -1;
        }
-       memcpy(nphysicals, &physdev->LUNListLength[0], sizeof(*nphysicals));
-       *nphysicals = be32_to_cpu(*nphysicals) / 8;
+       *nphysicals = be32_to_cpu(*((__be32 *)physdev->LUNListLength)) / 8;
        if (*nphysicals > HPSA_MAX_PHYS_LUN) {
                dev_warn(&h->pdev->dev, "maximum physical LUNs (%d) exceeded."
                        "  %d LUNs ignored.\n", HPSA_MAX_PHYS_LUN,
                dev_err(&h->pdev->dev, "report logical LUNs failed.\n");
                return -1;
        }
-       memcpy(nlogicals, &logdev->LUNListLength[0], sizeof(*nlogicals));
-       *nlogicals = be32_to_cpu(*nlogicals) / 8;
+       *nlogicals = be32_to_cpu(*((__be32 *) logdev->LUNListLength)) / 8;
        /* Reject Logicals in excess of our max capability. */
        if (*nlogicals > HPSA_MAX_LUN) {
                dev_warn(&h->pdev->dev,