27d3f02689
Merge DSP reset and cleanup sequence in sst_byt_pcm_dev_suspend_noirq() into sst_byt_pcm_dev_suspend_late(). First their order was wrong by first unloading firmware modules in suspend_late and then taking DSP into reset in suspend_noirq. Second ACPI has put device into OFF state already during suspend_late so trying to reset the DSP is a no-op at suspend_noirq stage. Fix these by moving DSP reset and cleanup into sst_byt_pcm_dev_suspend_late() before firmware unloading. Signed-off-by: Jarkko Nikula <jarkko.nikula@linux.intel.com> Tested-by: Borun Fu <borun.fu@intel.com> Signed-off-by: Mark Brown <broonie@linaro.org>
73 lines
2.7 KiB
C
73 lines
2.7 KiB
C
/*
|
|
* 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 <linux/types.h>
|
|
|
|
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
|