On 22-05-18, 23:58, Bjorn Andersson wrote: > 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... Agreed :) and i thought modify make help it make better > 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. Since Sricharan replied to comments, I though they would be fixed. Yeah this is fine from RFC.. -- ~Vinod -- 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