"-> template size %x bytes\n", dlen);
        if (dlen > risc_size * sizeof(*dcode)) {
                ql_log(ql_log_warn, vha, 0x0167,
-                   "Failed fwdump template exceeds array by %x bytes\n",
-                   (uint32_t)(dlen - risc_size * sizeof(*dcode)));
+                   "Failed fwdump template exceeds array by %lx bytes\n",
+                   (size_t)(dlen - risc_size * sizeof(*dcode)));
                goto default_template;
        }
        ha->fw_dump_template_len = dlen;
            "-> template size %x bytes\n", dlen);
        if (dlen > risc_size * sizeof(*fwcode)) {
                ql_log(ql_log_warn, vha, 0x0177,
-                   "Failed fwdump template exceeds array by %x bytes\n",
-                   (uint32_t)(dlen - risc_size * sizeof(*fwcode)));
+                   "Failed fwdump template exceeds array by %lx bytes\n",
+                   (size_t)(dlen - risc_size * sizeof(*fwcode)));
                goto default_template;
        }
        ha->fw_dump_template_len = dlen;
 
 {
        if (buf)
                ent->hdr.driver_flags |= DRIVER_FLAG_SKIP_ENTRY;
-       ql_dbg(ql_dbg_misc + ql_dbg_verbose, NULL, 0xd011,
-           "Skipping entry %d\n", ent->hdr.entry_type);
 }
 
 static int
        ql_dbg(ql_dbg_misc, vha, 0xd01a,
            "%s: entry count %lx\n", __func__, count);
        while (count--) {
+               if (buf && *len >= vha->hw->fw_dump_len)
+                       break;
                if (qla27xx_find_entry(ent->hdr.entry_type)(vha, ent, buf, len))
                        break;
                ent = qla27xx_next_entry(ent);
 
        if (count)
                ql_dbg(ql_dbg_misc, vha, 0xd018,
-                   "%s: residual count (%lx)\n", __func__, count);
+                   "%s: entry residual count (%lx)\n", __func__, count);
 
        if (ent->hdr.entry_type != ENTRY_TYPE_TMP_END)
                ql_dbg(ql_dbg_misc, vha, 0xd019,
-                   "%s: missing end (%lx)\n", __func__, count);
+                   "%s: missing end entry (%lx)\n", __func__, count);
 
-       ql_dbg(ql_dbg_misc, vha, 0xd01b,
-           "%s: len=%lx\n", __func__, *len);
+       if (buf && *len != vha->hw->fw_dump_len)
+               ql_dbg(ql_dbg_misc, vha, 0xd01b,
+                   "%s: length=%#lx residual=%+ld\n",
+                   __func__, *len, vha->hw->fw_dump_len - *len);
 
        if (buf) {
                ql_log(ql_log_warn, vha, 0xd015,
-                   "Firmware dump saved to temp buffer (%ld/%p)\n",
+                   "Firmware dump saved to temp buffer (%lu/%p)\n",
                    vha->host_no, vha->hw->fw_dump);
                qla2x00_post_uevent_work(vha, QLA_UEVENT_CODE_FW_DUMP);
        }