};
 EXPORT_SYMBOL_NS_GPL(tasdev_fct_efi_guid, "SND_HDA_SCODEC_TAS2781");
 
+/*
+ * The order of calibrated-data writing function is a bit different from the
+ * order in UEFI. Here is the conversion to match the order of calibrated-data
+ * writing function.
+ */
+static void cali_cnv(unsigned char *data, unsigned int base, int offset)
+{
+       struct cali_reg reg_data;
+
+       memcpy(®_data, &data[base], sizeof(reg_data));
+       /* the data order has to be swapped between r0_low_reg and inv0_reg */
+       swap(reg_data.r0_low_reg, reg_data.invr0_reg);
+
+       cpu_to_be32_array((__force __be32 *)(data + offset + 1),
+               (u32 *)®_data, TASDEV_CALIB_N);
+}
+
 static void tas2781_apply_calib(struct tasdevice_priv *p)
 {
        struct calidata *cali_data = &p->cali_data;
 
                                data[l] = k;
                                oft++;
-                               for (i = 0; i < TASDEV_CALIB_N * 4; i++)
-                                       data[l + i + 1] = data[4 * oft + i];
+                               cali_cnv(data, 4 * oft, l);
                                k++;
                        }
                }
 
                for (j = p->ndev - 1; j >= 0; j--) {
                        l = j * (cali_data->cali_dat_sz_per_dev + 1);
-                       for (i = TASDEV_CALIB_N * 4; i > 0 ; i--)
-                               data[l + i] = data[p->index * 5 + i];
-                       data[l+i] = j;
+                       cali_cnv(data, cali_data->cali_dat_sz_per_dev * j, l);
+                       data[l] = j;
                }
        }