Commit 814ebf50 authored by Thomas Zimmermann's avatar Thomas Zimmermann

drm/mgag200: Replace struct mga_i2c_chan with struct mgag200_ddc

Rename struct mga_i2c_chan to struct mgag200_ddc, define it in the
source file mgag200_i2c.c, and reorder its fields. Rename all related
variables from i2c to ddc. Also rename the i2c adapter accordingly.

Using the term 'ddc' documents the purpose of the code clearly. The
old term 'i2c' could refer to any functionality on an i2c bus. No
functional changes.
Signed-off-by: default avatarThomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: default avatarJocelyn Falempe <jfalempe@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240513125620.6337-7-tzimmermann@suse.de
parent 21cd0785
......@@ -10,9 +10,6 @@
#ifndef __MGAG200_DRV_H__
#define __MGAG200_DRV_H__
#include <linux/i2c-algo-bit.h>
#include <linux/i2c.h>
#include <video/vga.h>
#include <drm/drm_connector.h>
......@@ -189,13 +186,6 @@ static inline struct mgag200_crtc_state *to_mgag200_crtc_state(struct drm_crtc_s
return container_of(base, struct mgag200_crtc_state, base);
}
struct mga_i2c_chan {
struct i2c_adapter adapter;
struct mga_device *mdev;
struct i2c_algo_bit_data bit;
int data, clock;
};
enum mga_type {
G200_PCI,
G200_AGP,
......
......@@ -36,6 +36,16 @@
#include "mgag200_ddc.h"
#include "mgag200_drv.h"
struct mgag200_ddc {
struct mga_device *mdev;
int data;
int clock;
struct i2c_algo_bit_data bit;
struct i2c_adapter adapter;
};
static int mga_i2c_read_gpio(struct mga_device *mdev)
{
WREG8(DAC_INDEX, MGA1064_GEN_IO_DATA);
......@@ -63,62 +73,62 @@ static inline void mga_i2c_set(struct mga_device *mdev, int mask, int state)
static void mga_gpio_setsda(void *data, int state)
{
struct mga_i2c_chan *i2c = data;
struct mgag200_ddc *ddc = data;
mga_i2c_set(i2c->mdev, i2c->data, state);
mga_i2c_set(ddc->mdev, ddc->data, state);
}
static void mga_gpio_setscl(void *data, int state)
{
struct mga_i2c_chan *i2c = data;
struct mgag200_ddc *ddc = data;
mga_i2c_set(i2c->mdev, i2c->clock, state);
mga_i2c_set(ddc->mdev, ddc->clock, state);
}
static int mga_gpio_getsda(void *data)
{
struct mga_i2c_chan *i2c = data;
struct mgag200_ddc *ddc = data;
return (mga_i2c_read_gpio(i2c->mdev) & i2c->data) ? 1 : 0;
return (mga_i2c_read_gpio(ddc->mdev) & ddc->data) ? 1 : 0;
}
static int mga_gpio_getscl(void *data)
{
struct mga_i2c_chan *i2c = data;
struct mgag200_ddc *ddc = data;
return (mga_i2c_read_gpio(i2c->mdev) & i2c->clock) ? 1 : 0;
return (mga_i2c_read_gpio(ddc->mdev) & ddc->clock) ? 1 : 0;
}
static void mgag200_i2c_release(struct drm_device *dev, void *res)
static void mgag200_ddc_release(struct drm_device *dev, void *res)
{
struct mga_i2c_chan *i2c = res;
struct mgag200_ddc *ddc = res;
i2c_del_adapter(&i2c->adapter);
i2c_del_adapter(&ddc->adapter);
}
struct i2c_adapter *mgag200_ddc_create(struct mga_device *mdev)
{
struct drm_device *dev = &mdev->base;
const struct mgag200_device_info *info = mdev->info;
struct mga_i2c_chan *i2c;
struct mgag200_ddc *ddc;
struct i2c_algo_bit_data *bit;
struct i2c_adapter *adapter;
int ret;
i2c = drmm_kzalloc(dev, sizeof(*i2c), GFP_KERNEL);
if (!i2c)
ddc = drmm_kzalloc(dev, sizeof(*ddc), GFP_KERNEL);
if (!ddc)
return ERR_PTR(-ENOMEM);
WREG_DAC(MGA1064_GEN_IO_CTL2, 1);
WREG_DAC(MGA1064_GEN_IO_DATA, 0xff);
WREG_DAC(MGA1064_GEN_IO_CTL, 0);
i2c->mdev = mdev;
i2c->data = BIT(info->i2c.data_bit);
i2c->clock = BIT(info->i2c.clock_bit);
ddc->mdev = mdev;
ddc->data = BIT(info->i2c.data_bit);
ddc->clock = BIT(info->i2c.clock_bit);
bit = &i2c->bit;
bit->data = i2c;
bit = &ddc->bit;
bit->data = ddc;
bit->setsda = mga_gpio_setsda;
bit->setscl = mga_gpio_setscl;
bit->getsda = mga_gpio_getsda;
......@@ -126,18 +136,18 @@ struct i2c_adapter *mgag200_ddc_create(struct mga_device *mdev)
bit->udelay = 10;
bit->timeout = usecs_to_jiffies(2200);
adapter = &i2c->adapter;
adapter = &ddc->adapter;
adapter->owner = THIS_MODULE;
adapter->algo_data = bit;
adapter->dev.parent = dev->dev;
snprintf(adapter->name, sizeof(adapter->name), "mga i2c");
i2c_set_adapdata(adapter, i2c);
snprintf(adapter->name, sizeof(adapter->name), "Matrox DDC bus");
i2c_set_adapdata(adapter, ddc);
ret = i2c_bit_add_bus(adapter);
if (ret)
return ERR_PTR(ret);
ret = drmm_add_action_or_reset(dev, mgag200_i2c_release, i2c);
ret = drmm_add_action_or_reset(dev, mgag200_ddc_release, ddc);
if (ret)
return ERR_PTR(ret);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment