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

Misc. Zephyrization fixups #9731

Merged
merged 9 commits into from
Dec 19, 2024
Merged

Conversation

andyross
Copy link
Contributor

Some changes needed by an imminent Mediatek Zephyrization PR, largely of the form "make this older code build with Zephyr while we untangle it from the legacy layers".

Most of these shouldn't be controversial, so I've left them in a long series for simplicity. Let me know if there's something people want to split out for independent review.

In particular please look carefully at the Kconfig changes. I'm 90%+ sure that this is pure cleanup that doesn't change any existing configs, but it's not possible for me to test (or even build) all platforms, so some help by the relevant maintainers would be appreciated.

@andyross
Copy link
Contributor Author

Quick respin to fix a dropped file change. And now I see that this breaks IPC3 fuzzing somewhere. Will fix.

@andyross andyross force-pushed the zephyr-fixups-1224 branch 2 times, most recently from 132fbdd to 9b37e3f Compare December 18, 2024 00:28
@andyross andyross requested a review from singalsu as a code owner December 18, 2024 02:48
src/lib/alloc.c Outdated Show resolved Hide resolved
Copy link
Member

@lgirdwood lgirdwood left a comment

Choose a reason for hiding this comment

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

LGTM @andyross do you know if next step is to use native zephyr drivers for MTK ?

Copy link
Collaborator

@kv2019i kv2019i left a comment

Choose a reason for hiding this comment

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

Thanks @andyross . 90% of the PR is completely fine and ready to go. The XTENSA_TOOLS_VERSION change seems a bit orthogonal to other fixes so maybe could go in as a separate PR. Other than that, only one issue that affects NXP IMX configs (see inline comment), but rest looks nice!

This is also timely and good opportunity to discuss about our transition layers. I'll make a separate discussion page entry on that. I have some further cleanups in progress for our "transitory tools", btu I'm now a bit hesitent to push them through as they may cause trouble like you had with the DMA interface naming changes.

scripts/xtensa-build-zephyr.py Outdated Show resolved Hide resolved
src/lib/alloc.c Outdated Show resolved Hide resolved
@@ -287,7 +287,7 @@ static int primary_core_init(int argc, char *argv[], struct sof *sof)
interrupt_init(sof);
#endif /* __ZEPHYR__ */

#ifdef CONFIG_ZEPHYR_LOG
#if defined(CONFIG_ZEPHYR_LOG) && !defined(CONFIG_LOG_MODE_MINIMAL)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Ack, this has been missed. Minimal support indeed a good addition!

zephyr/include/rtos/interrupt.h Outdated Show resolved Hide resolved
@@ -97,6 +97,9 @@ enum dma_cb_status {
DMA_CB_STATUS_END,
};

#define SOF_DMA_CB_STATUS_RELOAD DMA_CB_STATUS_RELOAD
#define SOF_DMA_CB_STATUS_END DMA_CB_STATUS_END

Copy link
Collaborator

Choose a reason for hiding this comment

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

Apologies @andyross , I was testing with all AMD/MTK/NXP/Intel targets in upstream, but right, definitions not used in upstream were very likely missed.

@@ -5,7 +5,6 @@ CONFIG_DCACHE_LINE_SIZE=128
CONFIG_DYNAMIC_INTERRUPTS=y
Copy link
Collaborator

Choose a reason for hiding this comment

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

@andyross Ack. CONFIG_TRACE was working with Zephyr at some point, but basicly as Intel has moved to native logging, this code is likely to have bitrotted. For Intel, we are ok to remove it. It was useful at start, but now that there is plenty of infra available in Zephyr (and plenty of examples in SOF how to use it), I don't think it's the worth keeping around anymore. And if it doesn't work anymore, seems like a clear case.

depends on COMP_FIR
depends on COMP_IIR
depends on COMP_TDFB
depends on COMP_FIR || COMP_IIR || COMP_TDFB
Copy link
Collaborator

Choose a reason for hiding this comment

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

FYI @singalsu

@andyross
Copy link
Contributor Author

LGTM @andyross do you know if next step is to use native zephyr drivers for MTK ?

