2 * Copyright (c) 2010 Intel Corporation
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicensen
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
24 * Thomas Eaton <thomas.g.eaton@intel.com>
25 * Scott Rowe <scott.m.rowe@intel.com>
28 #include <linux/init.h>
29 #include "mdfld_dsi_dbi.h"
30 #include "mdfld_dsi_dpi.h"
31 #include "mdfld_dsi_output.h"
32 #include "mdfld_output.h"
33 #include "mdfld_dsi_dbi_dpu.h"
35 #include "displays/tpo_cmd.h"
36 #include "displays/tpo_vid.h"
37 #include "displays/tmd_cmd.h"
38 #include "displays/tmd_vid.h"
39 #include "displays/pyr_cmd.h"
40 #include "displays/pyr_vid.h"
41 /* #include "displays/hdmi.h" */
43 static int mdfld_dual_mipi
;
44 static int mdfld_hdmi
;
47 module_param(mdfld_dual_mipi
, int, 0600);
48 MODULE_PARM_DESC(mdfld_dual_mipi
, "Enable dual MIPI configuration");
49 module_param(mdfld_hdmi
, int, 0600);
50 MODULE_PARM_DESC(mdfld_hdmi
, "Enable Medfield HDMI");
51 module_param(mdfld_dpu
, int, 0600);
52 MODULE_PARM_DESC(mdfld_dpu
, "Enable Medfield DPU");
54 /* For now a single type per device is all we cope with */
55 int mdfld_get_panel_type(struct drm_device
*dev
, int pipe
)
57 struct drm_psb_private
*dev_priv
= dev
->dev_private
;
58 return dev_priv
->panel_id
;
61 int mdfld_panel_dpi(struct drm_device
*dev
)
63 struct drm_psb_private
*dev_priv
= dev
->dev_private
;
65 switch (dev_priv
->panel_id
) {
78 static int init_panel(struct drm_device
*dev
, int mipi_pipe
, int p_type
)
80 struct panel_funcs
*p_cmd_funcs
;
81 struct panel_funcs
*p_vid_funcs
;
83 /* Oh boy ... FIXME */
84 p_cmd_funcs
= kzalloc(sizeof(struct panel_funcs
), GFP_KERNEL
);
85 if (p_cmd_funcs
== NULL
)
87 p_vid_funcs
= kzalloc(sizeof(struct panel_funcs
), GFP_KERNEL
);
88 if (p_vid_funcs
== NULL
) {
95 tpo_cmd_init(dev
, p_cmd_funcs
);
96 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, p_cmd_funcs
, NULL
);
99 tpo_vid_init(dev
, p_vid_funcs
);
100 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, NULL
, p_vid_funcs
);
103 /*tmd_cmd_init(dev, p_cmd_funcs); */
104 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, p_cmd_funcs
, NULL
);
107 tmd_vid_init(dev
, p_vid_funcs
);
108 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, NULL
, p_vid_funcs
);
111 pyr_cmd_init(dev
, p_cmd_funcs
);
112 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, p_cmd_funcs
, NULL
);
115 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, NULL
, p_vid_funcs
);
117 case TPO
: /* TPO panel supports both cmd & vid interfaces */
118 tpo_cmd_init(dev
, p_cmd_funcs
);
119 tpo_vid_init(dev
, p_vid_funcs
);
120 mdfld_dsi_output_init(dev
, mipi_pipe
, NULL
, p_cmd_funcs
,
129 dev_dbg(dev
->dev
, "Initializing HDMI");
130 mdfld_hdmi_init(dev
, &dev_priv
->mode_dev
);
134 dev_err(dev
->dev
, "Unsupported interface %d", p_type
);
140 int mdfld_output_init(struct drm_device
*dev
)
145 type
= mdfld_get_panel_type(dev
, 0);
146 dev_info(dev
->dev
, "panel 1: type is %d\n", type
);
147 init_panel(dev
, 0, type
);
149 if (mdfld_dual_mipi
) {
151 type
= mdfld_get_panel_type(dev
, 2);
152 dev_info(dev
->dev
, "panel 2: type is %d\n", type
);
153 init_panel(dev
, 2, type
);
157 init_panel(dev
, 0, HDMI
);
161 void mdfld_output_setup(struct drm_device
*dev
)
163 /* FIXME: this is not the right place for this stuff ! */
166 mdfld_dbi_dpu_init(dev
);
168 mdfld_dbi_dsr_init(dev
);