[PATCH 1/3] drm/ast: Remove unused code paths for AST 1180
Thomas Zimmermann
tzimmermann at suse.de
Wed Jun 17 07:13:14 UTC 2020
Hi Emil
Am 16.06.20 um 01:21 schrieb Emil Velikov:
> Hi Thomas,
>
> On Thu, 11 Jun 2020 at 09:28, Thomas Zimmermann <tzimmermann at suse.de> wrote:
>
>> --- a/drivers/gpu/drm/ast/ast_drv.c
>> +++ b/drivers/gpu/drm/ast/ast_drv.c
>> @@ -59,7 +59,6 @@ static struct drm_driver driver;
>> static const struct pci_device_id pciidlist[] = {
>> AST_VGA_DEVICE(PCI_CHIP_AST2000, NULL),
>> AST_VGA_DEVICE(PCI_CHIP_AST2100, NULL),
>> - /* AST_VGA_DEVICE(PCI_CHIP_AST1180, NULL), - don't bind to 1180 for now */
>
> Since we don't bind to this pciid, the (removed) code is never
> used/dead. For the series:
> Reviewed-by: Emil Velikov <emil.l.velikov at gmail.com>
>
> Small idea below: feel free to ignore or if you agree - follow-up at a
> random point in the future.
>
>
>> + if (dev->pdev->revision >= 0x40) {
>> + ast->chip = AST2500;
>> + DRM_INFO("AST 2500 detected\n");
>> + } else if (dev->pdev->revision >= 0x30) {
>> + ast->chip = AST2400;
>> + DRM_INFO("AST 2400 detected\n");
>> + } else if (dev->pdev->revision >= 0x30) {
>> + ast->chip = AST2400;
>> + DRM_INFO("AST 2400 detected\n");
>> + } else if (dev->pdev->revision >= 0x20) {
>> + ast->chip = AST2300;
>> + DRM_INFO("AST 2300 detected\n");
>> + } else if (dev->pdev->revision >= 0x10) {
>> + switch (scu_rev & 0x0300) {
>> + case 0x0200:
>> + ast->chip = AST1100;
>> + DRM_INFO("AST 1100 detected\n");
>> + break;
>> + case 0x0100:
>> + ast->chip = AST2200;
>> + DRM_INFO("AST 2200 detected\n");
>> + break;
>> + case 0x0000:
>> + ast->chip = AST2150;
>> + DRM_INFO("AST 2150 detected\n");
>> + break;
>> + default:
>> + ast->chip = AST2100;
>> + DRM_INFO("AST 2100 detected\n");
>> + break;
>> }
>> + ast->vga2_clone = false;
>> + } else {
>> + ast->chip = AST2000;
>> + DRM_INFO("AST 2000 detected\n");
>> }
>>
> Instead of the above if/else spaghetti, one can use something alike
>
> static const struct foo {
> u8 rev_maj; // revision & 0xf0 >> 4
> u8 rev_scu; // scu_rev & 0x0300 >> 8, ignored if table has 0xf
> enum ast_chip;
> const char *name;
> } bar {
> { 0x3, 0xf, AST2400, "2400" },
> { 0x2, 0xf, AST2300, "2300" },
> { 0x1, 0x3, AST2100, "2100" },
> { 0x1, 0x2, AST1100, "1100" },
> { 0x1, 0x1, AST2200, "2200" },
> { 0x1, 0x0, AST2150, "2150" },
> { 0x0, 0xf, AST2000, "2000" },
> };
>
> + trivial loop.
I do like the idea, but there's plenty of similar code throughout the
driver. I think a separate patchset could introduce an info structure
with per-chip constants and flags, and fix the entire driver.
Best regards
Thomas
>
> -Emil
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel
>
--
Thomas Zimmermann
Graphics Driver Developer
SUSE Software Solutions Germany GmbH
Maxfeldstr. 5, 90409 Nürnberg, Germany
(HRB 36809, AG Nürnberg)
Geschäftsführer: Felix Imendörffer
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 488 bytes
Desc: OpenPGP digital signature
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20200617/649fbcd3/attachment.sig>
More information about the dri-devel
mailing list