2016-02-19 20:30:26 +08:00
|
|
|
/*
|
|
|
|
* ARC PGU DRM driver.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2016 Synopsys, Inc. (www.synopsys.com)
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-10-19 15:46:18 +08:00
|
|
|
#include <drm/drm_crtc.h>
|
2018-01-17 22:17:55 +08:00
|
|
|
#include <drm/drm_encoder.h>
|
|
|
|
#include <drm/drm_device.h>
|
2016-02-19 20:30:26 +08:00
|
|
|
|
|
|
|
#include "arcpgu.h"
|
|
|
|
|
|
|
|
static struct drm_encoder_funcs arcpgu_drm_encoder_funcs = {
|
|
|
|
.destroy = drm_encoder_cleanup,
|
|
|
|
};
|
|
|
|
|
|
|
|
int arcpgu_drm_hdmi_init(struct drm_device *drm, struct device_node *np)
|
|
|
|
{
|
2016-10-19 15:46:18 +08:00
|
|
|
struct drm_encoder *encoder;
|
|
|
|
struct drm_bridge *bridge;
|
|
|
|
|
|
|
|
int ret = 0;
|
2016-02-19 20:30:26 +08:00
|
|
|
|
|
|
|
encoder = devm_kzalloc(drm->dev, sizeof(*encoder), GFP_KERNEL);
|
|
|
|
if (encoder == NULL)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
2016-10-19 15:46:18 +08:00
|
|
|
/* Locate drm bridge from the hdmi encoder DT node */
|
|
|
|
bridge = of_drm_find_bridge(np);
|
|
|
|
if (!bridge)
|
2016-02-19 20:30:26 +08:00
|
|
|
return -EPROBE_DEFER;
|
|
|
|
|
2016-10-19 15:46:18 +08:00
|
|
|
encoder->possible_crtcs = 1;
|
|
|
|
encoder->possible_clones = 0;
|
|
|
|
ret = drm_encoder_init(drm, encoder, &arcpgu_drm_encoder_funcs,
|
2016-02-19 20:30:26 +08:00
|
|
|
DRM_MODE_ENCODER_TMDS, NULL);
|
|
|
|
if (ret)
|
|
|
|
return ret;
|
|
|
|
|
2016-10-19 15:46:18 +08:00
|
|
|
/* Link drm_bridge to encoder */
|
2016-11-28 23:59:08 +08:00
|
|
|
ret = drm_bridge_attach(encoder, bridge, NULL);
|
2016-10-19 15:46:18 +08:00
|
|
|
if (ret)
|
|
|
|
drm_encoder_cleanup(encoder);
|
2016-02-19 20:30:26 +08:00
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|