X-Git-Url: http://www.pilppa.org/gitweb/gitweb.cgi?a=blobdiff_plain;f=arch%2Farm%2Fmach-omap2%2Fmailbox.c;h=571aea7166aaf6bc6219b1cfb7f22436e8d314cb;hb=750e3381c3e79dc970f78573107c658a3300e235;hp=01d5f42f2d2dcc565c740e49cdefe6d315870d79;hpb=2e1c754bcb5f5bc6485f65b9d3f4a05300955dc5;p=linux-2.6-omap-h63xx.git diff --git a/arch/arm/mach-omap2/mailbox.c b/arch/arm/mach-omap2/mailbox.c index 01d5f42f2d2..571aea7166a 100644 --- a/arch/arm/mach-omap2/mailbox.c +++ b/arch/arm/mach-omap2/mailbox.c @@ -32,6 +32,8 @@ #define MAILBOX_IRQ_NEWMSG(u) (1 << (2 * (u))) #define MAILBOX_IRQ_NOTFULL(u) (1 << (2 * (u) + 1)) +#define MBOX_REG_SIZE 0x120 + static void __iomem *mbox_base; struct omap_mbox2_fifo { @@ -47,6 +49,7 @@ struct omap_mbox2_priv { unsigned long irqstatus; u32 newmsg_bit; u32 notfull_bit; + char ctx[MBOX_REG_SIZE]; }; static struct clk *mbox_ick_handle; @@ -167,6 +170,36 @@ static int omap2_mbox_is_irq(struct omap_mbox *mbox, return (enable & status & bit); } +static void omap2_mbox_save_ctx(struct omap_mbox *mbox) +{ + int i; + struct omap_mbox2_priv *p = mbox->priv; + + for (i = 0; i < MBOX_REG_SIZE; i += sizeof(u32)) { + u32 val; + + val = mbox_read_reg(i); + *(u32 *)(p->ctx + i) = val; + + dev_dbg(mbox->dev, "%s\t[%02d] %08x\n", __func__, i, val); + } +} + +static void omap2_mbox_restore_ctx(struct omap_mbox *mbox) +{ + int i; + struct omap_mbox2_priv *p = mbox->priv; + + for (i = 0; i < MBOX_REG_SIZE; i += sizeof(u32)) { + u32 val; + + val = *(u32 *)(p->ctx + i); + mbox_write_reg(val, i); + + dev_dbg(mbox->dev, "%s\t[%02d] %08x\n", __func__, i, val); + } +} + static struct omap_mbox_ops omap2_mbox_ops = { .type = OMAP_MBOX_TYPE2, .startup = omap2_mbox_startup, @@ -179,6 +212,8 @@ static struct omap_mbox_ops omap2_mbox_ops = { .disable_irq = omap2_mbox_disable_irq, .ack_irq = omap2_mbox_ack_irq, .is_irq = omap2_mbox_is_irq, + .save_ctx = omap2_mbox_save_ctx, + .restore_ctx = omap2_mbox_restore_ctx, }; /*