Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Staging/adf4030 support #2651

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open

Staging/adf4030 support #2651

wants to merge 3 commits into from

Conversation

mhennerich
Copy link
Contributor

PR Description

New Linux IIO driver for Analog Devices ADF4030 10-Channel Precision Synchronizer IC.

The ADF4030 provides for 10 bidirectional synchronized clock (BSYNC) channels and
accepts a reference clock input (REFIN) signal as a frequency reference for
generating an output clock on any BSYNC channels that are configured as an output.
The hallmark feature of the ADF4030 is the ability to time align the clock edges
of any one or more BSYNC channels to <5 ps (at the device pins) with respect to
the BSYNC channel selected as the reference BSYNC channel.

https://www.analog.com/en/products/adf4030.html

PR Type

  • New feature (a change that adds new functionality)

PR Checklist

  • I have conducted a self-review of my own code changes
  • I have tested the changes on the relevant hardware
  • I have updated the documentation outside this repo accordingly (if there is the case)


adi,extended-name:
description: Extended name for the channel.
$ref: /schemas/types.yaml#/definitions/string
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This one is questionable..

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Well it's handy, and avoids possible mix up.

properties:
reg:
description: Channel number.
$ref: /schemas/types.yaml#/definitions/uint32
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs some constrains. I guess some of the other properties also need it.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK


adi,rcm:
description: RCM value for the channel.
$ref: /schemas/types.yaml#/definitions/uint32
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A lot of these properties need a better description. Right now, the description is more or less the same what one can infer from the name.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You will always need the datasheet to properly set those and the naming follows the datasheet.
But I agree some more text doesn't harm. Will fix.

description: Number of iterations for auto alignment.

adi,bsync-autoalign-threshold-fs:
description: Threshold for auto alignment in femtoseconds.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I dunno the three above properties pass the binding check. They have no standard suffix and we're not defining a type for them.

Not sure why it does not fail in the check

drivers/iio/frequency/adf4030.c Show resolved Hide resolved
.shared = true,
.private = BSYNC_ALIGN_ITER,
},
{},
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The above four (at least) need an ABI doc. But I guess we can do it when upstreaming...

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ABI documentation sysfs-bus-iio-frequency-adf4030

Yeah - the wiki page already has a link for it ...
https://wiki.analog.com/resources/tools-software/linux-drivers/iio-synchronizer/adf4030

drivers/iio/frequency/adf4030.c Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
@mhennerich mhennerich force-pushed the staging/adf4030-support branch 2 times, most recently from 6e2a7c7 to ea7284a Compare December 5, 2024 11:51
Copy link
Collaborator

@nunojsa nunojsa left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks mostly good to me...

Is there any strong reason to merge this right now or can we wait till we upstream this driver?

drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Show resolved Hide resolved
st->clk_out_names,
ARRAY_SIZE(st->clk_out_names));
if (ret < 0)
return ret;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is still treating it as mandatory because we error out in case the property is not there. I guess we could do it in the same way as here:

https://elixir.bootlin.com/linux/v6.13-rc3/source/drivers/iio/frequency/adf4350.c#L467

drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Show resolved Hide resolved
drivers/iio/frequency/adf4030.c Outdated Show resolved Hide resolved
@mhennerich mhennerich force-pushed the staging/adf4030-support branch 2 times, most recently from fe0fb1f to 9b23d38 Compare January 13, 2025 12:51
Initial support...

Signed-off-by: Nuno Sa <nuno.sa@analog.com>
@mhennerich mhennerich force-pushed the staging/adf4030-support branch from 9b23d38 to b0db36f Compare January 13, 2025 13:10
@mhennerich
Copy link
Contributor Author

Pushed a new version which addresses the last review feedback

@mhennerich
Copy link
Contributor Author

Looks mostly good to me...

Is there any strong reason to merge this right now or can we wait till we upstream this driver?

Would be good to merge this now...

Copy link
Collaborator

@nunojsa nunojsa left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Minor comments that can be addressed later

/*
* Driver for ADF4030 10-Channel Precision Synchronizer IC.
*
* Copyright 2024 Analog Devices Inc.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: 2025 by now :)

}

static const struct spi_device_id adf4030_id[] = {
{"adf4030", 4030},
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

4030? It seems we should drop that

st->iio_channels[i].indexed = 1;
st->iio_channels[i].channel = chan->num;
st->iio_channels[i].address = i;
st->iio_channels[i].extend_name = chan->extended_name;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

extend_name should not be used in new devices. IIO will still make use of labels but that's only for backward compatibility. Can be fixed when upstreaming (though I still think that the devicetree property is questionable).

&st->channels[cnt].delay);

fwnode_property_read_string(child, "adi,extended-name",
&st->channels[cnt].extended_name);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

adc have a 'label' property to accomplish the same as the above. It should also be acceptable to have the same for 'frequency' devices. I can take care of this afterwards...

mhennerich and others added 2 commits January 15, 2025 12:42
Add dt-bindings for the Analog Devices ADF4030 Precision Synchronizer IC.

Signed-off-by: Michael Hennerich <michael.hennerich@analog.com>
Automatically imply ADF4030.

Signed-off-by: Nuno Sa <nuno.sa@analog.com>
@nunojsa nunojsa force-pushed the staging/adf4030-support branch from b0db36f to 55273ec Compare January 15, 2025 12:44
@nunojsa
Copy link
Collaborator

nunojsa commented Jan 15, 2025

Last push (not sure which version we're in this 😅) should fix the bindings validation job

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants