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

staging: vchi: Unify struct shim_service and struct vchi_service_handle

The idea behind struct vchi_service_handle is to create an opaque handle
to struct shim_service. This can be achieved by doing a forward
declaration of struct shim_service, which will avoid unwarranted casts
and pointer play.

Ultimately as a rename is due all over the vchi user space, rename
struct shim_service into struvt vchi_service, which is more consistent
with the rest of the exposed API.
Signed-off-by: default avatarNicolas Saenz Julienne <nsaenzjulienne@suse.de>

Link: https://lore.kernel.org/r/20200629150945.10720-13-nsaenzjulienne@suse.deSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent a7983fd9
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
struct bcm2835_audio_instance { struct bcm2835_audio_instance {
struct device *dev; struct device *dev;
struct vchi_service_handle *vchi_handle; struct vchi_service *service;
struct completion msg_avail_comp; struct completion msg_avail_comp;
struct mutex vchi_mutex; struct mutex vchi_mutex;
struct bcm2835_alsa_stream *alsa_stream; struct bcm2835_alsa_stream *alsa_stream;
...@@ -25,12 +25,12 @@ MODULE_PARM_DESC(force_bulk, "Force use of vchiq bulk for audio"); ...@@ -25,12 +25,12 @@ MODULE_PARM_DESC(force_bulk, "Force use of vchiq bulk for audio");
static void bcm2835_audio_lock(struct bcm2835_audio_instance *instance) static void bcm2835_audio_lock(struct bcm2835_audio_instance *instance)
{ {
mutex_lock(&instance->vchi_mutex); mutex_lock(&instance->vchi_mutex);
vchi_service_use(instance->vchi_handle); vchi_service_use(instance->service);
} }
static void bcm2835_audio_unlock(struct bcm2835_audio_instance *instance) static void bcm2835_audio_unlock(struct bcm2835_audio_instance *instance)
{ {
vchi_service_release(instance->vchi_handle); vchi_service_release(instance->service);
mutex_unlock(&instance->vchi_mutex); mutex_unlock(&instance->vchi_mutex);
} }
...@@ -44,7 +44,7 @@ static int bcm2835_audio_send_msg_locked(struct bcm2835_audio_instance *instance ...@@ -44,7 +44,7 @@ static int bcm2835_audio_send_msg_locked(struct bcm2835_audio_instance *instance
init_completion(&instance->msg_avail_comp); init_completion(&instance->msg_avail_comp);
} }
status = vchi_queue_kernel_message(instance->vchi_handle, status = vchi_queue_kernel_message(instance->service,
m, sizeof(*m)); m, sizeof(*m));
if (status) { if (status) {
dev_err(instance->dev, dev_err(instance->dev,
...@@ -101,7 +101,7 @@ static void audio_vchi_callback(void *param, ...@@ -101,7 +101,7 @@ static void audio_vchi_callback(void *param,
if (reason != VCHI_CALLBACK_MSG_AVAILABLE) if (reason != VCHI_CALLBACK_MSG_AVAILABLE)
return; return;
status = vchi_msg_dequeue(instance->vchi_handle, status = vchi_msg_dequeue(instance->service,
&m, sizeof(m), &msg_len, VCHI_FLAGS_NONE); &m, sizeof(m), &msg_len, VCHI_FLAGS_NONE);
if (status) if (status)
return; return;
...@@ -135,7 +135,7 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance, ...@@ -135,7 +135,7 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance,
/* Open the VCHI service connections */ /* Open the VCHI service connections */
status = vchi_service_open(vchiq_instance, &params, status = vchi_service_open(vchiq_instance, &params,
&instance->vchi_handle); &instance->service);
if (status) { if (status) {
dev_err(instance->dev, dev_err(instance->dev,
...@@ -145,7 +145,7 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance, ...@@ -145,7 +145,7 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance,
} }
/* Finished with the service for now */ /* Finished with the service for now */
vchi_service_release(instance->vchi_handle); vchi_service_release(instance->service);
return 0; return 0;
} }
...@@ -155,10 +155,10 @@ static void vc_vchi_audio_deinit(struct bcm2835_audio_instance *instance) ...@@ -155,10 +155,10 @@ static void vc_vchi_audio_deinit(struct bcm2835_audio_instance *instance)
int status; int status;
mutex_lock(&instance->vchi_mutex); mutex_lock(&instance->vchi_mutex);
vchi_service_use(instance->vchi_handle); vchi_service_use(instance->service);
/* Close all VCHI service connections */ /* Close all VCHI service connections */
status = vchi_service_close(instance->vchi_handle); status = vchi_service_close(instance->service);
if (status) { if (status) {
dev_err(instance->dev, dev_err(instance->dev,
"failed to close VCHI service connection (status=%d)\n", "failed to close VCHI service connection (status=%d)\n",
...@@ -228,7 +228,7 @@ int bcm2835_audio_open(struct bcm2835_alsa_stream *alsa_stream) ...@@ -228,7 +228,7 @@ int bcm2835_audio_open(struct bcm2835_alsa_stream *alsa_stream)
goto deinit; goto deinit;
bcm2835_audio_lock(instance); bcm2835_audio_lock(instance);
vchi_get_peer_version(instance->vchi_handle, &instance->peer_version); vchi_get_peer_version(instance->service, &instance->peer_version);
bcm2835_audio_unlock(instance); bcm2835_audio_unlock(instance);
if (instance->peer_version < 2 || force_bulk) if (instance->peer_version < 2 || force_bulk)
instance->max_packet = 0; /* bulk transfer */ instance->max_packet = 0; /* bulk transfer */
...@@ -344,7 +344,7 @@ int bcm2835_audio_write(struct bcm2835_alsa_stream *alsa_stream, ...@@ -344,7 +344,7 @@ int bcm2835_audio_write(struct bcm2835_alsa_stream *alsa_stream,
count = size; count = size;
if (!instance->max_packet) { if (!instance->max_packet) {
/* Send the message to the videocore */ /* Send the message to the videocore */
status = vchi_bulk_queue_transmit(instance->vchi_handle, status = vchi_bulk_queue_transmit(instance->service,
src, count, src, count,
VCHI_FLAGS_BLOCK_UNTIL_DATA_READ, VCHI_FLAGS_BLOCK_UNTIL_DATA_READ,
NULL); NULL);
...@@ -352,7 +352,7 @@ int bcm2835_audio_write(struct bcm2835_alsa_stream *alsa_stream, ...@@ -352,7 +352,7 @@ int bcm2835_audio_write(struct bcm2835_alsa_stream *alsa_stream,
while (count > 0) { while (count > 0) {
int bytes = min(instance->max_packet, count); int bytes = min(instance->max_packet, count);
status = vchi_queue_kernel_message(instance->vchi_handle, status = vchi_queue_kernel_message(instance->service,
src, bytes); src, bytes);
src += bytes; src += bytes;
count -= bytes; count -= bytes;
......
...@@ -53,7 +53,7 @@ struct service_creation { ...@@ -53,7 +53,7 @@ struct service_creation {
struct vchiq_instance; struct vchiq_instance;
// Opaque handle for a server or client // Opaque handle for a server or client
struct vchi_service_handle; struct vchi_service;
/****************************************************************************** /******************************************************************************
* Global funcs - implementation is specific to which side you are on * Global funcs - implementation is specific to which side you are on
...@@ -75,30 +75,27 @@ extern int32_t vchi_disconnect(struct vchiq_instance *instance); ...@@ -75,30 +75,27 @@ extern int32_t vchi_disconnect(struct vchiq_instance *instance);
// Routine to open a named service // Routine to open a named service
extern int32_t vchi_service_open(struct vchiq_instance *instance, extern int32_t vchi_service_open(struct vchiq_instance *instance,
struct service_creation *setup, struct service_creation *setup,
struct vchi_service_handle **handle); struct vchi_service **service);
extern int32_t vchi_get_peer_version(const struct vchi_service_handle *handle, extern int32_t vchi_get_peer_version(struct vchi_service *service,
short *peer_version); short *peer_version);
// Routine to close a named service // Routine to close a named service
extern int32_t vchi_service_close(const struct vchi_service_handle *handle); extern int32_t vchi_service_close(struct vchi_service *service);
// Routine to increment ref count on a named service // Routine to increment ref count on a named service
extern int32_t vchi_service_use(const struct vchi_service_handle *handle); extern int32_t vchi_service_use(struct vchi_service *service);
// Routine to decrement ref count on a named service // Routine to decrement ref count on a named service
extern int32_t vchi_service_release(const struct vchi_service_handle *handle); extern int32_t vchi_service_release(struct vchi_service *service);
/* Routine to send a message from kernel memory across a service */ /* Routine to send a message from kernel memory across a service */
extern int extern int vchi_queue_kernel_message(struct vchi_service *service, void *data,
vchi_queue_kernel_message(struct vchi_service_handle *handle, unsigned int size);
void *data,
unsigned int size);
// Routine to receive a msg from a service // Routine to receive a msg from a service
// Dequeue is equivalent to hold, copy into client buffer, release // Dequeue is equivalent to hold, copy into client buffer, release
extern int32_t vchi_msg_dequeue(struct vchi_service_handle *handle, extern int32_t vchi_msg_dequeue(struct vchi_service *service, void *data,
void *data,
uint32_t max_data_size_to_read, uint32_t max_data_size_to_read,
uint32_t *actual_msg_size, uint32_t *actual_msg_size,
enum vchi_flags flags); enum vchi_flags flags);
...@@ -106,7 +103,7 @@ extern int32_t vchi_msg_dequeue(struct vchi_service_handle *handle, ...@@ -106,7 +103,7 @@ extern int32_t vchi_msg_dequeue(struct vchi_service_handle *handle,
// Routine to look at a message in place. // Routine to look at a message in place.
// The message is dequeued, so the caller is left holding it; the descriptor is // The message is dequeued, so the caller is left holding it; the descriptor is
// filled in and must be released when the user has finished with the message. // filled in and must be released when the user has finished with the message.
extern int32_t vchi_msg_hold(struct vchi_service_handle *handle, extern int32_t vchi_msg_hold(struct vchi_service *service,
void **data, // } may be NULL, as info can be void **data, // } may be NULL, as info can be
uint32_t *msg_size, // } obtained from HELD_MSG_T uint32_t *msg_size, // } obtained from HELD_MSG_T
enum vchi_flags flags, enum vchi_flags flags,
...@@ -125,14 +122,14 @@ extern int32_t vchi_held_msg_release(struct vchi_held_msg *message); ...@@ -125,14 +122,14 @@ extern int32_t vchi_held_msg_release(struct vchi_held_msg *message);
*****************************************************************************/ *****************************************************************************/
// Routine to prepare interface for a transfer from the other side // Routine to prepare interface for a transfer from the other side
extern int32_t vchi_bulk_queue_receive(struct vchi_service_handle *handle, extern int32_t vchi_bulk_queue_receive(struct vchi_service *service,
void *data_dst, void *data_dst,
uint32_t data_size, uint32_t data_size,
enum vchi_flags flags, enum vchi_flags flags,
void *transfer_handle); 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(struct vchi_service_handle *handle, extern int32_t vchi_bulk_queue_transmit(struct vchi_service *service,
const void *data_src, const void *data_src,
uint32_t data_size, uint32_t data_size,
enum vchi_flags flags, enum vchi_flags flags,
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
#include "vchiq_util.h" #include "vchiq_util.h"
struct shim_service { struct vchi_service {
unsigned int handle; unsigned int handle;
struct vchiu_queue queue; struct vchiu_queue queue;
...@@ -18,10 +18,9 @@ struct shim_service { ...@@ -18,10 +18,9 @@ struct shim_service {
void *callback_param; void *callback_param;
}; };
int vchi_queue_kernel_message(struct vchi_service_handle *handle, void *data, int vchi_queue_kernel_message(struct vchi_service *service, void *data,
unsigned int size) unsigned int size)
{ {
struct shim_service *service = (struct shim_service *)handle;
enum vchiq_status status; enum vchiq_status status;
while (1) { while (1) {
...@@ -57,11 +56,10 @@ EXPORT_SYMBOL(vchi_queue_kernel_message); ...@@ -57,11 +56,10 @@ EXPORT_SYMBOL(vchi_queue_kernel_message);
* Returns: int32_t - success == 0 * Returns: int32_t - success == 0
* *
***********************************************************/ ***********************************************************/
int32_t vchi_bulk_queue_receive(struct vchi_service_handle *handle, void *data_dst, int32_t vchi_bulk_queue_receive(struct vchi_service *service, void *data_dst,
uint32_t data_size, enum vchi_flags flags, uint32_t data_size, enum vchi_flags flags,
void *bulk_handle) void *bulk_handle)
{ {
struct shim_service *service = (struct shim_service *)handle;
enum vchiq_bulk_mode mode; enum vchiq_bulk_mode mode;
enum vchiq_status status; enum vchiq_status status;
...@@ -115,13 +113,12 @@ EXPORT_SYMBOL(vchi_bulk_queue_receive); ...@@ -115,13 +113,12 @@ EXPORT_SYMBOL(vchi_bulk_queue_receive);
* Returns: int32_t - success == 0 * Returns: int32_t - success == 0
* *
***********************************************************/ ***********************************************************/
int32_t vchi_bulk_queue_transmit(struct vchi_service_handle *handle, int32_t vchi_bulk_queue_transmit(struct vchi_service *service,
const void *data_src, const void *data_src,
uint32_t data_size, uint32_t data_size,
enum vchi_flags flags, enum vchi_flags flags,
void *bulk_handle) void *bulk_handle)
{ {
struct shim_service *service = (struct shim_service *)handle;
enum vchiq_bulk_mode mode; enum vchiq_bulk_mode mode;
enum vchiq_status status; enum vchiq_status status;
...@@ -166,7 +163,7 @@ EXPORT_SYMBOL(vchi_bulk_queue_transmit); ...@@ -166,7 +163,7 @@ EXPORT_SYMBOL(vchi_bulk_queue_transmit);
/*********************************************************** /***********************************************************
* Name: vchi_msg_dequeue * Name: vchi_msg_dequeue
* *
* Arguments: struct vchi_service_handle *handle, * Arguments: struct vchi_service *service,
* void *data, * void *data,
* uint32_t max_data_size_to_read, * uint32_t max_data_size_to_read,
* uint32_t *actual_msg_size * uint32_t *actual_msg_size
...@@ -177,11 +174,10 @@ EXPORT_SYMBOL(vchi_bulk_queue_transmit); ...@@ -177,11 +174,10 @@ EXPORT_SYMBOL(vchi_bulk_queue_transmit);
* Returns: int32_t - success == 0 * Returns: int32_t - success == 0
* *
***********************************************************/ ***********************************************************/
int32_t vchi_msg_dequeue(struct vchi_service_handle *handle, void *data, int32_t vchi_msg_dequeue(struct vchi_service *service, void *data,
uint32_t max_data_size_to_read, uint32_t max_data_size_to_read,
uint32_t *actual_msg_size, enum vchi_flags flags) uint32_t *actual_msg_size, enum vchi_flags flags)
{ {
struct shim_service *service = (struct shim_service *)handle;
struct vchiq_header *header; struct vchiq_header *header;
WARN_ON((flags != VCHI_FLAGS_NONE) && WARN_ON((flags != VCHI_FLAGS_NONE) &&
...@@ -235,7 +231,7 @@ EXPORT_SYMBOL(vchi_held_msg_release); ...@@ -235,7 +231,7 @@ EXPORT_SYMBOL(vchi_held_msg_release);
/*********************************************************** /***********************************************************
* Name: vchi_msg_hold * Name: vchi_msg_hold
* *
* Arguments: struct vchi_service_handle *handle, * Arguments: struct vchi_service *service,
* void **data, * void **data,
* uint32_t *msg_size, * uint32_t *msg_size,
* enum vchi_flags flags, * enum vchi_flags flags,
...@@ -249,11 +245,10 @@ EXPORT_SYMBOL(vchi_held_msg_release); ...@@ -249,11 +245,10 @@ EXPORT_SYMBOL(vchi_held_msg_release);
* Returns: int32_t - success == 0 * Returns: int32_t - success == 0
* *
***********************************************************/ ***********************************************************/
int32_t vchi_msg_hold(struct vchi_service_handle *handle, void **data, int32_t vchi_msg_hold(struct vchi_service *service, void **data,
uint32_t *msg_size, enum vchi_flags flags, uint32_t *msg_size, enum vchi_flags flags,
struct vchi_held_msg *message_handle) struct vchi_held_msg *message_handle)
{ {
struct shim_service *service = (struct shim_service *)handle;
struct vchiq_header *header; struct vchiq_header *header;
WARN_ON((flags != VCHI_FLAGS_NONE) && WARN_ON((flags != VCHI_FLAGS_NONE) &&
...@@ -343,7 +338,7 @@ EXPORT_SYMBOL(vchi_disconnect); ...@@ -343,7 +338,7 @@ EXPORT_SYMBOL(vchi_disconnect);
* *
* Arguments: struct vchiq_instance *instance * Arguments: struct vchiq_instance *instance
* struct service_creation *setup, * struct service_creation *setup,
* struct vchi_service_handle **handle * struct vchi_service **service
* *
* Description: Routine to open a service * Description: Routine to open a service
* *
...@@ -356,8 +351,8 @@ static enum vchiq_status shim_callback(enum vchiq_reason reason, ...@@ -356,8 +351,8 @@ static enum vchiq_status shim_callback(enum vchiq_reason reason,
unsigned int handle, unsigned int handle,
void *bulk_user) void *bulk_user)
{ {
struct shim_service *service = struct vchi_service *service =
(struct shim_service *)VCHIQ_GET_SERVICE_USERDATA(handle); (struct vchi_service *)VCHIQ_GET_SERVICE_USERDATA(handle);
if (!service->callback) if (!service->callback)
goto release; goto release;
...@@ -407,10 +402,10 @@ static enum vchiq_status shim_callback(enum vchiq_reason reason, ...@@ -407,10 +402,10 @@ static enum vchiq_status shim_callback(enum vchiq_reason reason,
return VCHIQ_SUCCESS; return VCHIQ_SUCCESS;
} }
static struct shim_service *service_alloc(struct vchiq_instance *instance, static struct vchi_service *service_alloc(struct vchiq_instance *instance,
struct service_creation *setup) struct service_creation *setup)
{ {
struct shim_service *service = kzalloc(sizeof(struct shim_service), GFP_KERNEL); struct vchi_service *service = kzalloc(sizeof(struct vchi_service), GFP_KERNEL);
(void)instance; (void)instance;
...@@ -427,7 +422,7 @@ static struct shim_service *service_alloc(struct vchiq_instance *instance, ...@@ -427,7 +422,7 @@ static struct shim_service *service_alloc(struct vchiq_instance *instance,
return service; return service;
} }
static void service_free(struct shim_service *service) static void service_free(struct vchi_service *service)
{ {
if (service) { if (service) {
vchiu_queue_delete(&service->queue); vchiu_queue_delete(&service->queue);
...@@ -437,40 +432,36 @@ static void service_free(struct shim_service *service) ...@@ -437,40 +432,36 @@ static void service_free(struct shim_service *service)
int32_t vchi_service_open(struct vchiq_instance *instance, int32_t vchi_service_open(struct vchiq_instance *instance,
struct service_creation *setup, struct service_creation *setup,
struct vchi_service_handle **handle) struct vchi_service **service)
{ {
struct shim_service *service = service_alloc(instance, setup);
*handle = (struct vchi_service_handle *)service; *service = service_alloc(instance, setup);
if (*service) {
if (service) {
struct vchiq_service_params params; struct vchiq_service_params params;
enum vchiq_status status; enum vchiq_status status;
memset(&params, 0, sizeof(params)); memset(&params, 0, sizeof(params));
params.fourcc = setup->service_id; params.fourcc = setup->service_id;
params.callback = shim_callback; params.callback = shim_callback;
params.userdata = service; params.userdata = *service;
params.version = setup->version.version; params.version = setup->version.version;
params.version_min = setup->version.version_min; params.version_min = setup->version.version_min;
status = vchiq_open_service(instance, &params, status = vchiq_open_service(instance, &params,
&service->handle); &((*service)->handle));
if (status != VCHIQ_SUCCESS) { if (status != VCHIQ_SUCCESS) {
service_free(service); service_free(*service);
service = NULL; *service = NULL;
*handle = NULL;
} }
} }
return service ? 0 : -1; return *service ? 0 : -1;
} }
EXPORT_SYMBOL(vchi_service_open); EXPORT_SYMBOL(vchi_service_open);
int32_t vchi_service_close(const struct vchi_service_handle *handle) int32_t vchi_service_close(struct vchi_service *service)
{ {
int32_t ret = -1; int32_t ret = -1;
struct shim_service *service = (struct shim_service *)handle;
if (service) { if (service) {
enum vchiq_status status = vchiq_close_service(service->handle); enum vchiq_status status = vchiq_close_service(service->handle);
...@@ -483,10 +474,9 @@ int32_t vchi_service_close(const struct vchi_service_handle *handle) ...@@ -483,10 +474,9 @@ int32_t vchi_service_close(const struct vchi_service_handle *handle)
} }
EXPORT_SYMBOL(vchi_service_close); EXPORT_SYMBOL(vchi_service_close);
int32_t vchi_get_peer_version(const struct vchi_service_handle *handle, short *peer_version) int32_t vchi_get_peer_version(struct vchi_service *service, short *peer_version)
{ {
int32_t ret = -1; int32_t ret = -1;
struct shim_service *service = (struct shim_service *)handle;
if (service) { if (service) {
enum vchiq_status status; enum vchiq_status status;
...@@ -501,18 +491,17 @@ EXPORT_SYMBOL(vchi_get_peer_version); ...@@ -501,18 +491,17 @@ EXPORT_SYMBOL(vchi_get_peer_version);
/*********************************************************** /***********************************************************
* Name: vchi_service_use * Name: vchi_service_use
* *
* Arguments: const struct vchi_service_handle *handle * Arguments: struct vchi_service *service
* *
* Description: Routine to increment refcount on a service * Description: Routine to increment refcount on a service
* *
* Returns: void * Returns: void
* *
***********************************************************/ ***********************************************************/
int32_t vchi_service_use(const struct vchi_service_handle *handle) int32_t vchi_service_use(struct vchi_service *service)
{ {
int32_t ret = -1; int32_t ret = -1;
struct shim_service *service = (struct shim_service *)handle;
if (service) if (service)
ret = vchiq_use_service(service->handle); ret = vchiq_use_service(service->handle);
return ret; return ret;
...@@ -522,18 +511,17 @@ EXPORT_SYMBOL(vchi_service_use); ...@@ -522,18 +511,17 @@ EXPORT_SYMBOL(vchi_service_use);
/*********************************************************** /***********************************************************
* Name: vchi_service_release * Name: vchi_service_release
* *
* Arguments: const struct vchi_service_handle *handle * Arguments: struct vchi_service *service
* *
* Description: Routine to decrement refcount on a service * Description: Routine to decrement refcount on a service
* *
* Returns: void * Returns: void
* *
***********************************************************/ ***********************************************************/
int32_t vchi_service_release(const struct vchi_service_handle *handle) int32_t vchi_service_release(struct vchi_service *service)
{ {
int32_t ret = -1; int32_t ret = -1;
struct shim_service *service = (struct shim_service *)handle;
if (service) if (service)
ret = vchiq_release_service(service->handle); ret = vchiq_release_service(service->handle);
return ret; return ret;
......
...@@ -165,7 +165,7 @@ struct mmal_msg_context { ...@@ -165,7 +165,7 @@ struct mmal_msg_context {
}; };
struct vchiq_mmal_instance { struct vchiq_mmal_instance {
struct vchi_service_handle *handle; struct vchi_service *service;
/* ensure serialised access to service */ /* ensure serialised access to service */
struct mutex vchiq_mutex; struct mutex vchiq_mutex;
...@@ -294,8 +294,8 @@ static void buffer_to_host_work_cb(struct work_struct *work) ...@@ -294,8 +294,8 @@ static void buffer_to_host_work_cb(struct work_struct *work)
/* Dummy receive to ensure the buffers remain in order */ /* Dummy receive to ensure the buffers remain in order */
len = 8; len = 8;
/* queue the bulk submission */ /* queue the bulk submission */
vchi_service_use(instance->handle); vchi_service_use(instance->service);
ret = vchi_bulk_queue_receive(instance->handle, ret = vchi_bulk_queue_receive(instance->service,
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
...@@ -305,7 +305,7 @@ static void buffer_to_host_work_cb(struct work_struct *work) ...@@ -305,7 +305,7 @@ static void buffer_to_host_work_cb(struct work_struct *work)
VCHI_FLAGS_BLOCK_UNTIL_QUEUED, VCHI_FLAGS_BLOCK_UNTIL_QUEUED,
msg_context); msg_context);
vchi_service_release(instance->handle); vchi_service_release(instance->service);
if (ret != 0) if (ret != 0)
pr_err("%s: ctx: %p, vchi_bulk_queue_receive failed %d\n", pr_err("%s: ctx: %p, vchi_bulk_queue_receive failed %d\n",
...@@ -384,7 +384,7 @@ buffer_from_host(struct vchiq_mmal_instance *instance, ...@@ -384,7 +384,7 @@ buffer_from_host(struct vchiq_mmal_instance *instance,
if (!port->enabled) if (!port->enabled)
return -EINVAL; return -EINVAL;
pr_debug("instance:%p buffer:%p\n", instance->handle, buf); pr_debug("instance:%p buffer:%p\n", instance->service, buf);
/* get context */ /* get context */
if (!buf->msg_context) { if (!buf->msg_context) {
...@@ -439,14 +439,14 @@ buffer_from_host(struct vchiq_mmal_instance *instance, ...@@ -439,14 +439,14 @@ buffer_from_host(struct vchiq_mmal_instance *instance,
/* no payload in message */ /* no payload in message */
m.u.buffer_from_host.payload_in_message = 0; m.u.buffer_from_host.payload_in_message = 0;
vchi_service_use(instance->handle); vchi_service_use(instance->service);
ret = vchi_queue_kernel_message(instance->handle, ret = vchi_queue_kernel_message(instance->service,
&m, &m,
sizeof(struct mmal_msg_header) + sizeof(struct mmal_msg_header) +
sizeof(m.u.buffer_from_host)); sizeof(m.u.buffer_from_host));
vchi_service_release(instance->handle); vchi_service_release(instance->service);
return ret; return ret;
} }
...@@ -568,7 +568,7 @@ static void service_callback(void *param, ...@@ -568,7 +568,7 @@ static void service_callback(void *param,
switch (reason) { switch (reason) {
case VCHI_CALLBACK_MSG_AVAILABLE: case VCHI_CALLBACK_MSG_AVAILABLE:
status = vchi_msg_hold(instance->handle, (void **)&msg, status = vchi_msg_hold(instance->service, (void **)&msg,
&msg_len, VCHI_FLAGS_NONE, &msg_handle); &msg_len, VCHI_FLAGS_NONE, &msg_handle);
if (status) { if (status) {
pr_err("Unable to dequeue a message (%d)\n", status); pr_err("Unable to dequeue a message (%d)\n", status);
...@@ -684,14 +684,14 @@ static int send_synchronous_mmal_msg(struct vchiq_mmal_instance *instance, ...@@ -684,14 +684,14 @@ static int send_synchronous_mmal_msg(struct vchiq_mmal_instance *instance,
DBG_DUMP_MSG(msg, (sizeof(struct mmal_msg_header) + payload_len), DBG_DUMP_MSG(msg, (sizeof(struct mmal_msg_header) + payload_len),
">>> sync message"); ">>> sync message");
vchi_service_use(instance->handle); vchi_service_use(instance->service);
ret = vchi_queue_kernel_message(instance->handle, ret = vchi_queue_kernel_message(instance->service,
msg, msg,
sizeof(struct mmal_msg_header) + sizeof(struct mmal_msg_header) +
payload_len); payload_len);
vchi_service_release(instance->handle); vchi_service_release(instance->service);
if (ret) { if (ret) {
pr_err("error %d queuing message\n", ret); pr_err("error %d queuing message\n", ret);
...@@ -1839,9 +1839,9 @@ int vchiq_mmal_finalise(struct vchiq_mmal_instance *instance) ...@@ -1839,9 +1839,9 @@ int vchiq_mmal_finalise(struct vchiq_mmal_instance *instance)
if (mutex_lock_interruptible(&instance->vchiq_mutex)) if (mutex_lock_interruptible(&instance->vchiq_mutex))
return -EINTR; return -EINTR;
vchi_service_use(instance->handle); vchi_service_use(instance->service);
status = vchi_service_close(instance->handle); status = vchi_service_close(instance->service);
if (status != 0) if (status != 0)
pr_err("mmal-vchiq: VCHIQ close failed\n"); pr_err("mmal-vchiq: VCHIQ close failed\n");
...@@ -1918,21 +1918,21 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance) ...@@ -1918,21 +1918,21 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance)
if (!instance->bulk_wq) if (!instance->bulk_wq)
goto err_free; goto err_free;
status = vchi_service_open(vchiq_instance, &params, &instance->handle); status = vchi_service_open(vchiq_instance, &params, &instance->service);
if (status) { if (status) {
pr_err("Failed to open VCHI service connection (status=%d)\n", pr_err("Failed to open VCHI service connection (status=%d)\n",
status); status);
goto err_close_services; goto err_close_services;
} }
vchi_service_release(instance->handle); vchi_service_release(instance->service);
*out_instance = instance; *out_instance = instance;
return 0; return 0;
err_close_services: err_close_services:
vchi_service_close(instance->handle); vchi_service_close(instance->service);
destroy_workqueue(instance->bulk_wq); destroy_workqueue(instance->bulk_wq);
err_free: err_free:
vfree(instance->bulk_scratch); vfree(instance->bulk_scratch);
......
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