9077ac1ab1
This patch adds the support for system suspend/resume to the OMAP remoteproc driver so that the OMAP remoteproc devices can be suspended/resumed during a system suspend/resume. The support is added through the driver PM .suspend/.resume callbacks, and requires appropriate support from the OS running on the remote processors. The IPU & DSP remote processors typically have their own private modules like registers, internal memories, caches etc. The context of these modules need to be saved and restored properly for a suspend/resume to work. These are in general not accessible from the MPU, so the remote processors themselves have to implement the logic for the context save & restore of these modules. The OMAP remoteproc driver initiates a suspend by sending a mailbox message requesting the remote processor to save its context and enter into an idle/standby state. The remote processor should usually stop whatever processing it is doing to switch to a context save mode. The OMAP remoteproc driver detects the completion of the context save by checking the module standby status for the remoteproc device. It also stops any resources used by the remote processors like the timers. The timers need to be running only when the processor is active and executing, and need to be stopped otherwise to allow the timer driver to reach low-power states. The IOMMUs are automatically suspended by the PM core during the late suspend stage, after the remoteproc suspend process is completed by putting the remote processor cores into reset. Thereafter, the Linux kernel can put the domain into further lower power states as possible. The resume sequence undoes the operations performed in the PM suspend callback, by starting the timers and finally releasing the processors from reset. This requires that the remote processor side OS be able to distinguish a power-resume boot from a power-on/cold boot, restore the context of its private modules saved during the suspend phase, and resume executing code from where it was suspended. The IOMMUs would have been resumed by the PM core during early resume, so they are already enabled by the time remoteproc resume callback gets invoked. The remote processors should save their context into System RAM (DDR), as any internal memories are not guaranteed to retain context as it depends on the lowest power domain that the remote processor device is put into. The management of the DDR contents will be managed by the Linux kernel. Signed-off-by: Suman Anna <s-anna@ti.com> [t-kristo@ti.com: converted to use ti-sysc instead of hwmod] Signed-off-by: Tero Kristo <t-kristo@ti.com> Reviewed-by: Andrew F. Davis <afd@ti.com> Acked-by: Mathieu Poirier <mathieu.poirier@linaro.org> Link: https://lore.kernel.org/r/20200324110035.29907-12-t-kristo@ti.com Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
91 lines
3.5 KiB
C
91 lines
3.5 KiB
C
/*
|
|
* Remote processor messaging
|
|
*
|
|
* Copyright (C) 2011-2020 Texas Instruments, Inc.
|
|
* Copyright (C) 2011 Google, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
*
|
|
* * Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* * Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in
|
|
* the documentation and/or other materials provided with the
|
|
* distribution.
|
|
* * Neither the name Texas Instruments nor the names of its
|
|
* contributors may be used to endorse or promote products derived
|
|
* from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
#ifndef _OMAP_RPMSG_H
|
|
#define _OMAP_RPMSG_H
|
|
|
|
/*
|
|
* enum - Predefined Mailbox Messages
|
|
*
|
|
* @RP_MBOX_READY: informs the M3's that we're up and running. this is
|
|
* part of the init sequence sent that the M3 expects to see immediately
|
|
* after it is booted.
|
|
*
|
|
* @RP_MBOX_PENDING_MSG: informs the receiver that there is an inbound
|
|
* message waiting in its own receive-side vring. please note that currently
|
|
* this message is optional: alternatively, one can explicitly send the index
|
|
* of the triggered virtqueue itself. the preferred approach will be decided
|
|
* as we progress and experiment with those two different approaches.
|
|
*
|
|
* @RP_MBOX_CRASH: this message is sent if BIOS crashes
|
|
*
|
|
* @RP_MBOX_ECHO_REQUEST: a mailbox-level "ping" message.
|
|
*
|
|
* @RP_MBOX_ECHO_REPLY: a mailbox-level reply to a "ping"
|
|
*
|
|
* @RP_MBOX_ABORT_REQUEST: a "please crash" request, used for testing the
|
|
* recovery mechanism (to some extent).
|
|
*
|
|
* @RP_MBOX_SUSPEND_AUTO: auto suspend request for the remote processor
|
|
*
|
|
* @RP_MBOX_SUSPEND_SYSTEM: system suspend request for the remote processor
|
|
*
|
|
* @RP_MBOX_SUSPEND_ACK: successful response from remote processor for a
|
|
* suspend request
|
|
*
|
|
* @RP_MBOX_SUSPEND_CANCEL: a cancel suspend response from a remote processor
|
|
* on a suspend request
|
|
*
|
|
* Introduce new message definitions if any here.
|
|
*
|
|
* @RP_MBOX_END_MSG: Indicates end of known/defined messages from remote core
|
|
* This should be the last definition.
|
|
*
|
|
*/
|
|
enum omap_rp_mbox_messages {
|
|
RP_MBOX_READY = 0xFFFFFF00,
|
|
RP_MBOX_PENDING_MSG = 0xFFFFFF01,
|
|
RP_MBOX_CRASH = 0xFFFFFF02,
|
|
RP_MBOX_ECHO_REQUEST = 0xFFFFFF03,
|
|
RP_MBOX_ECHO_REPLY = 0xFFFFFF04,
|
|
RP_MBOX_ABORT_REQUEST = 0xFFFFFF05,
|
|
RP_MBOX_SUSPEND_AUTO = 0xFFFFFF10,
|
|
RP_MBOX_SUSPEND_SYSTEM = 0xFFFFFF11,
|
|
RP_MBOX_SUSPEND_ACK = 0xFFFFFF12,
|
|
RP_MBOX_SUSPEND_CANCEL = 0xFFFFFF13,
|
|
RP_MBOX_END_MSG = 0xFFFFFF14,
|
|
};
|
|
|
|
#endif /* _OMAP_RPMSG_H */
|