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

[BUG] sof-ctl blob format is not the same as with ALSA UCM, should align the sof-ctl format #9092

Open
singalsu opened this issue May 2, 2024 · 5 comments
Assignees
Labels
bug Something isn't working as expected
Milestone

Comments

@singalsu
Copy link
Collaborator

singalsu commented May 2, 2024

Describe the bug

Sof-ctl supports ASCII text format uint32_t numbers data (txt) and binary (blob) format. The binary blobs supported by UCM's cset-tlv need to have an additional 8 bytes header to work. The header contains for ALSA control API an index SOF_CTRL_CMD_BINARY (value 3) and size of following blob data without this header.

As result we need two kinds of binary blobs.

To Reproduce
Trying to cset-tlv an existing blob is not working. There is a fix in #9070 to produce new format binary blobs for UCM. But those blobs do not work with sof-ctl.

Reproduction Rate
Always

Expected behavior
Tools support for blobs without confusion to developers. Likely it would be best to change in sof-ctl both text and binary format data files to use the version with header from UCM.

The topology embedded format is same as sof-ctl's current format, no 8 bytes header. The topology blob format (.m4 or .conf ASCII hex bytes) should stay the same to avoid a compatibility break.

Impact
Annoyance.

Environment

  1. Branch name and commit hash of the 2 repositories: sof (firmware/topology) and linux (kernel driver).
    • Kernel: {SHA}
    • SOF: {SHA}
  2. Name of the topology file
    • Topology: {FILE}
  3. Name of the platform(s) on which the bug is observed.
    • Platform: {PLATFORM}

Screenshots or console output
If applicable, add a screenshot (drag-and-drop an image), or console logs
(cut-and-paste text and put a code fence (```) before and after, to help
explain the issue.

Please also include the relevant sections from the firmware log and kernel log in the report (and attach the full logs for complete reference). Kernel log is taken from dmesg and firmware log from sof-logger. See https://thesofproject.github.io/latest/developer_guides/debugability/logger/index.html

@singalsu singalsu added the bug Something isn't working as expected label May 2, 2024
@lgirdwood
Copy link
Member

@singalsu is the intention to align sof-ctl with how cset-tlv works or the other way around ?

@lgirdwood lgirdwood added this to the v2.11 milestone May 2, 2024
@singalsu
Copy link
Collaborator Author

singalsu commented May 3, 2024

@singalsu is the intention to align sof-ctl with how cset-tlv works or the other way around ?

There's already a lot of products mass with UCM's cset-tlv so we should follow it with sof-ctl (used only by developers).

@kv2019i
Copy link
Collaborator

kv2019i commented Sep 5, 2024

@singalsu Is this still planned for v2.11 (rc1 tag next Friday)?

@singalsu
Copy link
Collaborator Author

@singalsu Is this still planned for v2.11 (rc1 tag next Friday)?

I'll change it to v2.12, not enough time to test the change impact to various scripts (GUI, sof-test etc.). It's not critical since it's a developer feature.

@singalsu singalsu modified the milestones: v2.11, v2.12 Sep 11, 2024
@singalsu singalsu modified the milestones: v2.12, v2.13 Dec 20, 2024
@singalsu
Copy link
Collaborator Author

I today started I to work with the feature to target 2.13, updating Octave scripts for blobs exports and update sof-ctl. The patch depends on #9749.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working as expected
Projects
None yet
Development

No branches or pull requests

3 participants