driver/ioe_rpmsg: split server and client ept_cb to simplify code
Signed-off-by: Jiuzhu Dong <dongjiuzhu1@xiaomi.com>
This commit is contained in:
parent
978530f5f6
commit
40e86501f1
@ -63,8 +63,7 @@ struct ioe_rpmsg_cookie_s
|
|||||||
|
|
||||||
begin_packed_struct struct ioe_rpmsg_header_s
|
begin_packed_struct struct ioe_rpmsg_header_s
|
||||||
{
|
{
|
||||||
uint32_t command : 31;
|
uint32_t command;
|
||||||
uint32_t response : 1;
|
|
||||||
int32_t result;
|
int32_t result;
|
||||||
uint64_t cookie;
|
uint64_t cookie;
|
||||||
} end_packed_struct;
|
} end_packed_struct;
|
||||||
@ -143,9 +142,12 @@ struct ioe_rpmsg_client_s
|
|||||||
* Private Function Prototypes
|
* Private Function Prototypes
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static int ioe_rpmsg_ept_cb(FAR struct rpmsg_endpoint *ept,
|
static int ioe_rpmsg_client_ept_cb(FAR struct rpmsg_endpoint *ept,
|
||||||
FAR void *data, size_t len,
|
FAR void *data, size_t len,
|
||||||
uint32_t src, FAR void *priv_);
|
uint32_t src, FAR void *priv_);
|
||||||
|
static int ioe_rpmsg_server_ept_cb(FAR struct rpmsg_endpoint *ept,
|
||||||
|
FAR void *data, size_t len,
|
||||||
|
uint32_t src, FAR void *priv_);
|
||||||
|
|
||||||
static int ioe_rpmsg_direction_handler(FAR struct rpmsg_endpoint *ept,
|
static int ioe_rpmsg_direction_handler(FAR struct rpmsg_endpoint *ept,
|
||||||
FAR void *data, size_t len,
|
FAR void *data, size_t len,
|
||||||
@ -202,7 +204,6 @@ static const rpmsg_ept_cb g_ioe_rpmsg_handler[] =
|
|||||||
#ifdef CONFIG_IOEXPANDER_INT_ENABLE
|
#ifdef CONFIG_IOEXPANDER_INT_ENABLE
|
||||||
[IOE_RPMSG_ATTACH] = ioe_rpmsg_attach_handler,
|
[IOE_RPMSG_ATTACH] = ioe_rpmsg_attach_handler,
|
||||||
[IOE_RPMSG_DETACH] = ioe_rpmsg_detach_handler,
|
[IOE_RPMSG_DETACH] = ioe_rpmsg_detach_handler,
|
||||||
[IOE_RPMSG_IRQ] = ioe_rpmsg_irq_handler,
|
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -271,7 +272,6 @@ static int ioe_rpmsg_sendrecv(FAR struct rpmsg_endpoint *ept,
|
|||||||
nxsem_set_protocol(&cookie.sem, SEM_PRIO_NONE);
|
nxsem_set_protocol(&cookie.sem, SEM_PRIO_NONE);
|
||||||
|
|
||||||
msg->command = command;
|
msg->command = command;
|
||||||
msg->response = 0;
|
|
||||||
msg->result = -ENXIO;
|
msg->result = -ENXIO;
|
||||||
msg->cookie = (uintptr_t)&cookie;
|
msg->cookie = (uintptr_t)&cookie;
|
||||||
|
|
||||||
@ -453,7 +453,7 @@ static void ioe_rpmsg_irqworker(FAR void *priv_)
|
|||||||
msg.cbarg = cb->cbarg;
|
msg.cbarg = cb->cbarg;
|
||||||
|
|
||||||
msg.header.command = IOE_RPMSG_IRQ;
|
msg.header.command = IOE_RPMSG_IRQ;
|
||||||
msg.header.response = 0;
|
msg.header.cookie = 0;
|
||||||
rpmsg_send(cb->ept, &msg, sizeof(msg));
|
rpmsg_send(cb->ept, &msg, sizeof(msg));
|
||||||
|
|
||||||
cb->pendset = 0;
|
cb->pendset = 0;
|
||||||
@ -538,30 +538,27 @@ static int ioe_rpmsg_irq_handler(FAR struct rpmsg_endpoint *ept,
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static int ioe_rpmsg_ept_cb(FAR struct rpmsg_endpoint *ept, FAR void *data,
|
static int ioe_rpmsg_client_ept_cb(FAR struct rpmsg_endpoint *ept,
|
||||||
size_t len, uint32_t src, FAR void *priv_)
|
FAR void *data, size_t len,
|
||||||
|
uint32_t src, FAR void *priv_)
|
||||||
{
|
{
|
||||||
FAR struct ioe_rpmsg_header_s *msg = data;
|
FAR struct ioe_rpmsg_header_s *msg = data;
|
||||||
uint32_t cmd = msg->command;
|
|
||||||
int ret = -EINVAL;
|
|
||||||
|
|
||||||
struct ioe_rpmsg_cookie_s *cookie =
|
struct ioe_rpmsg_cookie_s *cookie =
|
||||||
(struct ioe_rpmsg_cookie_s *)(uintptr_t)msg->cookie;
|
(struct ioe_rpmsg_cookie_s *)(uintptr_t)msg->cookie;
|
||||||
|
|
||||||
if (msg->response && cookie)
|
if (cookie)
|
||||||
{
|
{
|
||||||
cookie->result = msg->result;
|
cookie->result = msg->result;
|
||||||
rpmsg_post(ept, &cookie->sem);
|
rpmsg_post(ept, &cookie->sem);
|
||||||
ret = 0;
|
|
||||||
}
|
}
|
||||||
else if (cmd < ARRAY_SIZE(g_ioe_rpmsg_handler)
|
#ifdef CONFIG_IOEXPANDER_INT_ENABLE
|
||||||
&& g_ioe_rpmsg_handler[cmd])
|
else if (msg->command == IOE_RPMSG_IRQ)
|
||||||
{
|
{
|
||||||
msg->response = 1;
|
ioe_rpmsg_irq_handler(ept, data, len, src, priv_);
|
||||||
ret = g_ioe_rpmsg_handler[cmd](ept, data, len, src, priv_);
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return ret;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ioe_rpmsg_client_created(FAR struct rpmsg_device *rdev,
|
static void ioe_rpmsg_client_created(FAR struct rpmsg_device *rdev,
|
||||||
@ -576,7 +573,7 @@ static void ioe_rpmsg_client_created(FAR struct rpmsg_device *rdev,
|
|||||||
|
|
||||||
priv->ept.priv = priv;
|
priv->ept.priv = priv;
|
||||||
rpmsg_create_ept(&priv->ept, rdev, eptname, RPMSG_ADDR_ANY,
|
rpmsg_create_ept(&priv->ept, rdev, eptname, RPMSG_ADDR_ANY,
|
||||||
RPMSG_ADDR_ANY, ioe_rpmsg_ept_cb, NULL);
|
RPMSG_ADDR_ANY, ioe_rpmsg_client_ept_cb, NULL);
|
||||||
|
|
||||||
rpmsg_post(&priv->ept, &priv->sem);
|
rpmsg_post(&priv->ept, &priv->sem);
|
||||||
}
|
}
|
||||||
@ -594,6 +591,21 @@ static void ioe_rpmsg_client_destroy(FAR struct rpmsg_device *rdev,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ioe_rpmsg_server_ept_cb(FAR struct rpmsg_endpoint *ept,
|
||||||
|
FAR void *data, size_t len,
|
||||||
|
uint32_t src, FAR void *priv_)
|
||||||
|
{
|
||||||
|
FAR struct ioe_rpmsg_header_s *msg = data;
|
||||||
|
uint32_t cmd = msg->command;
|
||||||
|
|
||||||
|
if (cmd < ARRAY_SIZE(g_ioe_rpmsg_handler) && g_ioe_rpmsg_handler[cmd])
|
||||||
|
{
|
||||||
|
return g_ioe_rpmsg_handler[cmd](ept, data, len, src, priv_);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void ioe_rpmsg_server_unbind(FAR struct rpmsg_endpoint *ept)
|
static void ioe_rpmsg_server_unbind(FAR struct rpmsg_endpoint *ept)
|
||||||
{
|
{
|
||||||
rpmsg_destroy_ept(ept);
|
rpmsg_destroy_ept(ept);
|
||||||
@ -624,7 +636,7 @@ static void ioe_rpmsg_server_bind(FAR struct rpmsg_device *rdev,
|
|||||||
ept->priv = priv;
|
ept->priv = priv;
|
||||||
|
|
||||||
rpmsg_create_ept(ept, rdev, name, RPMSG_ADDR_ANY, RPMSG_ADDR_ANY,
|
rpmsg_create_ept(ept, rdev, name, RPMSG_ADDR_ANY, RPMSG_ADDR_ANY,
|
||||||
ioe_rpmsg_ept_cb, ioe_rpmsg_server_unbind);
|
ioe_rpmsg_server_ept_cb, ioe_rpmsg_server_unbind);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user