1/* SPDX-License-Identifier: MIT */
2/*
3 * Copyright © 2019 Intel Corporation
4 */
5
6#ifndef __INTEL_GMBUS_H__
7#define __INTEL_GMBUS_H__
8
9#include <linux/types.h>
10
11struct drm_i915_private;
12struct i2c_adapter;
13
14#define GMBUS_PIN_DISABLED 0
15#define GMBUS_PIN_SSC 1
16#define GMBUS_PIN_VGADDC 2
17#define GMBUS_PIN_PANEL 3
18#define GMBUS_PIN_DPD_CHV 3 /* HDMID_CHV */
19#define GMBUS_PIN_DPC 4 /* HDMIC */
20#define GMBUS_PIN_DPB 5 /* SDVO, HDMIB */
21#define GMBUS_PIN_DPD 6 /* HDMID */
22#define GMBUS_PIN_RESERVED 7 /* 7 reserved */
23#define GMBUS_PIN_1_BXT 1 /* BXT+ (atom) and CNP+ (big core) */
24#define GMBUS_PIN_2_BXT 2
25#define GMBUS_PIN_3_BXT 3
26#define GMBUS_PIN_4_CNP 4
27#define GMBUS_PIN_5_MTP 5
28#define GMBUS_PIN_9_TC1_ICP 9
29#define GMBUS_PIN_10_TC2_ICP 10
30#define GMBUS_PIN_11_TC3_ICP 11
31#define GMBUS_PIN_12_TC4_ICP 12
32#define GMBUS_PIN_13_TC5_TGP 13
33#define GMBUS_PIN_14_TC6_TGP 14
34
35#define GMBUS_NUM_PINS 15 /* including 0 */
36
37int intel_gmbus_setup(struct drm_i915_private *dev_priv);
38void intel_gmbus_teardown(struct drm_i915_private *dev_priv);
39bool intel_gmbus_is_valid_pin(struct drm_i915_private *dev_priv,
40 unsigned int pin);
41int intel_gmbus_output_aksv(struct i2c_adapter *adapter);
42
43struct i2c_adapter *
44intel_gmbus_get_adapter(struct drm_i915_private *dev_priv, unsigned int pin);
45void intel_gmbus_force_bit(struct i2c_adapter *adapter, bool force_bit);
46bool intel_gmbus_is_forced_bit(struct i2c_adapter *adapter);
47void intel_gmbus_reset(struct drm_i915_private *dev_priv);
48
49void intel_gmbus_irq_handler(struct drm_i915_private *i915);
50
51#endif /* __INTEL_GMBUS_H__ */
52

source code of linux/drivers/gpu/drm/i915/display/intel_gmbus.h