* [PATCH 0/2] board: solidrun: clearfog gtr: add serdes configuration
@ 2024-01-06 17:29 Josua Mayer
2024-01-06 17:29 ` [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface Josua Mayer
2024-01-06 17:29 ` [PATCH 2/2] board: solidrun: clearfog: fix serdes 1 / eth2 speed for clearfog gtr Josua Mayer
0 siblings, 2 replies; 5+ messages in thread
From: Josua Mayer @ 2024-01-06 17:29 UTC (permalink / raw)
To: Stefan Roese; +Cc: u-boot, Josua Mayer
Add missing configuration options for clearog gtr serdes:
1. select between sata and pci-e for serdes 0
2. configure serdes 2 for 2.5Gbps link with managed switch
Signed-off-by: Josua Mayer <josua@solid-run.com>
---
Josua Mayer (2):
arm: mvebu: clearfog gtr: add config option to select serdes0 interface
board: solidrun: clearfog: fix serdes 1 / eth2 speed for clearfog gtr
board/solidrun/clearfog/Kconfig | 19 +++++++++++++++++++
board/solidrun/clearfog/clearfog.c | 19 ++++++++++++++++---
2 files changed, 35 insertions(+), 3 deletions(-)
---
base-commit: 82750ce44226e5f2b3bbcd79cf7b3ba3dfd3de4d
change-id: 20240106-clearfog-gtr-serdes-8a927f496bda
Sincerely,
--
Josua Mayer <josua@solid-run.com>
^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface
2024-01-06 17:29 [PATCH 0/2] board: solidrun: clearfog gtr: add serdes configuration Josua Mayer
@ 2024-01-06 17:29 ` Josua Mayer
2024-01-09 11:45 ` Stefan Roese
2024-01-06 17:29 ` [PATCH 2/2] board: solidrun: clearfog: fix serdes 1 / eth2 speed for clearfog gtr Josua Mayer
1 sibling, 1 reply; 5+ messages in thread
From: Josua Mayer @ 2024-01-06 17:29 UTC (permalink / raw)
To: Stefan Roese; +Cc: u-boot, Josua Mayer
Clearfog GTR has an assembly option for a SATA connector, CON18.
It shares the serdes with mini-pcie connector CON3.
Add new kconfig option to select betweenata and pci, defaulting to pci
as it was previously configured in board-file.
Clearfog GTR connects eth2 / serdes 1 to a 2.5Gbps capable ethernet
switch port. Linux already configures a fixed-link at speed 2500 from
device-tree.
Upgrade serdes 1 rate to 3.125Gbps to support a 2.5Gbps network link on
Clearfog GTR.
Signed-off-by: Josua Mayer <josua@solid-run.com>
---
board/solidrun/clearfog/Kconfig | 19 +++++++++++++++++++
board/solidrun/clearfog/clearfog.c | 11 ++++++++---
2 files changed, 27 insertions(+), 3 deletions(-)
diff --git a/board/solidrun/clearfog/Kconfig b/board/solidrun/clearfog/Kconfig
index 60d3921307..765d8a6355 100644
--- a/board/solidrun/clearfog/Kconfig
+++ b/board/solidrun/clearfog/Kconfig
@@ -39,6 +39,25 @@ config CLEARFOG_SFP_25GB
SGMII connection (requires a supporting SFP). By default, transfer speed
of 1.25 Gbps is used, suitable for a more common 1 Gbps SFP module.
+choice CLEARFOG_GTR_SERDES0
+ prompt "Select Clearfog GTR SerDes 0 Function"
+ help
+ Select function for SerDes 0 which is shared between CON3 and CON18
+ for either pci-e or sata.
+
+config CLEARFOG_GTR_SERDES0_PCIE
+ bool "PCI-E on CON3"
+ default y
+ help
+ Configure SerDes 0 for PCI-E to enable CON3 mini-PCI-E connector.
+
+config CLEARFOG_GTR_SERDES0_SATA
+ bool "SATA on CON18"
+ help
+ Configure SerDes 0 for SATA to enable CON18 SATA connector.
+
+endchoice
+
config ENV_SIZE
hex "Environment Size"
default 0x10000
diff --git a/board/solidrun/clearfog/clearfog.c b/board/solidrun/clearfog/clearfog.c
index 6fa2fe5fe3..51c5be518a 100644
--- a/board/solidrun/clearfog/clearfog.c
+++ b/board/solidrun/clearfog/clearfog.c
@@ -90,9 +90,14 @@ int hws_board_topology_load(struct serdes_map **serdes_map_array, u8 *count)
/* Apply runtime detection changes */
if (sr_product_is(&cf_tlv_data, "Clearfog GTR")) {
- board_serdes_map[0].serdes_type = PEX0;
- board_serdes_map[0].serdes_speed = SERDES_SPEED_5_GBPS;
- board_serdes_map[0].serdes_mode = PEX_ROOT_COMPLEX_X1;
+ if (IS_ENABLED(CONFIG_CLEARFOG_GTR_SERDES0_SATA)) {
+ /* serdes 0 is sata (like clearfog pro) */
+ } else if (IS_ENABLED(CONFIG_CLEARFOG_GTR_SERDES0_PCIE)) {
+ /* serdes 0 is pci */
+ board_serdes_map[0].serdes_type = PEX0;
+ board_serdes_map[0].serdes_speed = SERDES_SPEED_5_GBPS;
+ board_serdes_map[0].serdes_mode = PEX_ROOT_COMPLEX_X1;
+ }
} else if (sr_product_is(&cf_tlv_data, "Clearfog Pro")) {
/* handle recognized product as noop, no adjustment required */
} else if (sr_product_is(&cf_tlv_data, "Clearfog Base")) {
--
2.35.3
^ permalink raw reply related [flat|nested] 5+ messages in thread
* [PATCH 2/2] board: solidrun: clearfog: fix serdes 1 / eth2 speed for clearfog gtr
2024-01-06 17:29 [PATCH 0/2] board: solidrun: clearfog gtr: add serdes configuration Josua Mayer
2024-01-06 17:29 ` [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface Josua Mayer
@ 2024-01-06 17:29 ` Josua Mayer
1 sibling, 0 replies; 5+ messages in thread
From: Josua Mayer @ 2024-01-06 17:29 UTC (permalink / raw)
To: Stefan Roese; +Cc: u-boot, Josua Mayer
Clearfog GTR connects eth2 / serdes 1 to a 2.5Gbps capable ethernet
switch port. Linux already configures a fixed-link at speed 2500 from
device-tree.
Upgrade serdes 1 rate to 3.125Gbps to support a 2.5Gbps link.
Additionally add comments documenting each serdes' function of clearfog
gtr, which are shared with clearfog pro.
Signed-off-by: Josua Mayer <josua@solid-run.com>
---
board/solidrun/clearfog/clearfog.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/board/solidrun/clearfog/clearfog.c b/board/solidrun/clearfog/clearfog.c
index 51c5be518a..6977db0a9e 100644
--- a/board/solidrun/clearfog/clearfog.c
+++ b/board/solidrun/clearfog/clearfog.c
@@ -98,6 +98,14 @@ int hws_board_topology_load(struct serdes_map **serdes_map_array, u8 *count)
board_serdes_map[0].serdes_speed = SERDES_SPEED_5_GBPS;
board_serdes_map[0].serdes_mode = PEX_ROOT_COMPLEX_X1;
}
+ /* serdes 1 is 2.5Gbps fixed link to ethernet switch */
+ board_serdes_map[1].serdes_type = SGMII1;
+ board_serdes_map[1].serdes_speed = SERDES_SPEED_3_125_GBPS;
+ board_serdes_map[1].serdes_mode = SERDES_DEFAULT_MODE;
+ /* serdes 2 is pci (like clearfog pro) */
+ /* serdes 3 is usb-3 (like clearfog pro) */
+ /* serdes 4 is pci (like clearfog pro) */
+ /* serdes 5 is sfp connector (like clearfog pro) */
} else if (sr_product_is(&cf_tlv_data, "Clearfog Pro")) {
/* handle recognized product as noop, no adjustment required */
} else if (sr_product_is(&cf_tlv_data, "Clearfog Base")) {
--
2.35.3
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface
2024-01-06 17:29 ` [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface Josua Mayer
@ 2024-01-09 11:45 ` Stefan Roese
2024-01-12 13:32 ` Josua Mayer
0 siblings, 1 reply; 5+ messages in thread
From: Stefan Roese @ 2024-01-09 11:45 UTC (permalink / raw)
To: Josua Mayer; +Cc: u-boot
On 1/6/24 18:29, Josua Mayer wrote:
> Clearfog GTR has an assembly option for a SATA connector, CON18.
> It shares the serdes with mini-pcie connector CON3.
>
> Add new kconfig option to select betweenata and pci, defaulting to pci
> as it was previously configured in board-file.
>
> Clearfog GTR connects eth2 / serdes 1 to a 2.5Gbps capable ethernet
> switch port. Linux already configures a fixed-link at speed 2500 from
> device-tree.
> Upgrade serdes 1 rate to 3.125Gbps to support a 2.5Gbps network link on
> Clearfog GTR.
>
> Signed-off-by: Josua Mayer <josua@solid-run.com>
> ---
> board/solidrun/clearfog/Kconfig | 19 +++++++++++++++++++
> board/solidrun/clearfog/clearfog.c | 11 ++++++++---
> 2 files changed, 27 insertions(+), 3 deletions(-)
>
> diff --git a/board/solidrun/clearfog/Kconfig b/board/solidrun/clearfog/Kconfig
> index 60d3921307..765d8a6355 100644
> --- a/board/solidrun/clearfog/Kconfig
> +++ b/board/solidrun/clearfog/Kconfig
> @@ -39,6 +39,25 @@ config CLEARFOG_SFP_25GB
> SGMII connection (requires a supporting SFP). By default, transfer speed
> of 1.25 Gbps is used, suitable for a more common 1 Gbps SFP module.
>
> +choice CLEARFOG_GTR_SERDES0
> + prompt "Select Clearfog GTR SerDes 0 Function"
> + help
> + Select function for SerDes 0 which is shared between CON3 and CON18
> + for either pci-e or sata.
> +
> +config CLEARFOG_GTR_SERDES0_PCIE
> + bool "PCI-E on CON3"
> + default y
After applying this patch I get this warning:
board/solidrun/clearfog/Kconfig:50:warning: defaults for choice values
not supported
Could you please take a look?
Thanks,
Stefan
> + help
> + Configure SerDes 0 for PCI-E to enable CON3 mini-PCI-E connector.
> +
> +config CLEARFOG_GTR_SERDES0_SATA
> + bool "SATA on CON18"
> + help
> + Configure SerDes 0 for SATA to enable CON18 SATA connector.
> +
> +endchoice
> +
> config ENV_SIZE
> hex "Environment Size"
> default 0x10000
> diff --git a/board/solidrun/clearfog/clearfog.c b/board/solidrun/clearfog/clearfog.c
> index 6fa2fe5fe3..51c5be518a 100644
> --- a/board/solidrun/clearfog/clearfog.c
> +++ b/board/solidrun/clearfog/clearfog.c
> @@ -90,9 +90,14 @@ int hws_board_topology_load(struct serdes_map **serdes_map_array, u8 *count)
>
> /* Apply runtime detection changes */
> if (sr_product_is(&cf_tlv_data, "Clearfog GTR")) {
> - board_serdes_map[0].serdes_type = PEX0;
> - board_serdes_map[0].serdes_speed = SERDES_SPEED_5_GBPS;
> - board_serdes_map[0].serdes_mode = PEX_ROOT_COMPLEX_X1;
> + if (IS_ENABLED(CONFIG_CLEARFOG_GTR_SERDES0_SATA)) {
> + /* serdes 0 is sata (like clearfog pro) */
> + } else if (IS_ENABLED(CONFIG_CLEARFOG_GTR_SERDES0_PCIE)) {
> + /* serdes 0 is pci */
> + board_serdes_map[0].serdes_type = PEX0;
> + board_serdes_map[0].serdes_speed = SERDES_SPEED_5_GBPS;
> + board_serdes_map[0].serdes_mode = PEX_ROOT_COMPLEX_X1;
> + }
> } else if (sr_product_is(&cf_tlv_data, "Clearfog Pro")) {
> /* handle recognized product as noop, no adjustment required */
> } else if (sr_product_is(&cf_tlv_data, "Clearfog Base")) {
>
Viele Grüße,
Stefan Roese
--
DENX Software Engineering GmbH, Managing Director: Erika Unter
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-51 Fax: (+49)-8142-66989-80 Email: sr@denx.de
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface
2024-01-09 11:45 ` Stefan Roese
@ 2024-01-12 13:32 ` Josua Mayer
0 siblings, 0 replies; 5+ messages in thread
From: Josua Mayer @ 2024-01-12 13:32 UTC (permalink / raw)
To: Stefan Roese; +Cc: u-boot@lists.denx.de
Hi Stefan,
Am 09.01.24 um 12:45 schrieb Stefan Roese:
>> +choice CLEARFOG_GTR_SERDES0
>> + prompt "Select Clearfog GTR SerDes 0 Function"
>> + help
>> + Select function for SerDes 0 which is shared between CON3 and CON18
>> + for either pci-e or sata.
>> +
>> +config CLEARFOG_GTR_SERDES0_PCIE
>> + bool "PCI-E on CON3"
>> + default y
>
> After applying this patch I get this warning:
>
> board/solidrun/clearfog/Kconfig:50:warning: defaults for choice values not supported
>
> Could you please take a look?
Thank you, I was mistaken about where the default setting belongs, apparently it belongs to the "choice" - not its elements.
Will send v2 soon.
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2024-01-12 13:32 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-01-06 17:29 [PATCH 0/2] board: solidrun: clearfog gtr: add serdes configuration Josua Mayer
2024-01-06 17:29 ` [PATCH 1/2] arm: mvebu: clearfog gtr: add config option to select serdes0 interface Josua Mayer
2024-01-09 11:45 ` Stefan Roese
2024-01-12 13:32 ` Josua Mayer
2024-01-06 17:29 ` [PATCH 2/2] board: solidrun: clearfog: fix serdes 1 / eth2 speed for clearfog gtr Josua Mayer
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox