The mPCIe slots on ClearFog Pro and ClearFog Base may be alternately
configured for SATA usage.

Signed-off-by: Joel Johnson <mrj...@lixil.net>

---

v2 changes:
  - fixed help indentation
v3 changes:
  - none
v4 changes:
  - adjust static SerDes configuration at runtime instead of #ifdef
  - add setting of swap_rx for SATA (as yet untested on hardware)

Baruch, thanks for the pointer on the swap_rx flags. I've added them
here based on your input, my drives for testing are in another office so
I won't be able to do final testing on the updated series for another
day or so.

---
 board/solidrun/clearfog/Kconfig    | 17 +++++++++++++++++
 board/solidrun/clearfog/clearfog.c | 12 ++++++++++++
 2 files changed, 29 insertions(+)

diff --git a/board/solidrun/clearfog/Kconfig b/board/solidrun/clearfog/Kconfig
index fbaeed1a4f..e8c3f53d84 100644
--- a/board/solidrun/clearfog/Kconfig
+++ b/board/solidrun/clearfog/Kconfig
@@ -15,6 +15,23 @@ config TARGET_CLEARFOG_BASE
          detection via additional EEPROM hardware. This option enables 
selecting
          the Base variant for older hardware revisions.
 
+config CLEARFOG_CON3_SATA
+       bool "Use CON3 slot in SATA mode"
+       help
+         Use the CON3 port with SATA protocol instead of the default PCIe.
+         The ClearFog port allows usage of either mSATA or miniPCIe
+         modules, but the desired protocol must be configured at build
+         time since it affects the SerDes topology layout.
+
+config CLEARFOG_CON2_SATA
+       bool "Use CON2 slot in SATA mode"
+       depends on !TARGET_CLEARFOG_BASE
+       help
+         Use the CON2 port with SATA protocol instead of the default PCIe.
+         The ClearFog port allows usage of either mSATA or miniPCIe
+         modules, but the desired protocol must be configured at build
+         time since it affects the SerDes topology layout.
+
 config CLEARFOG_SFP_25GB
        bool "Enable 2.5 Gbps mode for SFP"
        help
diff --git a/board/solidrun/clearfog/clearfog.c 
b/board/solidrun/clearfog/clearfog.c
index 6c5b9a784f..3867855aff 100644
--- a/board/solidrun/clearfog/clearfog.c
+++ b/board/solidrun/clearfog/clearfog.c
@@ -58,6 +58,18 @@ void config_static_serdes_map(void)
                board_serdes_map[4].serdes_type = USB3_HOST0;
                board_serdes_map[4].serdes_speed = SERDES_SPEED_5_GBPS;
                board_serdes_map[4].serdes_mode = SERDES_DEFAULT_MODE;
+       } else if (IS_ENABLED(CONFIG_CLEARFOG_CON2_SATA)) {
+               board_serdes_map[4].serdes_type = SATA2;
+               board_serdes_map[4].serdes_speed = SERDES_SPEED_3_GBPS;
+               board_serdes_map[4].serdes_mode = SERDES_DEFAULT_MODE;
+               board_serdes_map[4].swap_rx = 1;
+       }
+
+       if (IS_ENABLED(CONFIG_CLEARFOG_CON3_SATA)) {
+               board_serdes_map[2].serdes_type = SATA1;
+               board_serdes_map[2].serdes_speed = SERDES_SPEED_3_GBPS;
+               board_serdes_map[2].serdes_mode = SERDES_DEFAULT_MODE;
+               board_serdes_map[2].swap_rx = 1;
        }
 
        if (IS_ENABLED(CONFIG_CLEARFOG_SFP_25GB))
-- 
2.20.1

Reply via email to