[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <d032c064b5324641b19b3c0b31dcd2e2@ti.com>
Date: Wed, 3 Sep 2025 22:06:50 +0000
From: "Ding, Shenghao" <shenghao-ding@...com>
To: Takashi Iwai <tiwai@...e.de>
CC: "broonie@...nel.org" <broonie@...nel.org>,
"andriy.shevchenko@...ux.intel.com" <andriy.shevchenko@...ux.intel.com>,
"13564923607@....com" <13564923607@....com>,
"13916275206@....com"
<13916275206@....com>,
"alsa-devel@...a-project.org"
<alsa-devel@...a-project.org>,
"linux-kernel@...r.kernel.org"
<linux-kernel@...r.kernel.org>,
"Xu, Baojun" <baojun.xu@...com>,
"Baojun.Xu@....com" <Baojun.Xu@....com>
Subject: RE: [EXTERNAL] Re: [PATCH v2] ALSA: hda/tas2781: Fix the order of
TAS2781 calibrated-data
Thanks for your ref code
> > +/*
> > + * The order of calibrated-data writing is a bit different from the
> > +order
> > + * in UEFI. Here is the conversion to match the order of
> > +calibrated-data
> > + * writing.
> > + */
> > +static void cali_cnv(unsigned char *data, unsigned int base, int
> > +offset) {
> > + __be32 bedata[TASDEV_CALIB_N];
> > + int i;
> > +
> > + /* r0_reg */
> > + bedata[0] = cpu_to_be32(*(uint32_t *)&data[base]);
> > + /* r0_low_reg */
> > + bedata[1] = cpu_to_be32(*(uint32_t *)&data[base + 8]);
> > + /* invr0_reg */
> > + bedata[2] = cpu_to_be32(*(uint32_t *)&data[base + 4]);
> > + /* pow_reg */
> > + bedata[3] = cpu_to_be32(*(uint32_t *)&data[base + 12]);
> > + /* tlimit_reg */
> > + bedata[4] = cpu_to_be32(*(uint32_t *)&data[base + 16]);
> > +
> > + for (i = 0; i < TASDEV_CALIB_N; i++)
> > + memcpy(&data[offset + i * 4 + 1], &bedata[i],
> > + sizeof(bedata[i]));
> > +}
>
> IMO, this can be more readable when you use struct calidata, e.g.
>
> static void cali_cnv(unsigned char *data, unsigned int base, int offset) {
> struct calidata reg;
>
> reg.r0_reg = *(u32 *)&data[base]
> reg.r0_low_reg = *(u32 *)&data[base + 8]
> reg.invr0_reg = *(u32 *)&data[base + 4]
> reg.pow_reg = *(u32 *)&data[base + 12];
> reg.tlimit_reg = *(u32 *)&data[base + 16]);
>
> cpu_to_be32_array((__force __be32 *)(data + offset + 1), ®,
> TASDEV_CALIB_N);
> }
>
> ... or even simpler like:
>
> static void cali_cnv(unsigned char *data, unsigned int base, int offset) {
> struct calidata reg;
>
> memcpy(®, data, sizeof(reg));
> /* the data order has to be swapped between r0_low_reg and inv0_reg
> */
> swap(reg.r0_low_reg, reg.invr0_reg);
>
> cpu_to_be32_array((__force __be32 *)(data + offset + 1), ®,
> TASDEV_CALIB_N);
> }
I like this code so much. It's elegant simplicity.
Thanks,
Shenghao Ding
Powered by blists - more mailing lists