/* * Intel Baytrail SST IPC Support * Copyright (c) 2014, Intel Corporation. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope 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 __SST_BYT_IPC_H #define __SST_BYT_IPC_H #include struct sst_byt; struct sst_byt_stream; struct sst_pdata; extern struct sst_ops sst_byt_ops; #define SST_BYT_MAILBOX_OFFSET 0x144000 #define SST_BYT_TIMESTAMP_OFFSET (SST_BYT_MAILBOX_OFFSET + 0x800) /** * Upfront defined maximum message size that is * expected by the in/out communication pipes in FW. */ #define SST_BYT_IPC_MAX_PAYLOAD_SIZE 200 /* stream API */ struct sst_byt_stream *sst_byt_stream_new(struct sst_byt *byt, int id, uint32_t (*get_write_position)(struct sst_byt_stream *stream, void *data), void *data); /* stream configuration */ int sst_byt_stream_set_bits(struct sst_byt *byt, struct sst_byt_stream *stream, int bits); int sst_byt_stream_set_channels(struct sst_byt *byt, struct sst_byt_stream *stream, u8 channels); int sst_byt_stream_set_rate(struct sst_byt *byt, struct sst_byt_stream *stream, unsigned int rate); int sst_byt_stream_type(struct sst_byt *byt, struct sst_byt_stream *stream, int codec_type, int stream_type, int operation); int sst_byt_stream_buffer(struct sst_byt *byt, struct sst_byt_stream *stream, uint32_t buffer_addr, uint32_t buffer_size); int sst_byt_stream_commit(struct sst_byt *byt, struct sst_byt_stream *stream); int sst_byt_stream_free(struct sst_byt *byt, struct sst_byt_stream *stream); /* stream ALSA trigger operations */ int sst_byt_stream_start(struct sst_byt *byt, struct sst_byt_stream *stream, u32 start_offset); int sst_byt_stream_stop(struct sst_byt *byt, struct sst_byt_stream *stream); int sst_byt_stream_pause(struct sst_byt *byt, struct sst_byt_stream *stream); int sst_byt_stream_resume(struct sst_byt *byt, struct sst_byt_stream *stream); int sst_byt_get_dsp_position(struct sst_byt *byt, struct sst_byt_stream *stream, int buffer_size); /* init */ int sst_byt_dsp_init(struct device *dev, struct sst_pdata *pdata); void sst_byt_dsp_free(struct device *dev, struct sst_pdata *pdata); struct sst_dsp *sst_byt_get_dsp(struct sst_byt *byt); int sst_byt_dsp_suspend_late(struct device *dev, struct sst_pdata *pdata); int sst_byt_dsp_boot(struct device *dev, struct sst_pdata *pdata); int sst_byt_dsp_wait_for_ready(struct device *dev, struct sst_pdata *pdata); #endif x/net-next.git/commit/?id=08d85f3ea99f1eeafc4e8507936190e86a16ee8c'>root/include/dt-bindings/power/r8a7743-sysc.h
diff options
context:
space:
mode:
authorMarc Zyngier <marc.zyngier@arm.com>2017-01-17 16:00:48 +0000
committerThomas Gleixner <tglx@linutronix.de>2017-01-30 15:18:56 +0100
commit08d85f3ea99f1eeafc4e8507936190e86a16ee8c (patch)
tree410bb1acd0cd7dcfaad37ae7b63ff243b7fa4bee /include/dt-bindings/power/r8a7743-sysc.h
parent566cf877a1fcb6d6dc0126b076aad062054c2637 (diff)
irqdomain: Avoid activating interrupts more than once
Since commit f3b0946d629c ("genirq/msi: Make sure PCI MSIs are activated early"), we can end-up activating a PCI/MSI twice (once at allocation time, and once at startup time). This is normally of no consequences, except that there is some HW out there that may misbehave if activate is used more than once (the GICv3 ITS, for example, uses the activate callback to issue the MAPVI command, and the architecture spec says that "If there is an existing mapping for the EventID-DeviceID combination, behavior is UNPREDICTABLE"). While this could be worked around in each individual driver, it may make more sense to tackle the issue at the core level. In order to avoid getting in that situation, let's have a per-interrupt flag to remember if we have already activated that interrupt or not. Fixes: f3b0946d629c ("genirq/msi: Make sure PCI MSIs are activated early") Reported-and-tested-by: Andre Przywara <andre.przywara@arm.com> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com> Cc: stable@vger.kernel.org Link: http://lkml.kernel.org/r/1484668848-24361-1-git-send-email-marc.zyngier@arm.com Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/dt-bindings/power/r8a7743-sysc.h')