On Tue 22 May 23:05 PDT 2018, Vinod wrote: > On 22-05-18, 22:20, Bjorn Andersson wrote: > > > +static int q6v5_wcss_reset(struct q6v5_wcss *wcss) > > +{ > > + int ret; > > + u32 val; > > + int i; > > + > > + /* Assert resets, stop core */ > > + val = readl(wcss->reg_base + QDSP6SS_RESET_REG); > > + val |= Q6SS_CORE_ARES | Q6SS_BUS_ARES_ENABLE | Q6SS_STOP_CORE; > > + writel(val, wcss->reg_base + QDSP6SS_RESET_REG); > > + > > + /* BHS require xo cbcr to be enabled */ > > + val = readl(wcss->reg_base + QDSP6SS_XO_CBCR); > > + val |= 0x1; > > + writel(val, wcss->reg_base + QDSP6SS_XO_CBCR); > > As commented on previous patch, it would help IMO to add a modify() wrapper > here which would perform read, modify and write. > Iirc the code ended up like this because a lot of these operations ended up being line wrapped and harder to read using some modify(reg, mask, val) helper. That said, the function isn't very pretty in it's current state either... One of the parts of the RFC is that this sequence is a verbatim copy from the qcom_q6v5_pil.c driver for 8996, so if we find this duplication suitable I would prefer that we keep them the same. The alternative to duplicating this function is as Sricharan proposed to have the qcom_q6v5_pil.c be both a driver for both the single-stage remoteproc and the two-stage (load boot loader, then modem firmware). > Looking at the patch, few other comments would be applicable too, so would be > great if you/Sricharan can update this > I agree, the primary purpose of this patch was rather to get feedback on the structure of the drivers, I do expect this to take another round through the editor to get some polishing touches. Sorry if this wasn't clear from the description. Regards, Bjorn -- To unsubscribe from this list: send the line "unsubscribe linux-remoteproc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html