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

staging: vchiq: Get rid of vchi

All the functions that vchi currently provides are a 1:1 mapping to its
vchiq counterparts. Get rid of vchi altogether and use vchiq's on all
services.

In the process also get rid of the vchi directory, as the only remaining
file was a TODO file, which now lives in the parent directory.
Signed-off-by: default avatarNicolas Saenz Julienne <nsaenzjulienne@suse.de>
Link: https://lore.kernel.org/r/20200629150945.10720-44-nsaenzjulienne@suse.deSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 5c01fc5c
...@@ -6,7 +6,6 @@ vchiq-objs := \ ...@@ -6,7 +6,6 @@ vchiq-objs := \
interface/vchiq_arm/vchiq_arm.o \ interface/vchiq_arm/vchiq_arm.o \
interface/vchiq_arm/vchiq_2835_arm.o \ interface/vchiq_arm/vchiq_2835_arm.o \
interface/vchiq_arm/vchiq_debugfs.o \ interface/vchiq_arm/vchiq_debugfs.o \
interface/vchiq_arm/vchiq_shim.o \
interface/vchiq_arm/vchiq_connected.o \ interface/vchiq_arm/vchiq_connected.o \
obj-$(CONFIG_SND_BCM2835) += bcm2835-audio/ obj-$(CONFIG_SND_BCM2835) += bcm2835-audio/
......
...@@ -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->service_handle); vchiq_use_service(instance->service_handle);
} }
static void bcm2835_audio_unlock(struct bcm2835_audio_instance *instance) static void bcm2835_audio_unlock(struct bcm2835_audio_instance *instance)
{ {
vchi_service_release(instance->service_handle); vchiq_release_service(instance->service_handle);
mutex_unlock(&instance->vchi_mutex); mutex_unlock(&instance->vchi_mutex);
} }
...@@ -132,8 +132,8 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance, ...@@ -132,8 +132,8 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance,
int status; int status;
/* Open the VCHI service connections */ /* Open the VCHI service connections */
status = vchi_service_open(vchiq_instance, &params, status = vchiq_open_service(vchiq_instance, &params,
&instance->service_handle); &instance->service_handle);
if (status) { if (status) {
dev_err(instance->dev, dev_err(instance->dev,
...@@ -143,7 +143,7 @@ vc_vchi_audio_init(struct vchiq_instance *vchiq_instance, ...@@ -143,7 +143,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->service_handle); vchiq_release_service(instance->service_handle);
return 0; return 0;
} }
...@@ -153,10 +153,10 @@ static void vc_vchi_audio_deinit(struct bcm2835_audio_instance *instance) ...@@ -153,10 +153,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->service_handle); vchiq_use_service(instance->service_handle);
/* Close all VCHI service connections */ /* Close all VCHI service connections */
status = vchi_service_close(instance->service_handle); status = vchiq_close_service(instance->service_handle);
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",
...@@ -171,14 +171,14 @@ int bcm2835_new_vchi_ctx(struct device *dev, struct bcm2835_vchi_ctx *vchi_ctx) ...@@ -171,14 +171,14 @@ int bcm2835_new_vchi_ctx(struct device *dev, struct bcm2835_vchi_ctx *vchi_ctx)
int ret; int ret;
/* Initialize and create a VCHI connection */ /* Initialize and create a VCHI connection */
ret = vchi_initialise(&vchi_ctx->instance); ret = vchiq_initialise(&vchi_ctx->instance);
if (ret) { if (ret) {
dev_err(dev, "failed to initialise VCHI instance (ret=%d)\n", dev_err(dev, "failed to initialise VCHI instance (ret=%d)\n",
ret); ret);
return -EIO; return -EIO;
} }
ret = vchi_connect(vchi_ctx->instance); ret = vchiq_connect(vchi_ctx->instance);
if (ret) { if (ret) {
dev_dbg(dev, "failed to connect VCHI instance (ret=%d)\n", dev_dbg(dev, "failed to connect VCHI instance (ret=%d)\n",
ret); ret);
...@@ -195,7 +195,7 @@ int bcm2835_new_vchi_ctx(struct device *dev, struct bcm2835_vchi_ctx *vchi_ctx) ...@@ -195,7 +195,7 @@ int bcm2835_new_vchi_ctx(struct device *dev, struct bcm2835_vchi_ctx *vchi_ctx)
void bcm2835_free_vchi_ctx(struct bcm2835_vchi_ctx *vchi_ctx) void bcm2835_free_vchi_ctx(struct bcm2835_vchi_ctx *vchi_ctx)
{ {
/* Close the VCHI connection - it will also free vchi_ctx->instance */ /* Close the VCHI connection - it will also free vchi_ctx->instance */
WARN_ON(vchi_disconnect(vchi_ctx->instance)); WARN_ON(vchiq_shutdown(vchi_ctx->instance));
vchi_ctx->instance = NULL; vchi_ctx->instance = NULL;
} }
...@@ -226,8 +226,8 @@ int bcm2835_audio_open(struct bcm2835_alsa_stream *alsa_stream) ...@@ -226,8 +226,8 @@ 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->service_handle, vchiq_get_peer_version(instance->service_handle,
&instance->peer_version); &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 */
......
...@@ -10,7 +10,6 @@ ...@@ -10,7 +10,6 @@
#include <sound/pcm.h> #include <sound/pcm.h>
#include <sound/pcm-indirect.h> #include <sound/pcm-indirect.h>
#include "interface/vchiq_arm/vchiq_if.h" #include "interface/vchiq_arm/vchiq_if.h"
#include "interface/vchi/vchi.h"
#define MAX_SUBSTREAMS (8) #define MAX_SUBSTREAMS (8)
#define AVAIL_SUBSTREAMS_MASK (0xff) #define AVAIL_SUBSTREAMS_MASK (0xff)
......
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
/* Copyright (c) 2010-2012 Broadcom. All rights reserved. */
#ifndef VCHI_H_
#define VCHI_H_
/******************************************************************************
* Global funcs - implementation is specific to which side you are on
* (local / remote)
*****************************************************************************/
// Routine used to initialise the vchi on both local + remote connections
extern int32_t vchi_initialise(struct vchiq_instance **instance);
extern int32_t vchi_connect(struct vchiq_instance *instance);
//When this is called, ensure that all services have no data pending.
//Bulk transfers can remain 'queued'
extern int32_t vchi_disconnect(struct vchiq_instance *instance);
/******************************************************************************
* Global service API
*****************************************************************************/
// Routine to open a named service
extern int vchi_service_open(struct vchiq_instance *instance,
struct vchiq_service_params *params,
unsigned *handle);
extern int32_t vchi_get_peer_version(unsigned handle, short *peer_version);
// Routine to close a named service
extern int32_t vchi_service_close(unsigned handle);
// Routine to increment ref count on a named service
extern int32_t vchi_service_use(unsigned handle);
// Routine to decrement ref count on a named service
extern int32_t vchi_service_release(unsigned handle);
// Routine to look at a message in place.
// 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.
struct vchiq_header *vchi_msg_hold(unsigned handle);
/*******************************************************************************
* Global service support API - operations on held messages
* and message iterators
******************************************************************************/
// Routine to release a held message after it has been processed
extern int32_t vchi_held_msg_release(unsigned handle, struct vchiq_header *message);
/******************************************************************************
* Configuration plumbing
*****************************************************************************/
#endif /* VCHI_H_ */
/****************************** End of file **********************************/
...@@ -2572,6 +2572,7 @@ vchiq_use_service(unsigned int handle) ...@@ -2572,6 +2572,7 @@ vchiq_use_service(unsigned int handle)
} }
return ret; return ret;
} }
EXPORT_SYMBOL(vchiq_use_service);
enum vchiq_status enum vchiq_status
vchiq_release_service(unsigned int handle) vchiq_release_service(unsigned int handle)
...@@ -2585,6 +2586,7 @@ vchiq_release_service(unsigned int handle) ...@@ -2585,6 +2586,7 @@ vchiq_release_service(unsigned int handle)
} }
return ret; return ret;
} }
EXPORT_SYMBOL(vchiq_release_service);
struct service_data_struct { struct service_data_struct {
int fourcc; int fourcc;
......
...@@ -2946,6 +2946,7 @@ vchiq_close_service(unsigned int handle) ...@@ -2946,6 +2946,7 @@ vchiq_close_service(unsigned int handle)
return status; return status;
} }
EXPORT_SYMBOL(vchiq_close_service);
enum vchiq_status enum vchiq_status
vchiq_remove_service(unsigned int handle) vchiq_remove_service(unsigned int handle)
...@@ -3268,6 +3269,7 @@ vchiq_release_message(unsigned int handle, ...@@ -3268,6 +3269,7 @@ vchiq_release_message(unsigned int handle,
unlock_service(service); unlock_service(service);
} }
EXPORT_SYMBOL(vchiq_release_message);
static void static void
release_message_sync(struct vchiq_state *state, struct vchiq_header *header) release_message_sync(struct vchiq_state *state, struct vchiq_header *header)
...@@ -3294,6 +3296,7 @@ vchiq_get_peer_version(unsigned int handle, short *peer_version) ...@@ -3294,6 +3296,7 @@ vchiq_get_peer_version(unsigned int handle, short *peer_version)
unlock_service(service); unlock_service(service);
return status; return status;
} }
EXPORT_SYMBOL(vchiq_get_peer_version);
void vchiq_get_config(struct vchiq_config *config) void vchiq_get_config(struct vchiq_config *config)
{ {
......
// SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
/* Copyright (c) 2010-2012 Broadcom. All rights reserved. */
#include <linux/module.h>
#include <linux/types.h>
#include <linux/slab.h>
#include <linux/delay.h>
#include "vchiq_if.h"
#include "../vchi/vchi.h"
#include "vchiq.h"
/***********************************************************
* Name: vchi_held_msg_release
*
* Arguments: unsgined handle
* struct vchiq_header *message
*
* Description: Routine to release a held message (after it has been read with
* vchi_msg_hold)
*
* Returns: int - success == 0
*
***********************************************************/
int vchi_held_msg_release(unsigned handle, struct vchiq_header *message)
{
/*
* Convert the service field pointer back to an
* unsigned int which is an int.
* This pointer is opaque to everything except
* vchi_msg_hold which simply upcasted the int
* to a pointer.
*/
vchiq_release_message(handle, message);
return 0;
}
EXPORT_SYMBOL(vchi_held_msg_release);
/***********************************************************
* Name: vchi_msg_hold
*
* Arguments: struct vchi_service *service,
* void **data,
* unsigned *msg_size,
* struct vchiq_header **message
*
* Description: Routine to return a pointer to the current message (to allow
* in place processing). The message is dequeued - don't forget
* to release the message using vchi_held_msg_release when you're
* finished.
*
* Returns: int - success == 0
*
***********************************************************/
struct vchiq_header *vchi_msg_hold(unsigned handle)
{
return vchiq_msg_hold(handle);
}
EXPORT_SYMBOL(vchi_msg_hold);
/***********************************************************
* Name: vchi_initialise
*
* Arguments: struct vchiq_instance **instance
*
* Description: Initialises the hardware but does not transmit anything
* When run as a Host App this will be called twice hence the need
* to malloc the state information
*
* Returns: 0 if successful, failure otherwise
*
***********************************************************/
int vchi_initialise(struct vchiq_instance **instance)
{
return vchiq_initialise(instance);
}
EXPORT_SYMBOL(vchi_initialise);
/***********************************************************
* Name: vchi_connect
*
* Arguments: struct vchiq_instance *instance
*
* Description: Starts the command service on each connection,
* causing INIT messages to be pinged back and forth
*
* Returns: 0 if successful, failure otherwise
*
***********************************************************/
int vchi_connect(struct vchiq_instance *instance)
{
return vchiq_connect(instance);
}
EXPORT_SYMBOL(vchi_connect);
/***********************************************************
* Name: vchi_disconnect
*
* Arguments: struct vchiq_instance *instance
*
* Description: Stops the command service on each connection,
* causing DE-INIT messages to be pinged back and forth
*
* Returns: 0 if successful, failure otherwise
*
***********************************************************/
int vchi_disconnect(struct vchiq_instance *instance)
{
return vchiq_shutdown(instance);
}
EXPORT_SYMBOL(vchi_disconnect);
/***********************************************************
* Name: vchi_service_open
* Name: vchi_service_create
*
* Arguments: struct vchiq_instance *instance
* struct service_creation *setup,
* unsigned *handle
*
* Description: Routine to open a service
*
* Returns: int - success == 0
*
***********************************************************/
int vchi_service_open(struct vchiq_instance *instance,
struct vchiq_service_params *params,
unsigned *handle)
{
return vchiq_open_service(instance, params, handle);
}
EXPORT_SYMBOL(vchi_service_open);
int vchi_service_close(unsigned handle)
{
return vchiq_close_service(handle);
}
EXPORT_SYMBOL(vchi_service_close);
int vchi_get_peer_version(unsigned handle, short *peer_version)
{
return vchiq_get_peer_version(handle, peer_version);
}
EXPORT_SYMBOL(vchi_get_peer_version);
/***********************************************************
* Name: vchi_service_use
*
* Arguments: unsigned handle
*
* Description: Routine to increment refcount on a service
*
* Returns: void
*
***********************************************************/
int vchi_service_use(unsigned handle)
{
return vchiq_use_service(handle);
}
EXPORT_SYMBOL(vchi_service_use);
/***********************************************************
* Name: vchi_service_release
*
* Arguments: unsigned handle
*
* Description: Routine to decrement refcount on a service
*
* Returns: void
*
***********************************************************/
int vchi_service_release(unsigned handle)
{
return vchiq_release_service(handle);
}
EXPORT_SYMBOL(vchi_service_release);
...@@ -30,7 +30,6 @@ ...@@ -30,7 +30,6 @@
#include "mmal-msg.h" #include "mmal-msg.h"
#include "interface/vchiq_arm/vchiq_if.h" #include "interface/vchiq_arm/vchiq_if.h"
#include "interface/vchi/vchi.h"
/* /*
* maximum number of components supported. * maximum number of components supported.
...@@ -294,7 +293,7 @@ static void buffer_to_host_work_cb(struct work_struct *work) ...@@ -294,7 +293,7 @@ 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->service_handle); vchiq_use_service(instance->service_handle);
ret = vchiq_bulk_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
...@@ -304,7 +303,7 @@ static void buffer_to_host_work_cb(struct work_struct *work) ...@@ -304,7 +303,7 @@ static void buffer_to_host_work_cb(struct work_struct *work)
msg_context, msg_context,
VCHIQ_BULK_MODE_CALLBACK); VCHIQ_BULK_MODE_CALLBACK);
vchi_service_release(instance->service_handle); vchiq_release_service(instance->service_handle);
if (ret != 0) if (ret != 0)
pr_err("%s: ctx: %p, vchiq_bulk_receive failed %d\n", pr_err("%s: ctx: %p, vchiq_bulk_receive failed %d\n",
...@@ -438,13 +437,13 @@ buffer_from_host(struct vchiq_mmal_instance *instance, ...@@ -438,13 +437,13 @@ 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->service_handle); vchiq_use_service(instance->service_handle);
ret = vchiq_queue_kernel_message(instance->service_handle, &m, ret = vchiq_queue_kernel_message(instance->service_handle, &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->service_handle); vchiq_release_service(instance->service_handle);
return ret; return ret;
} }
...@@ -678,13 +677,13 @@ static int send_synchronous_mmal_msg(struct vchiq_mmal_instance *instance, ...@@ -678,13 +677,13 @@ 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->service_handle); vchiq_use_service(instance->service_handle);
ret = vchiq_queue_kernel_message(instance->service_handle, msg, ret = vchiq_queue_kernel_message(instance->service_handle, msg,
sizeof(struct mmal_msg_header) + sizeof(struct mmal_msg_header) +
payload_len); payload_len);
vchi_service_release(instance->service_handle); vchiq_release_service(instance->service_handle);
if (ret) { if (ret) {
pr_err("error %d queuing message\n", ret); pr_err("error %d queuing message\n", ret);
...@@ -1832,9 +1831,9 @@ int vchiq_mmal_finalise(struct vchiq_mmal_instance *instance) ...@@ -1832,9 +1831,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->service_handle); vchiq_use_service(instance->service_handle);
status = vchi_service_close(instance->service_handle); status = vchiq_close_service(instance->service_handle);
if (status != 0) if (status != 0)
pr_err("mmal-vchiq: VCHIQ close failed\n"); pr_err("mmal-vchiq: VCHIQ close failed\n");
...@@ -1880,14 +1879,14 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance) ...@@ -1880,14 +1879,14 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance)
BUILD_BUG_ON(sizeof(struct mmal_port) != 64); BUILD_BUG_ON(sizeof(struct mmal_port) != 64);
/* create a vchi instance */ /* create a vchi instance */
status = vchi_initialise(&vchiq_instance); status = vchiq_initialise(&vchiq_instance);
if (status) { if (status) {
pr_err("Failed to initialise VCHI instance (status=%d)\n", pr_err("Failed to initialise VCHI instance (status=%d)\n",
status); status);
return -EIO; return -EIO;
} }
status = vchi_connect(vchiq_instance); status = vchiq_connect(vchiq_instance);
if (status) { if (status) {
pr_err("Failed to connect VCHI instance (status=%d)\n", status); pr_err("Failed to connect VCHI instance (status=%d)\n", status);
return -EIO; return -EIO;
...@@ -1912,22 +1911,22 @@ int vchiq_mmal_init(struct vchiq_mmal_instance **out_instance) ...@@ -1912,22 +1911,22 @@ 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, status = vchiq_open_service(vchiq_instance, &params,
&instance->service_handle); &instance->service_handle);
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->service_handle); vchiq_release_service(instance->service_handle);
*out_instance = instance; *out_instance = instance;
return 0; return 0;
err_close_services: err_close_services:
vchi_service_close(instance->service_handle); vchiq_close_service(instance->service_handle);
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