mirror of
https://github.com/smaeul/u-boot.git
synced 2025-10-24 09:38:18 +01:00
Sometimes mbox controllers wants to store private data in mbox_chan so that it can be used at a later point of time. Adding support for hooking private data. Reviewed-by: Tom Rini <trini@konsulko.com> Signed-off-by: Lokesh Vutla <lokeshvutla@ti.com>
148 lines
6.0 KiB
C
148 lines
6.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2016, NVIDIA CORPORATION.
|
|
*/
|
|
|
|
#ifndef _MAILBOX_H
|
|
#define _MAILBOX_H
|
|
|
|
/**
|
|
* A mailbox is a hardware mechanism for transferring small fixed-size messages
|
|
* and/or notifications between the CPU on which U-Boot runs and some other
|
|
* device such as an auxiliary CPU running firmware or a hardware module.
|
|
*
|
|
* Data transfer is optional; a mailbox may consist solely of a notification
|
|
* mechanism. When data transfer is implemented, it is via HW registers or
|
|
* FIFOs, rather than via RAM-based buffers. The mailbox API generally
|
|
* implements any communication protocol enforced solely by hardware, and
|
|
* leaves any higher-level protocols to other layers.
|
|
*
|
|
* A mailbox channel is a bi-directional mechanism that can send a message or
|
|
* notification to a single specific remote entity, and receive messages or
|
|
* notifications from that entity. The size, content, and format of such
|
|
* messages is defined by the mailbox implementation, or the remote entity with
|
|
* which it communicates; there is no general standard at this API level.
|
|
*
|
|
* A driver that implements UCLASS_MAILBOX is a mailbox provider. A provider
|
|
* will often implement multiple separate mailbox channels, since the hardware
|
|
* it manages often has this capability. mailbox-uclass.h describes the
|
|
* interface which mailbox providers must implement.
|
|
*
|
|
* Mailbox consumers/clients generate and send, or receive and process,
|
|
* messages. This header file describes the API used by clients.
|
|
*/
|
|
|
|
struct udevice;
|
|
|
|
/**
|
|
* struct mbox_chan - A handle to a single mailbox channel.
|
|
*
|
|
* Clients provide storage for channels. The content of the channel structure
|
|
* is managed solely by the mailbox API and mailbox drivers. A mailbox channel
|
|
* is initialized by "get"ing the mailbox. The channel struct is passed to all
|
|
* other mailbox APIs to identify which mailbox to operate upon.
|
|
*
|
|
* @dev: The device which implements the mailbox.
|
|
* @id: The mailbox channel ID within the provider.
|
|
* @con_priv: Hook for controller driver to attach private data
|
|
*
|
|
* Currently, the mailbox API assumes that a single integer ID is enough to
|
|
* identify and configure any mailbox channel for any mailbox provider. If this
|
|
* assumption becomes invalid in the future, the struct could be expanded to
|
|
* either (a) add more fields to allow mailbox providers to store additional
|
|
* information, or (b) replace the id field with an opaque pointer, which the
|
|
* provider would dynamically allocated during its .of_xlate op, and process
|
|
* during is .request op. This may require the addition of an extra op to clean
|
|
* up the allocation.
|
|
*/
|
|
struct mbox_chan {
|
|
struct udevice *dev;
|
|
/* Written by of_xlate.*/
|
|
unsigned long id;
|
|
void *con_priv;
|
|
};
|
|
|
|
/**
|
|
* mbox_get_by_index - Get/request a mailbox by integer index
|
|
*
|
|
* This looks up and requests a mailbox channel. The index is relative to the
|
|
* client device; each device is assumed to have n mailbox channels associated
|
|
* with it somehow, and this function finds and requests one of them. The
|
|
* mapping of client device channel indices to provider channels may be via
|
|
* device-tree properties, board-provided mapping tables, or some other
|
|
* mechanism.
|
|
*
|
|
* @dev: The client device.
|
|
* @index: The index of the mailbox channel to request, within the
|
|
* client's list of channels.
|
|
* @chan A pointer to a channel object to initialize.
|
|
* @return 0 if OK, or a negative error code.
|
|
*/
|
|
int mbox_get_by_index(struct udevice *dev, int index, struct mbox_chan *chan);
|
|
|
|
/**
|
|
* mbox_get_by_name - Get/request a mailbox by name
|
|
*
|
|
* This looks up and requests a mailbox channel. The name is relative to the
|
|
* client device; each device is assumed to have n mailbox channels associated
|
|
* with it somehow, and this function finds and requests one of them. The
|
|
* mapping of client device channel names to provider channels may be via
|
|
* device-tree properties, board-provided mapping tables, or some other
|
|
* mechanism.
|
|
*
|
|
* @dev: The client device.
|
|
* @name: The name of the mailbox channel to request, within the client's
|
|
* list of channels.
|
|
* @chan A pointer to a channel object to initialize.
|
|
* @return 0 if OK, or a negative error code.
|
|
*/
|
|
int mbox_get_by_name(struct udevice *dev, const char *name,
|
|
struct mbox_chan *chan);
|
|
|
|
/**
|
|
* mbox_free - Free a previously requested mailbox channel.
|
|
*
|
|
* @chan: A channel object that was previously successfully requested by
|
|
* calling mbox_get_by_*().
|
|
* @return 0 if OK, or a negative error code.
|
|
*/
|
|
int mbox_free(struct mbox_chan *chan);
|
|
|
|
/**
|
|
* mbox_send - Send a message over a mailbox channel
|
|
*
|
|
* This function will send a message to the remote entity. It may return before
|
|
* the remote entity has received and/or processed the message.
|
|
*
|
|
* @chan: A channel object that was previously successfully requested by
|
|
* calling mbox_get_by_*().
|
|
* @data: A pointer to the message to transfer. The format and size of
|
|
* the memory region pointed at by @data is determined by the
|
|
* mailbox provider. Providers that solely transfer notifications
|
|
* will ignore this parameter.
|
|
* @return 0 if OK, or a negative error code.
|
|
*/
|
|
int mbox_send(struct mbox_chan *chan, const void *data);
|
|
|
|
/**
|
|
* mbox_recv - Receive any available message from a mailbox channel
|
|
*
|
|
* This function will wait (up to the specified @timeout_us) for a message to
|
|
* be sent by the remote entity, and write the content of any such message
|
|
* into a caller-provided buffer.
|
|
*
|
|
* @chan: A channel object that was previously successfully requested by
|
|
* calling mbox_get_by_*().
|
|
* @data: A pointer to the buffer to receive the message. The format and
|
|
* size of the memory region pointed at by @data is determined by
|
|
* the mailbox provider. Providers that solely transfer
|
|
* notifications will ignore this parameter.
|
|
* @timeout_us: The maximum time to wait for a message to be available, in
|
|
* micro-seconds. A value of 0 does not wait at all.
|
|
* @return 0 if OK, -ENODATA if no message was available, or a negative error
|
|
* code.
|
|
*/
|
|
int mbox_recv(struct mbox_chan *chan, void *data, ulong timeout_us);
|
|
|
|
#endif
|