Commit b2bbe3dc authored by Nicolas Saenz Julienne's avatar Nicolas Saenz Julienne Committed by Greg Kroah-Hartman

staging: vchi: Get rid of vchi_bulk_queue_receive()

Its vchiq counterpart, vchiq_bulk_receive() is only used by vchi. We can
then merge both functions by moving vchi_bulk_queue_receive()'s retry
mechanism into vchiq_bulk_receive() and let services call the later.
Signed-off-by: default avatarNicolas Saenz Julienne <nsaenzjulienne@suse.de>
Link: https://lore.kernel.org/r/20200629150945.10720-41-nsaenzjulienne@suse.deSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 76dbbe77
...@@ -58,13 +58,6 @@ extern int32_t vchi_held_msg_release(unsigned handle, struct vchiq_header *messa ...@@ -58,13 +58,6 @@ extern int32_t vchi_held_msg_release(unsigned handle, struct vchiq_header *messa
* Global bulk API * Global bulk API
*****************************************************************************/ *****************************************************************************/
// Routine to prepare interface for a transfer from the other side
extern int32_t vchi_bulk_queue_receive(unsigned handle,
void *data_dst,
uint32_t data_size,
enum vchiq_bulk_mode mode,
void *transfer_handle);
// Routine to queue up data ready for transfer to the other (once they have signalled they are ready) // Routine to queue up data ready for transfer to the other (once they have signalled they are ready)
extern int32_t vchi_bulk_queue_transmit(unsigned handle, extern int32_t vchi_bulk_queue_transmit(unsigned handle,
const void *data_src, const void *data_src,
......
...@@ -374,24 +374,36 @@ vchiq_bulk_transmit(unsigned int handle, const void *data, ...@@ -374,24 +374,36 @@ vchiq_bulk_transmit(unsigned int handle, const void *data,
} }
EXPORT_SYMBOL(vchiq_bulk_transmit); EXPORT_SYMBOL(vchiq_bulk_transmit);
enum vchiq_status enum vchiq_status vchiq_bulk_receive(unsigned int handle, void *data,
vchiq_bulk_receive(unsigned int handle, void *data, unsigned int size, void *userdata,
unsigned int size, void *userdata, enum vchiq_bulk_mode mode) enum vchiq_bulk_mode mode)
{ {
enum vchiq_status status; enum vchiq_status status;
switch (mode) { while (1) {
case VCHIQ_BULK_MODE_NOCALLBACK: switch (mode) {
case VCHIQ_BULK_MODE_CALLBACK: case VCHIQ_BULK_MODE_NOCALLBACK:
status = vchiq_bulk_transfer(handle, data, size, userdata, case VCHIQ_BULK_MODE_CALLBACK:
mode, VCHIQ_BULK_RECEIVE); status = vchiq_bulk_transfer(handle, data, size, userdata,
break; mode, VCHIQ_BULK_RECEIVE);
case VCHIQ_BULK_MODE_BLOCKING: break;
status = vchiq_blocking_bulk_transfer(handle, case VCHIQ_BULK_MODE_BLOCKING:
(void *)data, size, VCHIQ_BULK_RECEIVE); status = vchiq_blocking_bulk_transfer(handle,
break; (void *)data, size, VCHIQ_BULK_RECEIVE);
default: break;
return VCHIQ_ERROR; default:
return VCHIQ_ERROR;
}
/*
* vchiq_*_bulk_transfer() may return VCHIQ_RETRY, so we need
* to implement a retry mechanism since this function is
* supposed to block until queued
*/
if (status != VCHIQ_RETRY)
break;
msleep(1);
} }
return status; return status;
......
...@@ -31,44 +31,6 @@ int vchi_queue_kernel_message(unsigned handle, void *data, unsigned int size) ...@@ -31,44 +31,6 @@ int vchi_queue_kernel_message(unsigned handle, void *data, unsigned int size)
} }
EXPORT_SYMBOL(vchi_queue_kernel_message); EXPORT_SYMBOL(vchi_queue_kernel_message);
/***********************************************************
* Name: vchi_bulk_queue_receive
*
* Arguments: VCHI_BULK_HANDLE_T handle,
* void *data_dst,
* const uint32_t data_size,
* enum vchi_flags flags
* void *bulk_handle
*
* Description: Routine to setup a rcv buffer
*
* Returns: int32_t - success == 0
*
***********************************************************/
int32_t vchi_bulk_queue_receive(unsigned handle, void *data_dst,
uint32_t data_size, enum vchiq_bulk_mode mode,
void *bulk_handle)
{
enum vchiq_status status;
while (1) {
status = vchiq_bulk_receive(handle, data_dst, data_size,
bulk_handle, mode);
/*
* vchiq_bulk_receive() may return VCHIQ_RETRY, so we need to
* implement a retry mechanism since this function is supposed
* to block until queued
*/
if (status != VCHIQ_RETRY)
break;
msleep(1);
}
return status;
}
EXPORT_SYMBOL(vchi_bulk_queue_receive);
/*********************************************************** /***********************************************************
* Name: vchi_bulk_queue_transmit * Name: vchi_bulk_queue_transmit
* *
......
...@@ -279,7 +279,7 @@ static void buffer_work_cb(struct work_struct *work) ...@@ -279,7 +279,7 @@ static void buffer_work_cb(struct work_struct *work)
* VCHI will allow up to 4 bulk receives to be scheduled before blocking. * VCHI will allow up to 4 bulk receives to be scheduled before blocking.
* If we block in the service_callback context then we can't process the * If we block in the service_callback context then we can't process the
* VCHI_CALLBACK_BULK_RECEIVED message that would otherwise allow the blocked * VCHI_CALLBACK_BULK_RECEIVED message that would otherwise allow the blocked
* vchi_bulk_queue_receive() call to complete. * vchiq_bulk_receive() call to complete.
*/ */
static void buffer_to_host_work_cb(struct work_struct *work) static void buffer_to_host_work_cb(struct work_struct *work)
{ {
...@@ -295,19 +295,19 @@ static void buffer_to_host_work_cb(struct work_struct *work) ...@@ -295,19 +295,19 @@ static void buffer_to_host_work_cb(struct work_struct *work)
len = 8; len = 8;
/* queue the bulk submission */ /* queue the bulk submission */
vchi_service_use(instance->service_handle); vchi_service_use(instance->service_handle);
ret = vchi_bulk_queue_receive(instance->service_handle, ret = vchiq_bulk_receive(instance->service_handle,
msg_context->u.bulk.buffer->buffer, msg_context->u.bulk.buffer->buffer,
/* Actual receive needs to be a multiple /* Actual receive needs to be a multiple
* of 4 bytes * of 4 bytes
*/ */
(len + 3) & ~3, (len + 3) & ~3,
VCHIQ_BULK_MODE_CALLBACK, msg_context,
msg_context); VCHIQ_BULK_MODE_CALLBACK);
vchi_service_release(instance->service_handle); vchi_service_release(instance->service_handle);
if (ret != 0) if (ret != 0)
pr_err("%s: ctx: %p, vchi_bulk_queue_receive failed %d\n", pr_err("%s: ctx: %p, vchiq_bulk_receive failed %d\n",
__func__, msg_context, ret); __func__, msg_context, ret);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment