Skip to content

Commit b3e2907

Browse files
crojewsk-intelbroonie
authored andcommitted
ASoC: Intel: avs: SKL-based platforms support
Define handlers specific to cAVS 1.5 platforms, that is SKL, KBL, AML and all other variants based on this very version of AudioDSP architecture. Most are specific to SKL-alike platforms with only skl_log_buffer_offset() being exposed and used later by younger equivalents. Signed-off-by: Amadeusz Sławiński <amadeuszx.slawinski@linux.intel.com> Signed-off-by: Cezary Rojewski <cezary.rojewski@intel.com> Link: https://lore.kernel.org/r/20220516101116.190192-15-cezary.rojewski@intel.com Signed-off-by: Mark Brown <broonie@kernel.org>
1 parent cfbc100 commit b3e2907

File tree

6 files changed

+170
-0
lines changed

6 files changed

+170
-0
lines changed

sound/soc/intel/avs/Makefile

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@
33
snd-soc-avs-objs := dsp.o ipc.o messages.o utils.o core.o loader.o \
44
topology.o path.o pcm.o board_selection.o
55
snd-soc-avs-objs += cldma.o
6+
snd-soc-avs-objs += skl.o
67

78
snd-soc-avs-objs += trace.o
89
# tell define_trace.h where to find the trace header

