[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <0b0d3dad-3fe2-4b3a-a018-35a3603f8c10@lunn.ch>
Date: Fri, 27 Jun 2025 09:57:12 +0200
From: Andrew Lunn <andrew@...n.ch>
To: Wen Gu <guwen@...ux.alibaba.com>
Cc: richardcochran@...il.com, andrew+netdev@...n.ch, davem@...emloft.net,
edumazet@...gle.com, kuba@...nel.org, pabeni@...hat.com,
xuanzhuo@...ux.alibaba.com, dust.li@...ux.alibaba.com,
netdev@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH net-next v2] ptp: add Alibaba CIPU PTP clock driver
> +#define PTP_CIPU_LOG_SUB(dev, level, type, event, fmt, ...) \
> +({ \
> + static DEFINE_RATELIMIT_STATE(_rs, \
> + DEFAULT_RATELIMIT_INTERVAL, \
> + DEFAULT_RATELIMIT_BURST); \
> + if (__ratelimit(&_rs)) \
> + dev_printk(level, dev, "[%02x:%02x]: " fmt, \
> + type, event, ##__VA_ARGS__); \
> +})
Please don't use such wrappers. Just use dev_dbg_ratelimited() etc.
> +static int cipu_iowrite8_and_check(void __iomem *addr,
> + u8 value, u8 *res)
> +{
> + iowrite8(value, addr);
> + if (value != ioread8(addr))
> + return -EIO;
> + *res = value;
> + return 0;
> +}
This probably needs a comment. I assume the hardware is broken and
sometimes writes don't work? You should state that.
> +static void ptp_cipu_print_dev_events(struct ptp_cipu_ctx *ptp_ctx,
> + int event)
> +{
> + struct device *dev = &ptp_ctx->pdev->dev;
> + int type = PTP_CIPU_EVT_TYPE_DEV;
> +
> + switch (event) {
> + case PTP_CIPU_EVT_H_CLK_ABN:
> + PTP_CIPU_LOG_SUB(dev, KERN_ERR, type, event,
> + "Atomic Clock Error Detected\n");
> + break;
> + case PTP_CIPU_EVT_H_CLK_ABN_REC:
> + PTP_CIPU_LOG_SUB(dev, KERN_INFO, type, event,
> + "Atomic Clock Error Recovered\n");
> + break;
> + case PTP_CIPU_EVT_H_DEV_MT:
> + PTP_CIPU_LOG_SUB(dev, KERN_ERR, type, event,
> + "Maintenance Exception Detected\n");
> + break;
> + case PTP_CIPU_EVT_H_DEV_MT_REC:
> + PTP_CIPU_LOG_SUB(dev, KERN_INFO, type, event,
> + "Maintenance Exception Recovered\n");
> + break;
> + case PTP_CIPU_EVT_H_DEV_MT_TOUT:
> + PTP_CIPU_LOG_SUB(dev, KERN_INFO, type, event,
> + "Maintenance Exception Failed to Recover "
> + "within %d us\n", ptp_ctx->regs.mt_tout_us);
> + break;
> + case PTP_CIPU_EVT_H_DEV_BUSY:
> + PTP_CIPU_LOG_SUB(dev, KERN_ERR, type, event,
> + "PHC Busy Detected\n");
> + break;
> + case PTP_CIPU_EVT_H_DEV_BUSY_REC:
> + PTP_CIPU_LOG_SUB(dev, KERN_INFO, type, event,
> + "PHC Busy Recovered\n");
> + break;
> + case PTP_CIPU_EVT_H_DEV_ERR:
> + PTP_CIPU_LOG_SUB(dev, KERN_ERR, type, event,
> + "PHC Error Detected\n");
> + break;
> + case PTP_CIPU_EVT_H_DEV_ERR_REC:
> + PTP_CIPU_LOG_SUB(dev, KERN_INFO, type, event,
> + "PHC Error Recovered\n");
Are these fatal? Or can the device still be used after these errors
occur?
> +static int ptp_cipu_enable(struct ptp_clock_info *info,
> + struct ptp_clock_request *request, int on)
> +{
> + return -EOPNOTSUPP;
> +}
> +
> +static int ptp_cipu_settime(struct ptp_clock_info *p,
> + const struct timespec64 *ts)
> +{
> + return -EOPNOTSUPP;
> +}
> +
> +static int ptp_cipu_adjfine(struct ptp_clock_info *ptp, long scaled_ppm)
> +{
> + return -EOPNOTSUPP;
> +}
> +
> +static int ptp_cipu_adjtime(struct ptp_clock_info *ptp, s64 delta)
> +{
> + return -EOPNOTSUPP;
> +}
I've not looked at the core. Are these actually required? Or if they
are missing, does the core default to -EOPNOTSUPP?
> +static ssize_t register_snapshot_show(struct device *dev,
> + struct device_attribute *attr, char *buf)
> +{
> + struct ptp_cipu_ctx *ctx = pci_get_drvdata(to_pci_dev(dev));
> + struct ptp_cipu_regs *regs = &ctx->regs;
> +
> + return sysfs_emit(buf, "%s 0x%x %s 0x%x %s 0x%x %s 0x%x "
> + "%s 0x%x %s 0x%x %s 0x%x %s 0x%x %s 0x%x "
> + "%s 0x%x %s 0x%x %s 0x%x\n",
> + "device_features", regs->dev_feat,
> + "guest_features", regs->gst_feat,
> + "driver_version", regs->drv_ver,
> + "environment_version", regs->env_ver,
> + "device_status", regs->dev_stat,
> + "sync_status", regs->sync_stat,
> + "time_precision(ns)", regs->tm_prec_ns,
> + "epoch_base(years)", regs->epo_base_yr,
> + "leap_second(s)", regs->leap_sec,
> + "max_latency(ns)", regs->max_lat_ns,
> + "maintenance_timeout(us)", regs->mt_tout_us,
> + "offset_threshold(us)", regs->thresh_us);
> +}
Is this debug? Maybe it should be placed in debugfs, rather than
sysfs.
Andrew
Powered by blists - more mailing lists