I want to use function calls from M4 and A9 simultaneosly.
I am using arbitrator sources for it.
The function call from A9 works fine and M4 returns data.
But function call from M4 seems doesn't work. The error appears in A9 "Waiting MU transmit buffer empty timeout!
ugh, imx_mu_rpmsg_send() failed: -5".
After this error data function call doesn't work in another side too: "rpmsg_multiept rpmsg0: virtqueue_add_outbuf failed: -5"
M4 code
.
.
erpc_transport_t transport = erpc_transport_rpmsg_lite_rtos_remote_init(30, 1024, BOARD_SHARED_MEMORY_BASE, 0, NULL, cp);
erpc_mbf_t message_buffer_factory = erpc_mbf_rpmsg_init(transport);
erpc_transport_t arbitrator = erpc_arbitrated_client_init(transport, message_buffer_factory);
erpc_server_init(arbitrator, message_buffer_factory);
erpc_add_service_to_server(create_XXX_service());
while (true)
{
erpc_server_poll();
function1(....);
}
A9 code
.
.
erpc_transport_t transport = erpc_transport_rpmsg_linux_init(1024, 0, 30);
erpc_mbf_t message_buffer_factory = erpc_mbf_dynamic_init();
erpc_transport_t arbitrator = erpc_arbitrated_client_init(transport, message_buffer_factory);
erpc_server_init(arbitrator, message_buffer_factory);
erpc_add_service_to_server(create_XXX_service());
while (true)
{
erpc_server_poll();
function2(....);
}
Could anybody suggest anything?
I want to use function calls from M4 and A9 simultaneosly.
I am using arbitrator sources for it.
The function call from A9 works fine and M4 returns data.
But function call from M4 seems doesn't work. The error appears in A9 "Waiting MU transmit buffer empty timeout!
ugh, imx_mu_rpmsg_send() failed: -5".
After this error data function call doesn't work in another side too: "rpmsg_multiept rpmsg0: virtqueue_add_outbuf failed: -5"
M4 code
.
.
erpc_transport_t transport = erpc_transport_rpmsg_lite_rtos_remote_init(30, 1024, BOARD_SHARED_MEMORY_BASE, 0, NULL, cp);
erpc_mbf_t message_buffer_factory = erpc_mbf_rpmsg_init(transport);
erpc_transport_t arbitrator = erpc_arbitrated_client_init(transport, message_buffer_factory);
erpc_server_init(arbitrator, message_buffer_factory);
erpc_add_service_to_server(create_XXX_service());
while (true)
{
erpc_server_poll();
function1(....);
}
A9 code
.
.
erpc_transport_t transport = erpc_transport_rpmsg_linux_init(1024, 0, 30);
erpc_mbf_t message_buffer_factory = erpc_mbf_dynamic_init();
erpc_transport_t arbitrator = erpc_arbitrated_client_init(transport, message_buffer_factory);
erpc_server_init(arbitrator, message_buffer_factory);
erpc_add_service_to_server(create_XXX_service());
while (true)
{
erpc_server_poll();
function2(....);
}
Could anybody suggest anything?