mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-03-04 02:30:14 +00:00
soundwire: intel: read mclk_freq property from firmware
The BIOS provides an Intel-specific property, let's use it to avoid hard-coded clock dividers. Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Link: https://lore.kernel.org/r/20190806005522.22642-12-pierre-louis.bossart@linux.intel.com Signed-off-by: Vinod Koul <vkoul@kernel.org>
This commit is contained in:
parent
82fc8d0650
commit
085f4ace10
@ -808,11 +808,37 @@ static int intel_register_dai(struct sdw_intel *sdw)
|
|||||||
dais, num_dai);
|
dais, num_dai);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int sdw_master_read_intel_prop(struct sdw_bus *bus)
|
||||||
|
{
|
||||||
|
struct sdw_master_prop *prop = &bus->prop;
|
||||||
|
struct fwnode_handle *link;
|
||||||
|
char name[32];
|
||||||
|
int nval, i;
|
||||||
|
|
||||||
|
/* Find master handle */
|
||||||
|
snprintf(name, sizeof(name),
|
||||||
|
"mipi-sdw-link-%d-subproperties", bus->link_id);
|
||||||
|
|
||||||
|
link = device_get_named_child_node(bus->dev, name);
|
||||||
|
if (!link) {
|
||||||
|
dev_err(bus->dev, "Master node %s not found\n", name);
|
||||||
|
return -EIO;
|
||||||
|
}
|
||||||
|
|
||||||
|
fwnode_property_read_u32(link,
|
||||||
|
"intel-sdw-ip-clock",
|
||||||
|
&prop->mclk_freq);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int intel_prop_read(struct sdw_bus *bus)
|
static int intel_prop_read(struct sdw_bus *bus)
|
||||||
{
|
{
|
||||||
/* Initialize with default handler to read all DisCo properties */
|
/* Initialize with default handler to read all DisCo properties */
|
||||||
sdw_master_read_prop(bus);
|
sdw_master_read_prop(bus);
|
||||||
|
|
||||||
|
/* read Intel-specific properties */
|
||||||
|
sdw_master_read_intel_prop(bus);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user