Thread (16 messages) 16 messages, 3 authors, 2026-01-19

Re: [PATCH v2 4/5] rtc: zynqmp: rework set_offset

From: Tomas Melin <hidden>
Date: 2026-01-15 07:24:44
Also in: linux-rtc, lkml

Hi,


On 14/01/2026 17:37, T, Harini wrote:
quoted
+++ b/drivers/rtc/rtc-zynqmp.c
@@ -208,13 +208,13 @@ static int xlnx_rtc_read_offset(struct device *dev,
long *offset)  static int xlnx_rtc_set_offset(struct device *dev, long offset)  {
        struct xlnx_rtc_dev *xrtcdev = dev_get_drvdata(dev);
-       unsigned long long rtc_ppb = RTC_PPB;
-       unsigned int tick_mult = do_div(rtc_ppb, xrtcdev->freq);
-       unsigned char fract_tick = 0;
+       int max_tick, tick_mult, fract_offset, fract_part;
        unsigned int calibval;
-       short int  max_tick;
-       int fract_offset;
+       int fract_data = 0;
+       int freq = xrtcdev->freq;
Please follow reverse XMAS tree style.
I can fix this with a follow up version.

Thanks,
Tomas


quoted
+       /* Tick to offset multiplier */
+       tick_mult = DIV_ROUND_CLOSEST(RTC_PPB, xrtcdev->freq);
        if (offset < RTC_MIN_OFFSET || offset > RTC_MAX_OFFSET)
                return -ERANGE;
@@ -223,29 +223,22 @@ static int xlnx_rtc_set_offset(struct device *dev,
long offset)

        /* Number fractional ticks for given offset */
        if (fract_offset) {
-               if (fract_offset < 0) {
-                       fract_offset = fract_offset + tick_mult;
+               fract_part = DIV_ROUND_UP(tick_mult, RTC_FR_MAX_TICKS);
+               fract_data = fract_offset / fract_part;
+               /* Subtract one from max_tick while adding fract_offset */
+               if (fract_offset < 0 && fract_data) {
                        max_tick--;
-               }
-               if (fract_offset > (tick_mult / RTC_FR_MAX_TICKS)) {
-                       for (fract_tick = 1; fract_tick < 16; fract_tick++) {
-                               if (fract_offset <=
-                                   (fract_tick *
-                                    (tick_mult / RTC_FR_MAX_TICKS)))
-                                       break;
-                       }
+                       fract_data += RTC_FR_MAX_TICKS;
                }
        }

        /* Zynqmp RTC uses second and fractional tick
         * counters for compensation
         */
-       calibval = max_tick + RTC_CALIB_DEF;
-
-       if (fract_tick)
-               calibval |= RTC_FR_EN;
+       calibval = max_tick + freq;

-       calibval |= (fract_tick << RTC_FR_DATSHIFT);
+       if (fract_data)
+               calibval |= (RTC_FR_EN | (fract_data <<
+ RTC_FR_DATSHIFT));

        writel(calibval, (xrtcdev->reg_base + RTC_CALIB_WR));


--
2.47.3
Thanks,
Harini T
  
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help