forked from MIPS/CI20_linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #4158 from plbossart/hdaudio/extended-multi-link
ASoC: SOF: Intel: hda-mlink: add support for Extended Multi Links
- Loading branch information
Showing
11 changed files
with
1,329 additions
and
46 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,3 +9,4 @@ HD-Audio | |
controls | ||
dp-mst | ||
realtek-pc-beep | ||
intel-multi-link |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,166 @@ | ||
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */ | ||
/* | ||
* This file is provided under a dual BSD/GPLv2 license. When using or | ||
* redistributing this file, you may do so under either license. | ||
* | ||
* Copyright(c) 2022-2023 Intel Corporation. All rights reserved. | ||
*/ | ||
|
||
struct hdac_bus; | ||
struct hdac_ext_link; | ||
|
||
#if IS_ENABLED(CONFIG_SND_SOC_SOF_HDA_MLINK) | ||
|
||
int hda_bus_ml_get_capabilities(struct hdac_bus *bus); | ||
void hda_bus_ml_free(struct hdac_bus *bus); | ||
|
||
int hdac_bus_eml_get_count(struct hdac_bus *bus, bool alt, int elid); | ||
void hdac_bus_eml_enable_interrupt(struct hdac_bus *bus, bool alt, int elid, bool enable); | ||
bool hdac_bus_eml_check_interrupt(struct hdac_bus *bus, bool alt, int elid); | ||
|
||
int hdac_bus_eml_set_syncprd_unlocked(struct hdac_bus *bus, bool alt, int elid, u32 syncprd); | ||
int hdac_bus_eml_sdw_set_syncprd_unlocked(struct hdac_bus *bus, u32 syncprd); | ||
|
||
int hdac_bus_eml_wait_syncpu_unlocked(struct hdac_bus *bus, bool alt, int elid); | ||
int hdac_bus_eml_sdw_wait_syncpu_unlocked(struct hdac_bus *bus); | ||
|
||
void hdac_bus_eml_sync_arm_unlocked(struct hdac_bus *bus, bool alt, int elid, int sublink); | ||
void hdac_bus_eml_sdw_sync_arm_unlocked(struct hdac_bus *bus, int sublink); | ||
|
||
int hdac_bus_eml_sync_go_unlocked(struct hdac_bus *bus, bool alt, int elid); | ||
int hdac_bus_eml_sdw_sync_go_unlocked(struct hdac_bus *bus); | ||
|
||
bool hdac_bus_eml_check_cmdsync_unlocked(struct hdac_bus *bus, bool alt, int elid); | ||
bool hdac_bus_eml_sdw_check_cmdsync_unlocked(struct hdac_bus *bus); | ||
|
||
int hdac_bus_eml_power_up(struct hdac_bus *bus, bool alt, int elid, int sublink); | ||
int hdac_bus_eml_power_up_unlocked(struct hdac_bus *bus, bool alt, int elid, int sublink); | ||
|
||
int hdac_bus_eml_power_down(struct hdac_bus *bus, bool alt, int elid, int sublink); | ||
int hdac_bus_eml_power_down_unlocked(struct hdac_bus *bus, bool alt, int elid, int sublink); | ||
|
||
int hdac_bus_eml_sdw_power_up_unlocked(struct hdac_bus *bus, int sublink); | ||
int hdac_bus_eml_sdw_power_down_unlocked(struct hdac_bus *bus, int sublink); | ||
|
||
int hdac_bus_eml_sdw_set_lsdiid(struct hdac_bus *bus, int sublink, int dev_num); | ||
|
||
void hda_bus_ml_put_all(struct hdac_bus *bus); | ||
void hda_bus_ml_reset_losidv(struct hdac_bus *bus); | ||
int hda_bus_ml_resume(struct hdac_bus *bus); | ||
int hda_bus_ml_suspend(struct hdac_bus *bus); | ||
|
||
struct hdac_ext_link *hdac_bus_eml_ssp_get_hlink(struct hdac_bus *bus); | ||
struct hdac_ext_link *hdac_bus_eml_dmic_get_hlink(struct hdac_bus *bus); | ||
|
||
struct mutex *hdac_bus_eml_get_mutex(struct hdac_bus *bus, bool alt, int elid); | ||
|
||
int hdac_bus_eml_enable_offload(struct hdac_bus *bus, bool alt, int elid, bool enable); | ||
|
||
#else | ||
|
||
static inline int | ||
hda_bus_ml_get_capabilities(struct hdac_bus *bus) { return 0; } | ||
|
||
static inline void hda_bus_ml_free(struct hdac_bus *bus) { } | ||
|
||
static inline int | ||
hdac_bus_eml_get_count(struct hdac_bus *bus, bool alt, int elid) { return 0; } | ||
|
||
static inline void | ||
hdac_bus_eml_enable_interrupt(struct hdac_bus *bus, bool alt, int elid, bool enable) { } | ||
|
||
static inline bool | ||
hdac_bus_eml_check_interrupt(struct hdac_bus *bus, bool alt, int elid) { return false; } | ||
|
||
static inline int | ||
hdac_bus_eml_set_syncprd_unlocked(struct hdac_bus *bus, bool alt, int elid, u32 syncprd) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_sdw_set_syncprd_unlocked(struct hdac_bus *bus, u32 syncprd) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_wait_syncpu_unlocked(struct hdac_bus *bus, bool alt, int elid) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_sdw_wait_syncpu_unlocked(struct hdac_bus *bus) { return 0; } | ||
|
||
static inline void | ||
hdac_bus_eml_sync_arm_unlocked(struct hdac_bus *bus, bool alt, int elid, int sublink) { } | ||
|
||
static inline void | ||
hdac_bus_eml_sdw_sync_arm_unlocked(struct hdac_bus *bus, int sublink) { } | ||
|
||
static inline int | ||
hdac_bus_eml_sync_go_unlocked(struct hdac_bus *bus, bool alt, int elid) { return 0; } | ||
|
||
static inline int | ||
hdac_bus_eml_sdw_sync_go_unlocked(struct hdac_bus *bus) { return 0; } | ||
|
||
static inline bool | ||
hdac_bus_eml_check_cmdsync_unlocked(struct hdac_bus *bus, bool alt, int elid) { return false; } | ||
|
||
static inline bool | ||
hdac_bus_eml_sdw_check_cmdsync_unlocked(struct hdac_bus *bus) { return false; } | ||
|
||
static inline int | ||
hdac_bus_eml_power_up(struct hdac_bus *bus, bool alt, int elid, int sublink) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_power_up_unlocked(struct hdac_bus *bus, bool alt, int elid, int sublink) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_power_down(struct hdac_bus *bus, bool alt, int elid, int sublink) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_power_down_unlocked(struct hdac_bus *bus, bool alt, int elid, int sublink) | ||
{ | ||
return 0; | ||
} | ||
|
||
static inline int | ||
hdac_bus_eml_sdw_power_up_unlocked(struct hdac_bus *bus, int sublink) { return 0; } | ||
|
||
static inline int | ||
hdac_bus_eml_sdw_power_down_unlocked(struct hdac_bus *bus, int sublink) { return 0; } | ||
|
||
static inline int | ||
hdac_bus_eml_sdw_set_lsdiid(struct hdac_bus *bus, int sublink, int dev_num) { return 0; } | ||
|
||
static inline void hda_bus_ml_put_all(struct hdac_bus *bus) { } | ||
static inline void hda_bus_ml_reset_losidv(struct hdac_bus *bus) { } | ||
static inline int hda_bus_ml_resume(struct hdac_bus *bus) { return 0; } | ||
static inline int hda_bus_ml_suspend(struct hdac_bus *bus) { return 0; } | ||
|
||
static inline struct hdac_ext_link * | ||
hdac_bus_eml_ssp_get_hlink(struct hdac_bus *bus) { return NULL; } | ||
|
||
static inline struct hdac_ext_link * | ||
hdac_bus_eml_dmic_get_hlink(struct hdac_bus *bus) { return NULL; } | ||
|
||
static inline struct mutex * | ||
hdac_bus_eml_get_mutex(struct hdac_bus *bus, bool alt, int elid) { return NULL; } | ||
|
||
static inline int | ||
hdac_bus_eml_enable_offload(struct hdac_bus *bus, bool alt, int elid, bool enable) | ||
{ | ||
return 0; | ||
} | ||
#endif /* CONFIG_SND_SOC_SOF_HDA */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.