On Thu, Nov 1, 2018 at 5:02 PM Jagan Teki <jagan@xxxxxxxxxxxxxxxxxxxx> wrote: > > On Thu, Nov 1, 2018 at 1:23 PM Chen-Yu Tsai <wens@xxxxxxxx> wrote: > > > > On Thu, Nov 1, 2018 at 3:33 PM Jagan Teki <jagan@xxxxxxxxxxxxxxxxxxxx> wrote: > > > > > > On Thu, Nov 1, 2018 at 8:25 AM Chen-Yu Tsai <wens@xxxxxxxx> wrote: > > > > > > > > On Thu, Nov 1, 2018 at 2:37 AM Jagan Teki <jagan@xxxxxxxxxxxxxxxxxxxx> wrote: > > > > > > > > > > From: Jagan Teki <jagan@xxxxxxxxxxxx> > > > > > > > > > > RTC controller is similar to A31, so use the same compatible > > > > > for H6 and update interrupt numbers as per manual. > > > > > > > > No. Unfortunately they are not that compatible. The A31 does not have > > > > the RTC clock output. So everyone got it wrong. :( Plus the clock rate > > > > of the internal RC oscillator varies between SoCs. I'm working on a > > > > series of patches to correct this. Stay tuned. > > > > > > 4 bit, EXT_LOSC_EN of LOSC_CTRL_REG (0x00) seem available in H6. I can > > > see external clock working with WIFI for A31 compatible. > > > > That bit turns on the external crystal, i.e. X32KIN and X32KOUT pins. > > This is what I confused, the same signal pins available there in A64 > schematics but no bit to enable external OSC in LOSC_CTRL_REG. > > But the X32KFOUT pin which is 0x60 , BIT(0) is enabled in A64, H6 w/o > this LOSC_CTRL_REG which I don't know exactly or may be feed it by > default not sure. > > > > > I'm talking about the X32KFOUT pin, which feeds the WiFi module the > > LPO clock in typical Allwinner designs. That is controlled by register > > 0x60, and is not present on the A31. That is the clock you say is > > working. You have the two confused. > > > > The clock tree looks like this: > > > > IOSC -----------------------------\ > > SUN6I_LOSC_CTRL_EXT_OSC mux ----> > > LOSC --> (to CCU) > > 32k crystal --> EXT_LOSC_EN gate -/ \ > > \ > > / > > (to WiFi) <-- X32KFOUT pin <-- LOSC_OUT_GATING_EN gate <---/ > > Yes, I understand this. But for A33, A64 there is no EXT_LOSC_EN which > is directly feed to WIFI from LOSC as per manual but from schematic > signals X32KI and X32KO were present. No. Read the schematic again. CAREFULLY. The pin that feeds the WiFi module is called X32KFOUT. With an "F". The A33 datasheet says the pin is "Clock Output of LOSC (X32KFOUT can be gating)". The A64 datasheet may not mention the output can be gated, but the LOSC_OUT_GATING_REG register is aptly named "LOSC Output Gating Register". And see below about the EXT_LOSC_EN bit. You are confusing input to the RTC module vs output from the RTC module. All crystals have an IN and an OUT connection. It's just the way they work. > > The bottom part does not exist in the A31. Meanwhile we've been claiming that > > all later RTC modules that actually have that part are compatible with the A31. > > Also the IOSC part has different clock rates for different chips. > > > > Do you see the problem? > > From external crystal point of view, between A33, A64 vs H6 I only see > the difference in EXT_LOSC_EN external oscillator enable bit only > available in H6 manual. You are focusing on the wrong thing. From the driver's point of view, we simply don't care about this bit. It is by default on. We might want to force enable it if some broken bootloader turns it off, but that is besides the point here. And on all the other SoCs, the absence of this bit means that the external crystal will always be on. Furthermore, this bit concerns the "input" from the crystal to the RTC. What I'm concerned about, and what you should be concerned about, because that's what you're using, is the LOSC_OUT_GATING_EN bit. As mentioned this does not exist on the A31. > > Regarding, rtc-sun6i. we can manage the external clock stuff via > "clock-output-names" with rtc->ext_losc and mentioning external > oscillator outputs on DTSI. since A31, don't have external clock to > wifi then we can skip those properties. > > What do you think? That's not correct. On the A31, the RTC's LOSC still feeds the CCU, so output index 0 is always valid. Output index 1 on the A31 is invalid because it simply doesn't have this in the hardware. Furthermore, you're still not dealing with the fact that one A23/A33 the IOSC is 600~700 kHZ, on the A64/H3/H5/H6 it is 16 MHz, and on the V3/V3s it is 32 kHz. The first two cases also have prescalers to divide the clock rate down to around 32 kHz. All these hardware details need to be tied to new compatible strings, so that the driver knows about them and can handle them if needed. What you're describing is very fragile and pretty much a hack. We already have enough of those. ChenYu