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

Initial i.MX93 support #189

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

Initial i.MX93 support #189

wants to merge 3 commits into from

Conversation

Indanz
Copy link
Contributor

@Indanz Indanz commented Nov 29, 2024

Works with the ARM generic timer when KernelArmExportPCNTUser and KernelArmExportPTMRUser are enabled. The Low Power Timer driver is in progress and will be added soon.

Same LPUART as imx8qxp. Timers seem new and needs a new driver.
For now, use ARM generic timer when KernelArmExportPCNTUser and
KernelArmExportPTMRUser are enabled.

Signed-off-by: Indan Zupancic <[email protected]>
@Xaphiosis
Copy link
Member

Works with the ARM generic timer when KernelArmExportPCNTUser and KernelArmExportPTMRUser are enabled. The Low Power Timer driver is in progress and will be added soon.

As far as we know, you added support for the low-power timer already. Is it only the case that this comment is out of date now?

@lsf37
Copy link
Member

lsf37 commented Dec 2, 2024

As far as we know, you added support for the low-power timer already. Is it only the case that this comment is out of date now?

The corresponding commit is still missing on this branch. (Not that it's required for the port, it would just be a nice additional feature to have).

@lsf37 lsf37 self-assigned this Dec 2, 2024
Copy link
Member

@lsf37 lsf37 left a comment

Choose a reason for hiding this comment

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

This looks good from my side. It would be nice to add the LPTR even just for convenience. Happy for it to go into this PR or a separate one.

@Indanz
Copy link
Contributor Author

Indanz commented Dec 3, 2024

More detail in my mail. To summarize, at least on the MCIMX93-SOMB2 module the 32 kHz clock is significantly out-of-sync with the 24 MHz clock (assuming they didn't put a 25 MHz crystal on by mistake), most likely because the 24 MHz clock is inaccurate by about 2.5%. This makes the SCHED0011 test fail because it relies on the clocks to be mostly in sync.

Another issue is that taking a timestamp takes 0.5 us, which is extremely slow.

Basically we have four choices:

  1. Don't bother with the LPTMR driver.
  2. Add the LPTMR using the 32 kHz clock: sel4test will fail on this board.
  3. Add LPTMR using the 24 MHz clock: sel4test will pass, timing will probably be very inaccurate.
  4. Add LPTMR using 32 kHz clock, but use Arm Generic Timer for timestamping when CONFIG_EXPORT_PCNT_USER is enabled. This should make make the tests pass and be practically useful. But would cost more time to implement.

Currently I have a driver with a define at the top that chooses between the two clock sources.

@Indanz
Copy link
Contributor Author

Indanz commented Dec 4, 2024

I pushed the LPTMR, I made the clock source a config option, with the 24 MHz source as default to avoid breaking sel4test.

@Indanz
Copy link
Contributor Author

Indanz commented Dec 11, 2024

The clock mystery also has been solved:

I measured the clocks with a borrowed oscilloscope and that proofs that the 24MHz is fine, but the 32 kHz one is garbage. They put a 32.768 kHz crystal on the dev board instead of a 32 kHz one, probably because it's cheaper. That explains the 2.4% difference I see. They even documented it in MCIMX93EVKUM.pdf and the schematics, but I missed it before.

I'm going to complain about this to NXP. Those dev boards are expensive, so you'd expect them to not cut corners like this. If they do things like this, you can as well get a much cheaper, but probably higher quality i.MX93 board from someone else instead.

I've updated the commit message to document this crystal problem.

@Indanz
Copy link
Contributor Author

Indanz commented Dec 11, 2024

Never mind, I'm just stupid: The 32kHz crystal is supposed to be 32.768 kHz. Updating the driver to that and change to the 32 kHz cock source as default. I've been misled by 32kHz dividing one second in a nice round nanosecond number, but that's not what the crystal value was chosen for, it was chosen to divide one second in a power-of-two number of ticks.

Only used if the Arm generic timer cannot be used.

The clock source is configurable. The default is the 32.768 kHz clock,
as that is more accurate for timekeeping and keeps running when the
board is in low power state and can wake up the CPU.

Retrieving the time takes about 0.5 us, so this timer is very slow.

Both LPMTR1 and LPTMR2 are used because you are not allowed to
change the compare value while the timer is running.

Signed-off-by: Indan Zupancic <[email protected]>
@Indanz
Copy link
Contributor Author

Indanz commented Dec 16, 2024

Could someone review my timer driver code? I'm not very familiar with the util_libs' driver framework, it's a bit confusing. Other timer drivers seem to be either over complicating things, or I'm missing something.

Copy link
Member

@lsf37 lsf37 left a comment

Choose a reason for hiding this comment

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

Happy with the updates and with the figured out mystery of the 32 kHz clock. The driver code as such looks good to me, but I can't say I'm an expert on these.

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.

3 participants