[PATCH] nvme: Add support for NVMe 1.3 Timestamp Feature

Jon Derrick jonathan.derrick at intel.com
Tue Jul 18 14:13:10 PDT 2017


On 07/13/2017 01:35 AM, Christoph Hellwig wrote:
> On Wed, Jul 12, 2017 at 04:11:01PM -0600, Jon Derrick wrote:
>> NVME's Timestamp feature allows controllers to be aware of the epoch
>> time in milliseconds. This patch adds the set features hook for various
>> transports. It also wires it up to the pci reset path, so that resets
>> and resumes can update the controller as necessary.
> 
> Please find a way to do this entirely from common code, currently you
> miss out on all the non-PCIe transports.
> 
>> +	u64 cur_ms;
>> +	u8 ts[8] = { 0, };
>> +	int status;
>> +	u32 result;
>> +
>> +	cur_ms = ktime_to_ms(ktime_get_real());
>> +	put_unaligned_le64(cur_ms, &ts[0]);
>> +
>> +	status = nvme_set_features(ctrl, NVME_FEAT_TIMESTAMP, 0, ts, 8,
> 
> I think this could simply be something like:
> 
> 	__le64 ts;
> 
> 	ts = cpu_to_le64(ktime_to_ms(ktime_get_real()));
> 	status = nvme_set_features(ctrl, NVME_FEAT_TIMESTAMP, 0, &ts,
> 			sizeof(ts),
> 
>> +			&result);
>> +	if (status < 0)
>> +		dev_warn_once(ctrl->device,
>> +			"could not set timestamp (%08x)\n", result);
>> +}
> 
> The Timestamp feature does not define a result, so you should just
> pass NULL for the result parameter.  And if you want to print something
> on error the status value is probably more useful.
> 
>> +	if (dev->ctrl.vs >= NVME_VS(1, 3, 0) &&
>> +	    dev->ctrl.oncs & NVME_CTRL_ONCS_TIMESTAMP)
>> +		nvme_set_timestamp(&dev->ctrl);
> 
> No need to check for the version - NVMe TPs also apply to all previous
> versions if they are backwards compatible, which this one is.
> 

Thanks for the tips



More information about the Linux-nvme mailing list