summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/i915/display/vlv_sideband.c
blob: e18045f2b89d22a24bdd527022c3e23628929447 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// SPDX-License-Identifier: MIT
/* Copyright © 2025 Intel Corporation */

#include <drm/drm_print.h>

#include "intel_display_core.h"
#include "intel_display_types.h"
#include "intel_dpio_phy.h"
#include "vlv_sideband.h"

static enum vlv_iosf_sb_unit vlv_dpio_phy_to_unit(struct intel_display *display,
						  enum dpio_phy phy)
{
	/*
	 * IOSF_PORT_DPIO: VLV x2 PHY (DP/HDMI B and C), CHV x1 PHY (DP/HDMI D)
	 * IOSF_PORT_DPIO_2: CHV x2 PHY (DP/HDMI B and C)
	 */
	if (display->platform.cherryview)
		return phy == DPIO_PHY0 ? VLV_IOSF_SB_DPIO_2 : VLV_IOSF_SB_DPIO;
	else
		return VLV_IOSF_SB_DPIO;
}

u32 vlv_dpio_read(struct drm_device *drm, enum dpio_phy phy, int reg)
{
	struct intel_display *display = to_intel_display(drm);
	enum vlv_iosf_sb_unit unit = vlv_dpio_phy_to_unit(display, phy);
	u32 val;

	val = vlv_iosf_sb_read(drm, unit, reg);

	/*
	 * FIXME: There might be some registers where all 1's is a valid value,
	 * so ideally we should check the register offset instead...
	 */
	drm_WARN(display->drm, val == 0xffffffff,
		 "DPIO PHY%d read reg 0x%x == 0x%x\n",
		 phy, reg, val);

	return val;
}

void vlv_dpio_write(struct drm_device *drm,
		    enum dpio_phy phy, int reg, u32 val)
{
	struct intel_display *display = to_intel_display(drm);
	enum vlv_iosf_sb_unit unit = vlv_dpio_phy_to_unit(display, phy);

	vlv_iosf_sb_write(drm, unit, reg, val);
}