Commit 3f43c48d authored by Chris Wilson's avatar Chris Wilson Committed by Keith Packard

drm/i915: Share the common force-audio property between connectors

Make the audio property creation routine common and share the single
property between the connectors.
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: default avatarKeith Packard <keithp@keithp.com>
Signed-off-by: default avatarKeith Packard <keithp@keithp.com>
parent 4bce2da3
...@@ -716,6 +716,7 @@ typedef struct drm_i915_private { ...@@ -716,6 +716,7 @@ typedef struct drm_i915_private {
struct intel_fbdev *fbdev; struct intel_fbdev *fbdev;
struct drm_property *broadcast_rgb_property; struct drm_property *broadcast_rgb_property;
struct drm_property *force_audio_property;
atomic_t forcewake_count; atomic_t forcewake_count;
} drm_i915_private_t; } drm_i915_private_t;
......
...@@ -59,8 +59,6 @@ struct intel_dp { ...@@ -59,8 +59,6 @@ struct intel_dp {
bool is_pch_edp; bool is_pch_edp;
uint8_t train_set[4]; uint8_t train_set[4];
uint8_t link_status[DP_LINK_STATUS_SIZE]; uint8_t link_status[DP_LINK_STATUS_SIZE];
struct drm_property *force_audio_property;
}; };
/** /**
...@@ -1702,7 +1700,7 @@ intel_dp_set_property(struct drm_connector *connector, ...@@ -1702,7 +1700,7 @@ intel_dp_set_property(struct drm_connector *connector,
if (ret) if (ret)
return ret; return ret;
if (property == intel_dp->force_audio_property) { if (property == dev_priv->force_audio_property) {
int i = val; int i = val;
bool has_audio; bool has_audio;
...@@ -1841,16 +1839,7 @@ bool intel_dpd_is_edp(struct drm_device *dev) ...@@ -1841,16 +1839,7 @@ bool intel_dpd_is_edp(struct drm_device *dev)
static void static void
intel_dp_add_properties(struct intel_dp *intel_dp, struct drm_connector *connector) intel_dp_add_properties(struct intel_dp *intel_dp, struct drm_connector *connector)
{ {
struct drm_device *dev = connector->dev; intel_attach_force_audio_property(connector);
intel_dp->force_audio_property =
drm_property_create(dev, DRM_MODE_PROP_RANGE, "force_audio", 2);
if (intel_dp->force_audio_property) {
intel_dp->force_audio_property->values[0] = -1;
intel_dp->force_audio_property->values[1] = 1;
drm_connector_attach_property(connector, intel_dp->force_audio_property, 0);
}
intel_attach_broadcast_rgb_property(connector); intel_attach_broadcast_rgb_property(connector);
} }
......
...@@ -236,6 +236,7 @@ struct intel_unpin_work { ...@@ -236,6 +236,7 @@ struct intel_unpin_work {
int intel_ddc_get_modes(struct drm_connector *c, struct i2c_adapter *adapter); int intel_ddc_get_modes(struct drm_connector *c, struct i2c_adapter *adapter);
extern bool intel_ddc_probe(struct intel_encoder *intel_encoder, int ddc_bus); extern bool intel_ddc_probe(struct intel_encoder *intel_encoder, int ddc_bus);
extern void intel_attach_force_audio_property(struct drm_connector *connector);
extern void intel_attach_broadcast_rgb_property(struct drm_connector *connector); extern void intel_attach_broadcast_rgb_property(struct drm_connector *connector);
extern void intel_crt_init(struct drm_device *dev); extern void intel_crt_init(struct drm_device *dev);
......
...@@ -45,7 +45,6 @@ struct intel_hdmi { ...@@ -45,7 +45,6 @@ struct intel_hdmi {
bool has_hdmi_sink; bool has_hdmi_sink;
bool has_audio; bool has_audio;
int force_audio; int force_audio;
struct drm_property *force_audio_property;
}; };
static struct intel_hdmi *enc_to_intel_hdmi(struct drm_encoder *encoder) static struct intel_hdmi *enc_to_intel_hdmi(struct drm_encoder *encoder)
...@@ -287,7 +286,7 @@ intel_hdmi_set_property(struct drm_connector *connector, ...@@ -287,7 +286,7 @@ intel_hdmi_set_property(struct drm_connector *connector,
if (ret) if (ret)
return ret; return ret;
if (property == intel_hdmi->force_audio_property) { if (property == dev_priv->force_audio_property) {
int i = val; int i = val;
bool has_audio; bool has_audio;
...@@ -365,16 +364,7 @@ static const struct drm_encoder_funcs intel_hdmi_enc_funcs = { ...@@ -365,16 +364,7 @@ static const struct drm_encoder_funcs intel_hdmi_enc_funcs = {
static void static void
intel_hdmi_add_properties(struct intel_hdmi *intel_hdmi, struct drm_connector *connector) intel_hdmi_add_properties(struct intel_hdmi *intel_hdmi, struct drm_connector *connector)
{ {
struct drm_device *dev = connector->dev; intel_attach_force_audio_property(connector);
intel_hdmi->force_audio_property =
drm_property_create(dev, DRM_MODE_PROP_RANGE, "force_audio", 2);
if (intel_hdmi->force_audio_property) {
intel_hdmi->force_audio_property->values[0] = -1;
intel_hdmi->force_audio_property->values[1] = 1;
drm_connector_attach_property(connector, intel_hdmi->force_audio_property, 0);
}
intel_attach_broadcast_rgb_property(connector); intel_attach_broadcast_rgb_property(connector);
} }
......
...@@ -81,6 +81,36 @@ int intel_ddc_get_modes(struct drm_connector *connector, ...@@ -81,6 +81,36 @@ int intel_ddc_get_modes(struct drm_connector *connector,
return ret; return ret;
} }
static const char *force_audio_names[] = {
"off",
"auto",
"on",
};
void
intel_attach_force_audio_property(struct drm_connector *connector)
{
struct drm_device *dev = connector->dev;
struct drm_i915_private *dev_priv = dev->dev_private;
struct drm_property *prop;
int i;
prop = dev_priv->force_audio_property;
if (prop == NULL) {
prop = drm_property_create(dev, DRM_MODE_PROP_ENUM,
"audio",
ARRAY_SIZE(force_audio_names));
if (prop == NULL)
return;
for (i = 0; i < ARRAY_SIZE(force_audio_names); i++)
drm_property_add_enum(prop, i, i-1, force_audio_names[i]);
dev_priv->force_audio_property = prop;
}
drm_connector_attach_property(connector, prop, 0);
}
static const char *broadcast_rgb_names[] = { static const char *broadcast_rgb_names[] = {
"Full", "Full",
"Limited 16:235", "Limited 16:235",
......
...@@ -148,8 +148,6 @@ struct intel_sdvo_connector { ...@@ -148,8 +148,6 @@ struct intel_sdvo_connector {
int format_supported_num; int format_supported_num;
struct drm_property *tv_format; struct drm_property *tv_format;
struct drm_property *force_audio_property;
/* add the property for the SDVO-TV */ /* add the property for the SDVO-TV */
struct drm_property *left; struct drm_property *left;
struct drm_property *right; struct drm_property *right;
...@@ -1712,7 +1710,7 @@ intel_sdvo_set_property(struct drm_connector *connector, ...@@ -1712,7 +1710,7 @@ intel_sdvo_set_property(struct drm_connector *connector,
if (ret) if (ret)
return ret; return ret;
if (property == intel_sdvo_connector->force_audio_property) { if (property == dev_priv->force_audio_property) {
int i = val; int i = val;
bool has_audio; bool has_audio;
...@@ -2037,15 +2035,7 @@ intel_sdvo_add_hdmi_properties(struct intel_sdvo_connector *connector) ...@@ -2037,15 +2035,7 @@ intel_sdvo_add_hdmi_properties(struct intel_sdvo_connector *connector)
{ {
struct drm_device *dev = connector->base.base.dev; struct drm_device *dev = connector->base.base.dev;
connector->force_audio_property = intel_attach_force_audio_property(&connector->base.base);
drm_property_create(dev, DRM_MODE_PROP_RANGE, "force_audio", 2);
if (connector->force_audio_property) {
connector->force_audio_property->values[0] = -1;
connector->force_audio_property->values[1] = 1;
drm_connector_attach_property(&connector->base.base,
connector->force_audio_property, 0);
}
if (INTEL_INFO(dev)->gen >= 4 && IS_MOBILE(dev)) if (INTEL_INFO(dev)->gen >= 4 && IS_MOBILE(dev))
intel_attach_broadcast_rgb_property(&connector->base.base); intel_attach_broadcast_rgb_property(&connector->base.base);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment