Re: [PATCH v2] cirrus-logic-framebuffer-i2c-support.patch

From: Antonino A. Daplas
Date: Sun Jul 09 2006 - 19:53:15 EST


Krzysztof Halasa wrote:
> Hi,
>
> I've attached the second version of the Cirrus Logic I2C patch.
> Supersedes:
> cirrus-logic-framebuffer-i2c-support.patch
> cirrus-logic-framebuffer-i2c-support-fix.patch
>
> Created against current Linus' tree.
> Thanks.
>
> Signed-off-by: Krzysztof Halasa <khc@xxxxxxxxx>
>


> @@ -2335,6 +2376,36 @@ static int cirrusfb_register(struct cirr
> goto err_dealloc_cmap;
> }
>
> +#ifdef CONFIG_FB_CIRRUS_I2C
> + cinfo->i2c_used = 0;
> + if (cinfo->btype == BT_ALPINE || cinfo->btype == BT_PICASSO4) {
> + vga_wseq(cinfo->regbase, 0x08, 0x41); /* DDC mode: SCL */
> + vga_wseq(cinfo->regbase, 0x08, 0x43); /* DDC mode: SCL + SDA */
> + cinfo->bit_cirrus_data.setsda = alpine_setsda;
> + cinfo->bit_cirrus_data.setscl = alpine_setscl;
> + cinfo->bit_cirrus_data.getsda = alpine_getsda;
> + cinfo->bit_cirrus_data.getscl = alpine_getscl;
> + cinfo->bit_cirrus_data.udelay = 5;
> + cinfo->bit_cirrus_data.mdelay = 1;
> + cinfo->bit_cirrus_data.timeout = HZ;
> + cinfo->bit_cirrus_data.data = cinfo;
> + cinfo->cirrus_ops.owner = THIS_MODULE;
> + cinfo->cirrus_ops.id = I2C_HW_B_CIRRUS;
> + cinfo->cirrus_ops.class = I2C_CLASS_DDC;
> + cinfo->cirrus_ops.algo_data = &cinfo->bit_cirrus_data;
> + cinfo->cirrus_ops.dev.parent = info->device;
> + strlcpy(cinfo->cirrus_ops.name, "Cirrus Logic DDC I2C adapter",
> + I2C_NAME_SIZE);
> + if (!(err = i2c_bit_add_bus(&cinfo->cirrus_ops))) {
> + printk(KERN_DEBUG "Initialized Cirrus Logic I2C"
> + " adapter\n");
> + cinfo->i2c_used = 1;
> + } else
> + printk(KERN_WARNING "Unable to initialize Cirrus"
> + " Logic I2C adapter (result = %i)\n", err);
> + }
> +#endif

Why don't you create a separate function for this, ie cirrusfb_create_i2c()
or something. This way, we eliminate the #ifdef/#endif inside the function.

> +
> DPRINTK ("EXIT, returning 0\n");
> return 0;
>
> @@ -2350,6 +2421,10 @@ static void __devexit cirrusfb_cleanup (
> struct cirrusfb_info *cinfo = info->par;
> DPRINTK ("ENTER\n");
>
> +#ifdef CONFIG_FB_CIRRUS_I2C
> + if (cinfo->i2c_used)
> + i2c_bit_del_bus(&cinfo->cirrus_ops);
> +#endif

Same here.

Tony
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/