That's the idea. It's just the two drivers: dummy_dma and afe. The former might have a solution from NXP already, but if not it's pretty simple as I read it. The latter is half way there already: it sources all its config from DTS on the Zephyr side, but then translates it to the legacy config struct for use by the existing driver code. Shouldn't be too hard. But for sure the first submission is going to be ZEPHYR_NATIVE_DRIVERS=n and IPC3.

I'm hammering out all the existing workaround right now and hope to have the submission out today.

Zephyr builds don't use the older trace protocol, but for now still
need to work with IPC3 kernel layers that expect it to be present.
Just return a noop success from trace messages when not configured,
otherwise the -EINVAL will propagate to the other side and abort the
firmware load.

Signed-off-by: Andy Ross <[email protected]>
When CONFIG_LOG_MODE_MINIMAL is chosen this function doesn't exist.

Minimal logging is actually really useful when debugging: it's a
synchronous logging mode (especially useful for winstream logging
where it becomes safe against DSP hangs or latchups) using the same
logging API, but with no buffering/filtering/timestamping, and is
backed by the platform printk() implementation.  We want to support
this.

Signed-off-by: Andy Ross <[email protected]>
This header may be included in situations where there is no log
context declared, but still needs to expand a tr_err() macro.  Declare
the "zephyr" context as a default.  (Though really this is not a
runtime error and should probably be handled with a BUILD_ASSERT()).

Also, there was a growing "enumerate all the Zephyr platforms"
preprocessor #if expression that can be simplified to
just the IMX8M device that needs special treatment.

Signed-off-by: Andy Ross <[email protected]>
These symbols got renamed in commit 1d73fb3 ("treewide: prefix
RTOS lib/dma.h DMA_ definitions with SOF_DMA_"), but these spots were
apparently dead code and missed it.  They're being resurrected, so fix
them up.

Signed-off-by: Andy Ross <[email protected]>
Things had gotten a little messy here.  The CPU_MASK_PIN_ONLY and
SMP_BOOT_DELAY options are in fact not generic to all Zephyr builds;
they both depend on SMP, and in fact don't exist otherwise, producing
a build failure if the board defconfig doesn't turn it off.  Create an
application "Kconfig" file (which SOF hasn't used so far), which
allows the dependencies for these settings to be more cleanly
expressed.

Similarly CONFIG_TRACE=y won't build with Zephyr, and all boards were
turning it off independently.  Move that to the prj.conf level.

And likewise CONFIG_ZEPHYR_LOG, while not strictly required for a
Zephyr build, is pervasively enabled (except on ACP6?  What does that
device use for logging?), so it belongs in the global file.

Signed-off-by: Andy Ross <[email protected]>
This DMA driver was using timer_get_system() to generate timestamps,
which is the Xtensa CCOUNT timer in legacy SOF but doesn't exist at
all in Zephyr (well, you can read the SR directly).  Use
sof_cycle_get_64(), which is the portable API based on the clock
hardware.  Other DMA drivers do just fine with this.

Signed-off-by: Andy Ross <[email protected]>
The older SOF allocator would return a valid pointer into the heap for
a zero length block, but Zephyr's sys_heap returns a NULL.  That's not
an error and it will free() as a noop.

Signed-off-by: Andy Ross <[email protected]>
At the start of probe(), the expectation is that component objects go
to COMP_STATE_INIT.  This was being skipped.  That used to be benign,
I believe because the struct was allocated via a path that set it
already.  But now it fails with the Zephyr integration.

Signed-off-by: Andy Ross <[email protected]>
The intent of the dependencies on this choice seems to be that they
apply only to certain components so the selection should be hidden if
they aren't in use.

But the logic was wrong: instead of enabling it if any component was
enabled that needed it, it would hide the selection unless ALL such
components were enabled.  Which doesn't build.  Fix.

(Also I note the comment implies that other kconfigs should probably
be in the list too, but not adding them out of conservatism as this
is, again, just a hygiene thing.)

Signed-off-by: Andy Ross <[email protected]>
Copy link
Collaborator

@kv2019i kv2019i left a comment

Choose a reason for hiding this comment

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

Thanks, looks good now!

@lgirdwood
Copy link
Member

@wszypelt @lrudyX Jenkins all passing, good to merge ?

@wszypelt
Copy link

@lgirdwood good to merge :)

@lgirdwood lgirdwood merged commit 3c4184b into thesofproject:main Dec 19, 2024
41 of 47 checks passed
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.

6 participants