fsata_sinit.c 2.4 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
/*
 * Copyright : (C) 2022 Phytium Information Technology, Inc.
 * All Rights Reserved.
 *
 * This program is OPEN SOURCE software: you can redistribute it and/or modify it
 * under the terms of the Phytium Public License as published by the Phytium Technology Co.,Ltd,
 * either version 1.0 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the Phytium Public License for more details.
 *
 *
 * FilePath: fsata_sinit.c
 * Date: 2022-02-10 14:55:11
 * LastEditTime: 2022-02-18 09:04:15
 * Description:  This files is for sata static init
 *
 * Modify History:
 *  Ver   Who        Date         Changes
 * ----- ------     --------    --------------------------------------
 */

/***************************** Include Files *********************************/

#include "fsata.h"
#include "fparameters.h"
#include "sdkconfig.h"
#include "fassert.h"

/************************** Constant Definitions *****************************/

/**************************** Type Definitions *******************************/

/***************** Macros (Inline Functions) Definitions *********************/

/************************** Function Prototypes ******************************/

/************************** Variable Definitions *****************************/

extern const FSataConfig FSataPcieConfigTbl[PLAT_AHCI_HOST_MAX_COUNT];

#if defined(CONFIG_TARGET_E2000)
    extern const FSataConfig FSataControllerConfigTbl[FSATA_INSTANCE_NUM];
#endif

/*****************************************************************************/
/**
 * @name: FSataLookupConfig
 * @msg: get sata configs by id and type, Support both pcie and SATA controllers
 * @return {FSataConfig *}
 * @param {u32} instance_id, id of sata ctrl
 */
const FSataConfig *FSataLookupConfig(u32 instance_id, u8 type)
{
    const FSataConfig *pconfig = NULL;
    if (type == FSATA_TYPE_CONTROLLER)
    {
#if defined(CONFIG_TARGET_E2000)
        FASSERT(instance_id < FSATA_INSTANCE_NUM);
        pconfig = &FSataControllerConfigTbl[instance_id];
#endif
    }
    else
    {
        FASSERT(instance_id < PLAT_AHCI_HOST_MAX_COUNT);
        pconfig = &FSataPcieConfigTbl[instance_id];
    }

    return (const FSataConfig *)pconfig;
}