Contributors: 15
Author Tokens Token Proportion Commits Commit Proportion
Daniele Ceraolo Spurio 87 42.44% 1 3.85%
Jani Nikula 43 20.98% 6 23.08%
Jesse Barnes 17 8.29% 3 11.54%
Daniel Kurtz 13 6.34% 2 7.69%
Ville Syrjälä 9 4.39% 2 7.69%
Chris Wilson 7 3.41% 3 11.54%
Imre Deak 5 2.44% 1 3.85%
Zhenyu Wang 4 1.95% 1 3.85%
Radhakrishna Sripada 4 1.95% 1 3.85%
Zou Nan hai 4 1.95% 1 3.85%
Sean Paul 3 1.46% 1 3.85%
Yuanhan Liu 3 1.46% 1 3.85%
Keith Packard 2 0.98% 1 3.85%
Ander Conselvan de Oliveira 2 0.98% 1 3.85%
Tvrtko A. Ursulin 2 0.98% 1 3.85%
Total 205 26


/* SPDX-License-Identifier: MIT */
/*
 * Copyright © 2019 Intel Corporation
 */

#ifndef __INTEL_GMBUS_H__
#define __INTEL_GMBUS_H__

#include <linux/types.h>

struct drm_i915_private;
struct i2c_adapter;

#define GMBUS_PIN_DISABLED	0
#define GMBUS_PIN_SSC		1
#define GMBUS_PIN_VGADDC	2
#define GMBUS_PIN_PANEL		3
#define GMBUS_PIN_DPD_CHV	3 /* HDMID_CHV */
#define GMBUS_PIN_DPC		4 /* HDMIC */
#define GMBUS_PIN_DPB		5 /* SDVO, HDMIB */
#define GMBUS_PIN_DPD		6 /* HDMID */
#define GMBUS_PIN_RESERVED	7 /* 7 reserved */
#define GMBUS_PIN_1_BXT		1 /* BXT+ (atom) and CNP+ (big core) */
#define GMBUS_PIN_2_BXT		2
#define GMBUS_PIN_3_BXT		3
#define GMBUS_PIN_4_CNP		4
#define GMBUS_PIN_5_MTP		5
#define GMBUS_PIN_9_TC1_ICP	9
#define GMBUS_PIN_10_TC2_ICP	10
#define GMBUS_PIN_11_TC3_ICP	11
#define GMBUS_PIN_12_TC4_ICP	12
#define GMBUS_PIN_13_TC5_TGP	13
#define GMBUS_PIN_14_TC6_TGP	14

#define GMBUS_NUM_PINS	15 /* including 0 */

int intel_gmbus_setup(struct drm_i915_private *dev_priv);
void intel_gmbus_teardown(struct drm_i915_private *dev_priv);
bool intel_gmbus_is_valid_pin(struct drm_i915_private *dev_priv,
			      unsigned int pin);
int intel_gmbus_output_aksv(struct i2c_adapter *adapter);

struct i2c_adapter *
intel_gmbus_get_adapter(struct drm_i915_private *dev_priv, unsigned int pin);
void intel_gmbus_force_bit(struct i2c_adapter *adapter, bool force_bit);
bool intel_gmbus_is_forced_bit(struct i2c_adapter *adapter);
void intel_gmbus_reset(struct drm_i915_private *dev_priv);

void intel_gmbus_irq_handler(struct drm_i915_private *i915);

#endif /* __INTEL_GMBUS_H__ */