sound/soc/intel/avs/avs.h

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -56,6 +56,8 @@ struct avs_dsp_ops {
5656
#define avs_dsp_op(adev, op, ...) \
5757
((adev)->spec->dsp_ops->op(adev, ## __VA_ARGS__))
5858

59+
extern const struct avs_dsp_ops skl_dsp_ops;
60+
5961
#define AVS_PLATATTR_CLDMA BIT_ULL(0)
6062
#define AVS_PLATATTR_IMR BIT_ULL(1)
6163

@@ -249,6 +251,8 @@ void avs_ipc_block(struct avs_ipc *ipc);
249251
int avs_dsp_disable_d0ix(struct avs_dev *adev);
250252
int avs_dsp_enable_d0ix(struct avs_dev *adev);
251253

254+
int skl_log_buffer_offset(struct avs_dev *adev, u32 core);
255+
252256
/* Firmware resources management */
253257

254258
int avs_get_module_entry(struct avs_dev *adev, const guid_t *uuid, struct avs_module_entry *entry);

sound/soc/intel/avs/core.c

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -634,7 +634,25 @@ static const struct dev_pm_ops avs_dev_pm = {
634634
SET_RUNTIME_PM_OPS(avs_runtime_suspend, avs_runtime_resume, NULL)
635635
};
636636

637+
static const struct avs_spec skl_desc = {
638+
.name = "skl",
639+
.min_fw_version = {
640+
.major = 9,
641+
.minor = 21,
642+
.hotfix = 0,
643+
.build = 4732,
644+
},
645+
.dsp_ops = &skl_dsp_ops,
646+
.core_init_mask = 1,
647+
.attributes = AVS_PLATATTR_CLDMA,
648+
.sram_base_offset = SKL_ADSP_SRAM_BASE_OFFSET,
649+
.sram_window_size = SKL_ADSP_SRAM_WINDOW_SIZE,
650+
.rom_status = SKL_ADSP_SRAM_BASE_OFFSET,
651+
};
652+
637653
static const struct pci_device_id avs_ids[] = {
654+
{ PCI_VDEVICE(INTEL, 0x9d70), (unsigned long)&skl_desc }, /* SKL */
655+
{ PCI_VDEVICE(INTEL, 0x9d71), (unsigned long)&skl_desc }, /* KBL */
638656
{ 0 }
639657
};
640658
MODULE_DEVICE_TABLE(pci, avs_ids);

sound/soc/intel/avs/messages.h

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -347,6 +347,24 @@ enum avs_log_enable {
347347
AVS_LOG_ENABLE = 1
348348
};
349349

350+
enum avs_skl_log_priority {
351+
AVS_SKL_LOG_CRITICAL = 1,
352+
AVS_SKL_LOG_HIGH,
353+
AVS_SKL_LOG_MEDIUM,
354+
AVS_SKL_LOG_LOW,
355+
AVS_SKL_LOG_VERBOSE,
356+
};
357+
358+
struct skl_log_state {
359+
u32 enable;
360+
u32 min_priority;
361+
} __packed;
362+
363+
struct skl_log_state_info {
364+
u32 core_mask;
365+
struct skl_log_state logs_core[];
366+
} __packed;
367+
350368
int avs_ipc_set_enable_logs(struct avs_dev *adev, u8 *log_info, size_t size);
351369

352370
struct avs_fw_version {

sound/soc/intel/avs/registers.h

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -48,6 +48,10 @@
4848
#define SKL_ADSP_HIPCIE_DONE BIT(30)
4949
#define SKL_ADSP_HIPCT_BUSY BIT(31)
5050

51+
/* Intel HD Audio SRAM windows base addresses */
52+
#define SKL_ADSP_SRAM_BASE_OFFSET 0x8000
53+
#define SKL_ADSP_SRAM_WINDOW_SIZE 0x2000
54+
5155
/* Constants used when accessing SRAM, space shared with firmware */
5256
#define AVS_FW_REG_BASE(adev) ((adev)->spec->sram_base_offset)
5357
#define AVS_FW_REG_STATUS(adev) (AVS_FW_REG_BASE(adev) + 0x0)

sound/soc/intel/avs/skl.c

Lines changed: 125 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,125 @@
1+
// SPDX-License-Identifier: GPL-2.0-only
2+
//
3+
// Copyright(c) 2021-2022 Intel Corporation. All rights reserved.
4+
//
5+
// Authors: Cezary Rojewski <cezary.rojewski@intel.com>
6+
// Amadeusz Slawinski <amadeuszx.slawinski@linux.intel.com>
7+
//
8+
9+
#include <linux/devcoredump.h>
10+
#include <linux/slab.h>
11+
#include <sound/hdaudio_ext.h>
12+
#include "avs.h"
13+
#include "messages.h"
14+
15+
static int skl_enable_logs(struct avs_dev *adev, enum avs_log_enable enable, u32 aging_period,
16+
u32 fifo_full_period, unsigned long resource_mask, u32 *priorities)
17+
{
18+
struct skl_log_state_info *info;
19+
u32 size, num_cores = adev->hw_cfg.dsp_cores;
20+
int ret, i;
21+
22+
if (fls_long(resource_mask) > num_cores)
23+
return -EINVAL;
24+
size = struct_size(info, logs_core, num_cores);
25+
info = kzalloc(size, GFP_KERNEL);
26+
if (!info)
27+
return -ENOMEM;
28+
29+
info->core_mask = resource_mask;
30+
if (enable)
31+
for_each_set_bit(i, &resource_mask, GENMASK(num_cores, 0)) {
32+
info->logs_core[i].enable = enable;
33+
info->logs_core[i].min_priority = *priorities++;
34+
}
35+
else
36+
for_each_set_bit(i, &resource_mask, GENMASK(num_cores, 0))
37+
info->logs_core[i].enable = enable;
38+
39+
ret = avs_ipc_set_enable_logs(adev, (u8 *)info, size);
40+
kfree(info);
41+
if (ret)
42+
return AVS_IPC_RET(ret);
43+
44+
return 0;
45+
}
46+
47+
int skl_log_buffer_offset(struct avs_dev *adev, u32 core)
48+
{
49+
return core * avs_log_buffer_size(adev);
50+
}
51+
52+
/* fw DbgLogWp registers */
53+
#define FW_REGS_DBG_LOG_WP(core) (0x30 + 0x4 * core)
54+
55+
static int
56+
skl_log_buffer_status(struct avs_dev *adev, union avs_notify_msg *msg)
57+
{
58+
unsigned long flags;
59+
void __iomem *buf;
60+
u16 size, write, offset;
61+
62+
spin_lock_irqsave(&adev->dbg.trace_lock, flags);
63+
if (!kfifo_initialized(&adev->dbg.trace_fifo)) {
64+
spin_unlock_irqrestore(&adev->dbg.trace_lock, flags);
65+
return 0;
66+
}
67+
68+
size = avs_log_buffer_size(adev) / 2;
69+
write = readl(avs_sram_addr(adev, AVS_FW_REGS_WINDOW) + FW_REGS_DBG_LOG_WP(msg->log.core));
70+
/* determine buffer half */
71+
offset = (write < size) ? size : 0;
72+
73+
/* Address is guaranteed to exist in SRAM2. */
74+
buf = avs_log_buffer_addr(adev, msg->log.core) + offset;
75+
__kfifo_fromio_locked(&adev->dbg.trace_fifo, buf, size, &adev->dbg.fifo_lock);
76+
wake_up(&adev->dbg.trace_waitq);
77+
spin_unlock_irqrestore(&adev->dbg.trace_lock, flags);
78+
79+
return 0;
80+
}
81+
82+
static int skl_coredump(struct avs_dev *adev, union avs_notify_msg *msg)
83+
{
84+
u8 *dump;
85+
86+
dump = vzalloc(AVS_FW_REGS_SIZE);
87+
if (!dump)
88+
return -ENOMEM;
89+
90+
memcpy_fromio(dump, avs_sram_addr(adev, AVS_FW_REGS_WINDOW), AVS_FW_REGS_SIZE);
91+
dev_coredumpv(adev->dev, dump, AVS_FW_REGS_SIZE, GFP_KERNEL);
92+
93+
return 0;
94+
}
95+
96+
static bool
97+
skl_d0ix_toggle(struct avs_dev *adev, struct avs_ipc_msg *tx, bool wake)
98+
{
99+
/* unsupported on cAVS 1.5 hw */
100+
return false;
101+
}
102+
103+
static int skl_set_d0ix(struct avs_dev *adev, bool enable)
104+
{
105+
/* unsupported on cAVS 1.5 hw */
106+
return 0;
107+
}
108+
109+
const struct avs_dsp_ops skl_dsp_ops = {
110+
.power = avs_dsp_core_power,
111+
.reset = avs_dsp_core_reset,
112+
.stall = avs_dsp_core_stall,
113+
.irq_handler = avs_dsp_irq_handler,
114+
.irq_thread = avs_dsp_irq_thread,
115+
.int_control = avs_dsp_interrupt_control,
116+
.load_basefw = avs_cldma_load_basefw,
117+
.load_lib = avs_cldma_load_library,
118+
.transfer_mods = avs_cldma_transfer_modules,
119+
.enable_logs = skl_enable_logs,
120+
.log_buffer_offset = skl_log_buffer_offset,
121+
.log_buffer_status = skl_log_buffer_status,
122+
.coredump = skl_coredump,
123+
.d0ix_toggle = skl_d0ix_toggle,
124+
.set_d0ix = skl_set_d0ix,
125+
};

0 commit comments

Comments
 (0)