mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-04-12 17:34:31 +00:00
pinctrl: gemini: Fix up TVC clock group
The previous fix made the TVC clock get muxed in on the
D-Link DIR-685 instead of giving nagging warnings of this
not working. Not good. We didn't want that, as it breaks
video.
Create a specific group for the TVC CLK, and break out
a specific GPIO group for it on the SL3516 so we can use
that line as GPIO if we don't need the TVC CLK.
Fixes: d17f477c5b
("pinctrl: gemini: Mask and set properly")
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
dab6558f57
commit
a85c928f6a
1 changed files with 36 additions and 8 deletions
|
@ -591,13 +591,16 @@ static const unsigned int tvc_3512_pins[] = {
|
||||||
319, /* TVC_DATA[1] */
|
319, /* TVC_DATA[1] */
|
||||||
301, /* TVC_DATA[2] */
|
301, /* TVC_DATA[2] */
|
||||||
283, /* TVC_DATA[3] */
|
283, /* TVC_DATA[3] */
|
||||||
265, /* TVC_CLK */
|
|
||||||
320, /* TVC_DATA[4] */
|
320, /* TVC_DATA[4] */
|
||||||
302, /* TVC_DATA[5] */
|
302, /* TVC_DATA[5] */
|
||||||
284, /* TVC_DATA[6] */
|
284, /* TVC_DATA[6] */
|
||||||
266, /* TVC_DATA[7] */
|
266, /* TVC_DATA[7] */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const unsigned int tvc_clk_3512_pins[] = {
|
||||||
|
265, /* TVC_CLK */
|
||||||
|
};
|
||||||
|
|
||||||
/* NAND flash pins */
|
/* NAND flash pins */
|
||||||
static const unsigned int nflash_3512_pins[] = {
|
static const unsigned int nflash_3512_pins[] = {
|
||||||
199, 200, 201, 202, 216, 217, 218, 219, 220, 234, 235, 236, 237, 252,
|
199, 200, 201, 202, 216, 217, 218, 219, 220, 234, 235, 236, 237, 252,
|
||||||
|
@ -629,7 +632,7 @@ static const unsigned int pflash_3512_pins_extended[] = {
|
||||||
/* Serial flash pins CE0, CE1, DI, DO, CK */
|
/* Serial flash pins CE0, CE1, DI, DO, CK */
|
||||||
static const unsigned int sflash_3512_pins[] = { 230, 231, 232, 233, 211 };
|
static const unsigned int sflash_3512_pins[] = { 230, 231, 232, 233, 211 };
|
||||||
|
|
||||||
/* The GPIO0A (0) pin overlap with TVC and extended parallel flash */
|
/* The GPIO0A (0) pin overlap with TVC CLK and extended parallel flash */
|
||||||
static const unsigned int gpio0a_3512_pins[] = { 265 };
|
static const unsigned int gpio0a_3512_pins[] = { 265 };
|
||||||
|
|
||||||
/* The GPIO0B (1-4) pins overlap with TVC and ICE */
|
/* The GPIO0B (1-4) pins overlap with TVC and ICE */
|
||||||
|
@ -823,7 +826,13 @@ static const struct gemini_pin_group gemini_3512_pin_groups[] = {
|
||||||
.num_pins = ARRAY_SIZE(tvc_3512_pins),
|
.num_pins = ARRAY_SIZE(tvc_3512_pins),
|
||||||
/* Conflict with character LCD and ICE */
|
/* Conflict with character LCD and ICE */
|
||||||
.mask = LCD_PADS_ENABLE,
|
.mask = LCD_PADS_ENABLE,
|
||||||
.value = TVC_PADS_ENABLE | TVC_CLK_PAD_ENABLE,
|
.value = TVC_PADS_ENABLE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.name = "tvcclkgrp",
|
||||||
|
.pins = tvc_clk_3512_pins,
|
||||||
|
.num_pins = ARRAY_SIZE(tvc_clk_3512_pins),
|
||||||
|
.value = TVC_CLK_PAD_ENABLE,
|
||||||
},
|
},
|
||||||
/*
|
/*
|
||||||
* The construction is done such that it is possible to use a serial
|
* The construction is done such that it is possible to use a serial
|
||||||
|
@ -860,8 +869,8 @@ static const struct gemini_pin_group gemini_3512_pin_groups[] = {
|
||||||
.name = "gpio0agrp",
|
.name = "gpio0agrp",
|
||||||
.pins = gpio0a_3512_pins,
|
.pins = gpio0a_3512_pins,
|
||||||
.num_pins = ARRAY_SIZE(gpio0a_3512_pins),
|
.num_pins = ARRAY_SIZE(gpio0a_3512_pins),
|
||||||
/* Conflict with TVC */
|
/* Conflict with TVC CLK */
|
||||||
.mask = TVC_PADS_ENABLE,
|
.mask = TVC_CLK_PAD_ENABLE,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.name = "gpio0bgrp",
|
.name = "gpio0bgrp",
|
||||||
|
@ -1531,13 +1540,16 @@ static const unsigned int tvc_3516_pins[] = {
|
||||||
311, /* TVC_DATA[1] */
|
311, /* TVC_DATA[1] */
|
||||||
394, /* TVC_DATA[2] */
|
394, /* TVC_DATA[2] */
|
||||||
374, /* TVC_DATA[3] */
|
374, /* TVC_DATA[3] */
|
||||||
333, /* TVC_CLK */
|
|
||||||
354, /* TVC_DATA[4] */
|
354, /* TVC_DATA[4] */
|
||||||
395, /* TVC_DATA[5] */
|
395, /* TVC_DATA[5] */
|
||||||
312, /* TVC_DATA[6] */
|
312, /* TVC_DATA[6] */
|
||||||
334, /* TVC_DATA[7] */
|
334, /* TVC_DATA[7] */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const unsigned int tvc_clk_3516_pins[] = {
|
||||||
|
333, /* TVC_CLK */
|
||||||
|
};
|
||||||
|
|
||||||
/* NAND flash pins */
|
/* NAND flash pins */
|
||||||
static const unsigned int nflash_3516_pins[] = {
|
static const unsigned int nflash_3516_pins[] = {
|
||||||
243, 260, 261, 224, 280, 262, 281, 264, 300, 263, 282, 301, 320, 283,
|
243, 260, 261, 224, 280, 262, 281, 264, 300, 263, 282, 301, 320, 283,
|
||||||
|
@ -1570,7 +1582,7 @@ static const unsigned int pflash_3516_pins_extended[] = {
|
||||||
static const unsigned int sflash_3516_pins[] = { 296, 338, 295, 359, 339 };
|
static const unsigned int sflash_3516_pins[] = { 296, 338, 295, 359, 339 };
|
||||||
|
|
||||||
/* The GPIO0A (0-4) pins overlap with TVC and extended parallel flash */
|
/* The GPIO0A (0-4) pins overlap with TVC and extended parallel flash */
|
||||||
static const unsigned int gpio0a_3516_pins[] = { 333, 354, 395, 312, 334 };
|
static const unsigned int gpio0a_3516_pins[] = { 354, 395, 312, 334 };
|
||||||
|
|
||||||
/* The GPIO0B (5-7) pins overlap with ICE */
|
/* The GPIO0B (5-7) pins overlap with ICE */
|
||||||
static const unsigned int gpio0b_3516_pins[] = { 375, 396, 376 };
|
static const unsigned int gpio0b_3516_pins[] = { 375, 396, 376 };
|
||||||
|
@ -1602,6 +1614,9 @@ static const unsigned int gpio0j_3516_pins[] = { 359, 339 };
|
||||||
/* The GPIO0K (30,31) pins overlap with NAND flash */
|
/* The GPIO0K (30,31) pins overlap with NAND flash */
|
||||||
static const unsigned int gpio0k_3516_pins[] = { 275, 298 };
|
static const unsigned int gpio0k_3516_pins[] = { 275, 298 };
|
||||||
|
|
||||||
|
/* The GPIO0L (0) pins overlap with TVC_CLK */
|
||||||
|
static const unsigned int gpio0l_3516_pins[] = { 333 };
|
||||||
|
|
||||||
/* The GPIO1A (0-4) pins that overlap with IDE and parallel flash */
|
/* The GPIO1A (0-4) pins that overlap with IDE and parallel flash */
|
||||||
static const unsigned int gpio1a_3516_pins[] = { 221, 200, 222, 201, 220 };
|
static const unsigned int gpio1a_3516_pins[] = { 221, 200, 222, 201, 220 };
|
||||||
|
|
||||||
|
@ -1761,7 +1776,13 @@ static const struct gemini_pin_group gemini_3516_pin_groups[] = {
|
||||||
.num_pins = ARRAY_SIZE(tvc_3516_pins),
|
.num_pins = ARRAY_SIZE(tvc_3516_pins),
|
||||||
/* Conflict with character LCD */
|
/* Conflict with character LCD */
|
||||||
.mask = LCD_PADS_ENABLE,
|
.mask = LCD_PADS_ENABLE,
|
||||||
.value = TVC_PADS_ENABLE | TVC_CLK_PAD_ENABLE,
|
.value = TVC_PADS_ENABLE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.name = "tvcclkgrp",
|
||||||
|
.pins = tvc_clk_3516_pins,
|
||||||
|
.num_pins = ARRAY_SIZE(tvc_clk_3516_pins),
|
||||||
|
.value = TVC_CLK_PAD_ENABLE,
|
||||||
},
|
},
|
||||||
/*
|
/*
|
||||||
* The construction is done such that it is possible to use a serial
|
* The construction is done such that it is possible to use a serial
|
||||||
|
@ -1872,6 +1893,13 @@ static const struct gemini_pin_group gemini_3516_pin_groups[] = {
|
||||||
/* Conflict with parallel and NAND flash */
|
/* Conflict with parallel and NAND flash */
|
||||||
.value = PFLASH_PADS_DISABLE | NAND_PADS_DISABLE,
|
.value = PFLASH_PADS_DISABLE | NAND_PADS_DISABLE,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.name = "gpio0lgrp",
|
||||||
|
.pins = gpio0l_3516_pins,
|
||||||
|
.num_pins = ARRAY_SIZE(gpio0l_3516_pins),
|
||||||
|
/* Conflict with TVE CLK */
|
||||||
|
.mask = TVC_CLK_PAD_ENABLE,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.name = "gpio1agrp",
|
.name = "gpio1agrp",
|
||||||
.pins = gpio1a_3516_pins,
|
.pins = gpio1a_3516_pins,
|
||||||
|
|
Loading…
Add table
Reference in a new issue