mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-09-01 23:46:45 +00:00

With users both in i915 core and display, struct drm_device is the common denominator for the VLV IOSF SB users. Also use drm_device for the helpers on the display side to keep the static inlines as simple as possible. We can drop a number of dependencies on i915_drv.h with this. v2,v3: Rebase Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://lore.kernel.org/r/c1d013ed88ce2e3e5bdc15ce3bf01a3960b1e817.1747061743.git.jani.nikula@intel.com Signed-off-by: Jani Nikula <jani.nikula@intel.com>
51 lines
1.3 KiB
C
51 lines
1.3 KiB
C
// 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);
|
|
}
|