• Serge Semin's avatar
    ata: ahci-dwc: Add Baikal-T1 AHCI SATA interface support · 9628711a
    Serge Semin authored
    It's almost fully compatible DWC AHCI SATA IP-core derivative except the
    reference clocks source, which need to be very carefully selected. In
    particular the DWC AHCI SATA PHY can be clocked either from the pads
    ref_pad_clk_{m,p} or from the internal wires ref_alt_clk_{m,n}. In the
    later case the clock signal is generated from the Baikal-T1 CCU SATA PLL.
    The clocks source is selected by means of the ref_use_pad wire connected
    to the CCU SATA reference clock CSR.
    
    In normal situation it would be much more handy to use the internal
    reference clock source, but alas we haven't managed to make the AHCI
    controller working well with it so far. So it's preferable to have the
    controller clocked from the external clock generator and fallback to the
    internal clock source only as a last resort. Other than that the
    controller is full compatible with the DWC AHCI SATA IP-core.
    Signed-off-by: default avatarSerge Semin <Sergey.Semin@baikalelectronics.ru>
    Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
    Signed-off-by: default avatarDamien Le Moal <damien.lemoal@opensource.wdc.com>
    9628711a
ahci_dwc.c 12.8 KB