lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <b13fd9f0-6f65-404b-9625-e431ee45ed17@linux.alibaba.com>
Date: Mon, 30 Jun 2025 20:45:33 +0800
From: Wen Gu <guwen@...ux.alibaba.com>
To: Andrew Lunn <andrew@...n.ch>
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



On 2025/6/27 15:57, Andrew Lunn wrote:
>> +#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.
> 

Agree. This was for compatibility with older kernels, I should
change it to new helpers.. Will fix in next version. Thanks!

>> +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.
> 

Yes, If the cloud device thinks the written value is not what it
expected, the write will fail. I will add a comment about that, thanks.

>> +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?

The clock can't work as expected if these events happened.

The gettime operation will get an invalid timestamp whose
PTP_CIPU_M_TS_ABN bit is set and return -EIO.

> 
>> +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?
> 

See reply to Vadim :)

>> +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.

These are considered attributes of the CIPU ptp device, so I perfer
to put them in sysfs.

But I found sysfs prefers only one value per file [1]. The format
here may need to be improved.

[1] https://docs.kernel.org/filesystems/sysfs.html

Thank you for these comments!

Wen Gu

> 
> 	Andrew


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