return 0;
 }
 
-static int hclge_ptp_adjfreq(struct ptp_clock_info *ptp, s32 ppb)
+static int hclge_ptp_adjfine(struct ptp_clock_info *ptp, long scaled_ppm)
 {
        struct hclge_dev *hdev = hclge_ptp_get_hdev(ptp);
        struct hclge_ptp_cycle *cycle = &hdev->ptp->cycle;
-       u64 adj_val, adj_base, diff;
+       u64 adj_val, adj_base;
        unsigned long flags;
-       bool is_neg = false;
        u32 quo, numerator;
 
-       if (ppb < 0) {
-               ppb = -ppb;
-               is_neg = true;
-       }
-
        adj_base = (u64)cycle->quo * (u64)cycle->den + (u64)cycle->numer;
-       adj_val = adj_base * ppb;
-       diff = div_u64(adj_val, 1000000000ULL);
-
-       if (is_neg)
-               adj_val = adj_base - diff;
-       else
-               adj_val = adj_base + diff;
+       adj_val = adjust_by_scaled_ppm(adj_base, scaled_ppm);
 
        /* This clock cycle is defined by three part: quotient, numerator
         * and denominator. For example, 2.5ns, the quotient is 2,
        ptp->info.max_adj = HCLGE_PTP_CYCLE_ADJ_MAX;
        ptp->info.n_ext_ts = 0;
        ptp->info.pps = 0;
-       ptp->info.adjfreq = hclge_ptp_adjfreq;
+       ptp->info.adjfine = hclge_ptp_adjfine;
        ptp->info.adjtime = hclge_ptp_adjtime;
        ptp->info.gettimex64 = hclge_ptp_gettimex;
        ptp->info.settime64 = hclge_ptp_settime;
                goto out;
 
        set_bit(HCLGE_PTP_FLAG_EN, &hdev->ptp->flags);
-       ret = hclge_ptp_adjfreq(&hdev->ptp->info, 0);
+       ret = hclge_ptp_adjfine(&hdev->ptp->info, 0);
        if (ret) {
                dev_err(&hdev->pdev->dev,
                        "failed to init freq, ret = %d\n", ret);