-
Notifications
You must be signed in to change notification settings - Fork 6.8k
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
missing async uart.h system calls #21431
Comments
Original PR discussion for async API is here: There's a lot of discussion in here, but from skimming over all of it appears that the async UART APIs are intended for supervisor mode only, and these APIs are intended to be used by other drivers that are built on top of the UART. And that application code wouldn't use these APIs. @nordic-krch @pfalcon @Mierunski @carlescufi do I have that right? |
I don't think that's accurate
I am really not sure that is the case. I think those are actually also intended for application use. @nordic-krch and @Mierunski can you please confirm? |
We had that discussion already. It's not intended to be used in userspace. Tty api is more suitable. |
Yeah, this discussion isn't very clear. I saw these comments. We have lots of driver subsystems which have both system calls and callback registration. We don't allow callback registration from user mode, so the callback APIs are left supervisor only. But the rest of the APIs are exposed as system calls. The programming model is to set up callbacks at application init, before dropping privileges to user mode. What's special about this set of async APIs that we cannot create system calls for everything except uart_callback_set()? What am I missing here?
That wasn't my question -- I was asking if this is an application API or only intended for use by drivers. |
This was main argument for removing system calls from API (they were there at start of PR). There wasn't much interest in keeping system calls from other participants.
In my opinion this could also be application API, as (for me) it is easier to use than interrupt driven API. |
OK I think you guys got some bad advice, we can add syscalls for this API set and just omit it for the callback registration function. Callbacks get set up by supervisor threads just like other driver APIs. |
I'm looking at the serial driver system calls today. Adding the system calls themselves does not seem too hard. We have a small problem: async UART APIs are only implemented for two serial drivers: sam0 and nrfx. There are currently no platforms that are user-mode capable that also have the async UART APIs implemented in their serial driver, so I can't test whether this actually works even though we have a test case in tests/drivers/uart/uart_async_api [EDIT] I got confused, we have several boards we can test with. I could use help from someone at Nordic to test #21878 |
Describe the bug
The set of system calls for our serial API subsystem is incomplete. We are missing system calls for the following APIs, all of which are related to CONFIG_UART_ASYNC_API:
uart_tx()
uart_tx_abort()
uart_rx_enable()
uart_rx_disable()
uart_callback_set() installs a callback handler and shouldn't have a system call. uart_tx_buf_rsp() is only intended to be invoked from callbacks. The rest we should add unless we can specify a reason not to.
Impact
User mode threads can't use these APIs.
The text was updated successfully, but these errors were encountered: