Skip to content

Commit

Permalink
Rename HDMI ALSA device names, check for enable state
Browse files Browse the repository at this point in the history
HDMI Alsa devices renamed to match names used by DRM, to
HDMI 1 and HDMI 2

Check for which HDMI devices are connected and only create
devices for those that are present.

The rename of the devices might cause some backwards compatibility
issues, but since this particular part of the driver needs to be
specifically enabled, I suspect the number of people who will see
the problem will be very small.

Signed-off-by: James Hughes <[email protected]>
  • Loading branch information
James Hughes authored and popcornmix committed Jan 3, 2020
1 parent 7bc1429 commit 73dc9c0
Showing 1 changed file with 63 additions and 7 deletions.
70 changes: 63 additions & 7 deletions drivers/staging/vc04_services/bcm2835-audio/bcm2835.c
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,9 @@
#include <linux/of.h>

#include "bcm2835.h"
#include <soc/bcm2835/raspberrypi-firmware.h>

static bool enable_hdmi;
static bool enable_hdmi, enable_hdmi0, enable_hdmi1;
static bool enable_headphones;
static bool enable_compat_alsa = true;

Expand Down Expand Up @@ -115,8 +116,8 @@ static struct bcm2835_audio_driver bcm2835_audio_hdmi0 = {
.name = "bcm2835_hdmi",
.owner = THIS_MODULE,
},
.shortname = "bcm2835 HDMI",
.longname = "bcm2835 HDMI",
.shortname = "bcm2835 HDMI 1",
.longname = "bcm2835 HDMI 1",
.minchannels = 1,
.newpcm = bcm2835_audio_simple_newpcm,
.newctl = snd_bcm2835_new_hdmi_ctl,
Expand All @@ -128,8 +129,8 @@ static struct bcm2835_audio_driver bcm2835_audio_hdmi1 = {
.name = "bcm2835_hdmi",
.owner = THIS_MODULE,
},
.shortname = "bcm2835 HDMI 1",
.longname = "bcm2835 HDMI 1",
.shortname = "bcm2835 HDMI 2",
.longname = "bcm2835 HDMI 2",
.minchannels = 1,
.newpcm = bcm2835_audio_simple_newpcm,
.newctl = snd_bcm2835_new_hdmi_ctl,
Expand Down Expand Up @@ -161,11 +162,11 @@ static struct bcm2835_audio_drivers children_devices[] = {
},
{
.audio_driver = &bcm2835_audio_hdmi0,
.is_enabled = &enable_hdmi,
.is_enabled = &enable_hdmi0,
},
{
.audio_driver = &bcm2835_audio_hdmi1,
.is_enabled = &enable_hdmi,
.is_enabled = &enable_hdmi1,
},
{
.audio_driver = &bcm2835_audio_headphones,
Expand Down Expand Up @@ -312,6 +313,53 @@ static int snd_add_child_devices(struct device *device, u32 numchans)
return 0;
}

static void set_hdmi_enables(struct device *dev)
{
struct device_node *firmware_node;
struct rpi_firmware *firmware;
u32 num_displays, i, display_id;
int ret;

firmware_node = of_parse_phandle(dev->of_node, "brcm,firmware", 0);
firmware = rpi_firmware_get(firmware_node);

if (!firmware)
return;

of_node_put(firmware_node);

ret = rpi_firmware_property(firmware,
RPI_FIRMWARE_FRAMEBUFFER_GET_NUM_DISPLAYS,
&num_displays, sizeof(u32));

if (ret)
return;

for (i = 0; i < num_displays; i++) {
display_id = i;
ret = rpi_firmware_property(firmware,
RPI_FIRMWARE_FRAMEBUFFER_GET_DISPLAY_ID,
&display_id, sizeof(display_id));
if (!ret) {
if (display_id == 2)
enable_hdmi0 = true;
if (display_id == 7)
enable_hdmi1 = true;
}
}

if (!enable_hdmi0 && enable_hdmi1) {
/* Swap them over and reassign route. This means
* that if we only have one connected, it is always named
* HDMI1, irrespective of if its on port HDMI0 or HDMI1.
* This should match with the naming of HDMI ports in DRM
*/
enable_hdmi0 = true;
enable_hdmi1 = false;
bcm2835_audio_hdmi0.route = AUDIO_DEST_HDMI1;
}
}

static int snd_bcm2835_alsa_probe(struct platform_device *pdev)
{
struct device *dev = &pdev->dev;
Expand All @@ -332,6 +380,14 @@ static int snd_bcm2835_alsa_probe(struct platform_device *pdev)
numchans);
}

if (!enable_compat_alsa) {
set_hdmi_enables(dev);
// In this mode, always enable analog output
enable_headphones = true;
} else {
enable_hdmi0 = enable_hdmi;
}

err = bcm2835_devm_add_vchi_ctx(dev);
if (err)
return err;
Expand Down

0 comments on commit 73dc9c0

Please sign in to comment.