34ed5a33b1
Add a remoteproc driver for OMAP4, so we can boot the dual-M3 and and DSP subsystems. Use the omap_device_* API to control the hardware state, and utilize the OMAP mailbox to interrupt the remote processor when a new message is pending (the mailbox payload is used to tell it which virtqueue was the message placed in). Conversely, when an inbound mailbox message arrives, tell the remoteproc core which virtqueue is triggered. Later we will also use the mailbox payload to signal omap-specific events like remote crashes (which will be used to trigger remoteproc recovery) and power management transitions. At that point we will also extend the remoteproc core to support this. Based on (but now quite far from) work done by Fernando Guzman Lugo <fernando.lugo@ti.com> and Hari Kanigeri <h-kanigeri2@ti.com>. Designed with Brian Swetland <swetland@google.com>. Signed-off-by: Ohad Ben-Cohen <ohad@wizery.com> Acked-by: Tony Lindgren <tony@atomide.com> Cc: Brian Swetland <swetland@google.com> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Grant Likely <grant.likely@secretlab.ca> Cc: Russell King <linux@arm.linux.org.uk> Cc: Rusty Russell <rusty@rustcorp.com.au> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Greg KH <greg@kroah.com> Cc: Stephen Boyd <sboyd@codeaurora.org>
58 lines
1.6 KiB
C
58 lines
1.6 KiB
C
/*
|
|
* Remote Processor - omap-specific bits
|
|
*
|
|
* Copyright (C) 2011 Texas Instruments, Inc.
|
|
* Copyright (C) 2011 Google, Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*/
|
|
|
|
#ifndef _PLAT_REMOTEPROC_H
|
|
#define _PLAT_REMOTEPROC_H
|
|
|
|
struct rproc_ops;
|
|
struct platform_device;
|
|
|
|
/*
|
|
* struct omap_rproc_pdata - omap remoteproc's platform data
|
|
* @name: the remoteproc's name
|
|
* @oh_name: omap hwmod device
|
|
* @oh_name_opt: optional, secondary omap hwmod device
|
|
* @firmware: name of firmware file to load
|
|
* @mbox_name: name of omap mailbox device to use with this rproc
|
|
* @ops: start/stop rproc handlers
|
|
* @device_enable: omap-specific handler for enabling a device
|
|
* @device_shutdown: omap-specific handler for shutting down a device
|
|
*/
|
|
struct omap_rproc_pdata {
|
|
const char *name;
|
|
const char *oh_name;
|
|
const char *oh_name_opt;
|
|
const char *firmware;
|
|
const char *mbox_name;
|
|
const struct rproc_ops *ops;
|
|
int (*device_enable) (struct platform_device *pdev);
|
|
int (*device_shutdown) (struct platform_device *pdev);
|
|
};
|
|
|
|
#if defined(CONFIG_OMAP_REMOTEPROC) || defined(CONFIG_OMAP_REMOTEPROC_MODULE)
|
|
|
|
void __init omap_rproc_reserve_cma(void);
|
|
|
|
#else
|
|
|
|
void __init omap_rproc_reserve_cma(void)
|
|
{
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* _PLAT_REMOTEPROC_H */
|