drivers/rpmsg: Add edge_create and edge_destroy for router

use cmd to notify the other cpu to destroy router edge device,
and dont destroy the other cpu's "router:ept"

Signed-off-by: yintao <yintao@xiaomi.com>
This commit is contained in:
yintao 2024-07-02 18:31:52 +08:00 committed by Xiang Xiao
parent 76572f9892
commit 968da8b781
3 changed files with 111 additions and 30 deletions

View File

@ -39,12 +39,16 @@
#define RPMSG_ROUTER_NAME_PREFIX_LEN 2 #define RPMSG_ROUTER_NAME_PREFIX_LEN 2
#define RPMSG_ROUTER_CPUNAME_LEN 8 #define RPMSG_ROUTER_CPUNAME_LEN 8
#define RPMSG_ROUTER_CREATE 1
#define RPMSG_ROUTER_DESTROY 2
/**************************************************************************** /****************************************************************************
* Public Types * Public Types
****************************************************************************/ ****************************************************************************/
begin_packed_struct struct rpmsg_router_s begin_packed_struct struct rpmsg_router_s
{ {
uint32_t cmd;
uint32_t tx_len; uint32_t tx_len;
uint32_t rx_len; uint32_t rx_len;
char cpuname[RPMSG_ROUTER_CPUNAME_LEN]; char cpuname[RPMSG_ROUTER_CPUNAME_LEN];

View File

@ -67,6 +67,7 @@ struct rpmsg_router_edge_s
struct rpmsg_s rpmsg; struct rpmsg_s rpmsg;
struct rpmsg_device rdev; struct rpmsg_device rdev;
struct rpmsg_device *hubdev; struct rpmsg_device *hubdev;
char name[RPMSG_NAME_SIZE];
char localcpu[RPMSG_ROUTER_CPUNAME_LEN]; char localcpu[RPMSG_ROUTER_CPUNAME_LEN];
char remotecpu[RPMSG_ROUTER_CPUNAME_LEN]; char remotecpu[RPMSG_ROUTER_CPUNAME_LEN];
@ -536,49 +537,64 @@ static void rpmsg_router_edge_bind(FAR struct rpmsg_device *rdev,
} }
/**************************************************************************** /****************************************************************************
* Name: rpmsg_router_cb * Name: rpmsg_router_edge_destroy
* *
* Description: * Description:
* This function is used to receive sync message from router core, * This function is used to destroy the edge core device.
* and initialize the router rpmsg device.
* *
* Parameters: * Parameters:
* ept - endpoint for synchronizing ready messages * edge - rpmsg router edge device
* data - received data
* len - received data length
* src - source address
* priv - private data
*
* Returned Values:
* 0 on success; A negated errno value is returned on any failure.
* *
****************************************************************************/ ****************************************************************************/
static int rpmsg_router_cb(FAR struct rpmsg_endpoint *ept, static void rpmsg_router_edge_destroy(FAR struct rpmsg_router_edge_s *edge)
FAR void *data, size_t len, {
uint32_t src, FAR void *priv) rpmsg_unregister_callback(edge, NULL, NULL,
rpmsg_router_edge_match,
rpmsg_router_edge_bind);
rpmsg_unregister(edge->name, &edge->rpmsg);
rpmsg_device_destory(&edge->rpmsg);
kmm_free(edge);
}
/****************************************************************************
* Name: rpmsg_router_edge_create
*
* Description:
* This function is used to create the edge core device.
*
* Parameters:
* hubdev - rpmsg device for router hub
* msg - sync message from router hub
* remotecpu - remote edge cpu name
*
* Returned Values:
* edge device on success; NULL on failure.
*
****************************************************************************/
static FAR struct rpmsg_router_edge_s *
rpmsg_router_edge_create(FAR struct rpmsg_device *hubdev,
FAR struct rpmsg_router_s *msg,
FAR const char *remotecpu)
{ {
FAR struct rpmsg_router_s *msg = data;
FAR struct rpmsg_router_edge_s *edge; FAR struct rpmsg_router_edge_s *edge;
FAR struct rpmsg_device *rdev; FAR struct rpmsg_device *rdev;
char name[32];
int ret; int ret;
/* Create the router edge device */
edge = kmm_zalloc(sizeof(*edge)); edge = kmm_zalloc(sizeof(*edge));
if (!edge) if (!edge)
{ {
return -ENOMEM; return NULL;
} }
/* Initialize router device */ strlcpy(edge->remotecpu, remotecpu, sizeof(edge->remotecpu));
strlcpy(edge->remotecpu, ept->name + RPMSG_ROUTER_NAME_LEN,
sizeof(edge->remotecpu));
strlcpy(edge->localcpu, msg->cpuname, sizeof(edge->localcpu)); strlcpy(edge->localcpu, msg->cpuname, sizeof(edge->localcpu));
edge->rx_len = msg->rx_len; edge->rx_len = msg->rx_len;
edge->tx_len = msg->tx_len; edge->tx_len = msg->tx_len;
edge->hubdev = ept->rdev; edge->hubdev = hubdev;
ept->priv = edge;
/* Initialize router rpmsg device */ /* Initialize router rpmsg device */
@ -599,8 +615,8 @@ static int rpmsg_router_cb(FAR struct rpmsg_endpoint *ept,
/* Register rpmsg for edge core */ /* Register rpmsg for edge core */
snprintf(name, sizeof(name), "/dev/rpmsg/%s", edge->remotecpu); snprintf(edge->name, sizeof(edge->name), "/dev/rpmsg/%s", edge->remotecpu);
ret = rpmsg_register(name, &edge->rpmsg, &g_rpmsg_router_edge_ops); ret = rpmsg_register(edge->name, &edge->rpmsg, &g_rpmsg_router_edge_ops);
if (ret < 0) if (ret < 0)
{ {
rpmsgerr("rpmsg_register failed: %d\n", ret); rpmsgerr("rpmsg_register failed: %d\n", ret);
@ -622,14 +638,68 @@ static int rpmsg_router_cb(FAR struct rpmsg_endpoint *ept,
/* Broadcast device_created to all registers */ /* Broadcast device_created to all registers */
rpmsg_device_created(&edge->rpmsg); rpmsg_device_created(&edge->rpmsg);
return 0; return edge;
unregister: unregister:
rpmsg_unregister(name, &edge->rpmsg); rpmsg_unregister(edge->name, &edge->rpmsg);
free: free:
kmm_free(edge); kmm_free(edge);
ept->priv = NULL; return NULL;
return ret; }
/****************************************************************************
* Name: rpmsg_router_cb
*
* Description:
* This function is used to receive sync message from router core,
* and create or destroy the edge core device.
*
* Parameters:
* ept - endpoint for synchronizing ready messages
* data - received data
* len - received data length
* src - source address
* priv - private data
*
* Returned Values:
* 0 on success; A negated errno value is returned on any failure.
*
****************************************************************************/
static int rpmsg_router_cb(FAR struct rpmsg_endpoint *ept,
FAR void *data, size_t len,
uint32_t src, FAR void *priv)
{
FAR struct rpmsg_router_s *msg = data;
FAR struct rpmsg_router_edge_s *edge;
/* Destroy the router edge device */
if (msg->cmd == RPMSG_ROUTER_DESTROY)
{
edge = ept->priv;
if (edge)
{
rpmsg_router_edge_destroy(edge);
ept->priv = NULL;
return 0;
}
return -EINVAL;
}
/* Create the router edge device */
edge = rpmsg_router_edge_create(ept->rdev, msg,
ept->name + RPMSG_ROUTER_NAME_LEN);
if (!edge)
{
return -ENODEV;
}
ept->priv = edge;
return 0;
} }
/**************************************************************************** /****************************************************************************
@ -650,7 +720,7 @@ static void rpmsg_router_unbind(FAR struct rpmsg_endpoint *ept)
if (edge) if (edge)
{ {
kmm_free(edge); rpmsg_router_edge_destroy(edge);
ept->priv = NULL; ept->priv = NULL;
} }

View File

@ -321,6 +321,7 @@ static void rpmsg_router_bound(FAR struct rpmsg_endpoint *ept)
for (i = 0; i < 2; i++) for (i = 0; i < 2; i++)
{ {
msg.cmd = RPMSG_ROUTER_CREATE;
msg.tx_len = MIN(rpmsg_get_rx_buffer_size(hub->ept[i].rdev), msg.tx_len = MIN(rpmsg_get_rx_buffer_size(hub->ept[i].rdev),
rpmsg_get_tx_buffer_size(hub->ept[1 - i].rdev)); rpmsg_get_tx_buffer_size(hub->ept[1 - i].rdev));
msg.rx_len = MIN(rpmsg_get_tx_buffer_size(hub->ept[i].rdev), msg.rx_len = MIN(rpmsg_get_tx_buffer_size(hub->ept[i].rdev),
@ -397,6 +398,7 @@ static void rpmsg_router_destroy(FAR struct rpmsg_device *rdev,
FAR void *priv) FAR void *priv)
{ {
FAR struct rpmsg_router_hub_s *hub = priv; FAR struct rpmsg_router_hub_s *hub = priv;
struct rpmsg_router_s msg;
int i; int i;
for (i = 0; i < 2; i++) for (i = 0; i < 2; i++)
@ -407,6 +409,11 @@ static void rpmsg_router_destroy(FAR struct rpmsg_device *rdev,
} }
rpmsg_destroy_ept(&hub->ept[i]); rpmsg_destroy_ept(&hub->ept[i]);
/* Notify the other edge core to destroy router device */
msg.cmd = RPMSG_ROUTER_DESTROY;
rpmsg_send(&hub->ept[1 - i], &msg, sizeof(msg));
break; break;
} }
} }