aff95158创建于 2025年12月23日历史提交
/**
 * Copyright (c) 2025 Huawei Technologies Co., Ltd.
 * This program is free software, you can redistribute it and/or modify it under the terms and conditions of
 * CANN Open Software License Agreement Version 2.0 (the "License").
 * Please refer to the License for details. You may not use this file except in compliance with the License.
 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED,
 * INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
 * See LICENSE in the root of the software repository for the full text of the License.
 */

#ifdef CFG_FEATURE_EMMC_INFO

#include <limits.h>
#include <sys/ioctl.h>
#include "securec.h"
#include "dms_user_common.h"
#include "dms/dms_misc_interface.h"
#include "ascend_hal_error.h"
#include "ascend_hal.h"
#include "dms/dms_devdrv_info_comm.h"
#include "devdrv_user_common.h"
#include "dsmi_common_interface.h"
#include "dms_emmc.h"
#include "ascend_dev_num.h"

#ifdef STATIC_SKIP
#define STATIC
#else
#define STATIC static
#endif

#define EMMC_MANUFACTORY_INFO_LEN 512

STATIC int dms_get_emmc_standard_info(unsigned int dev_id, unsigned int vfid, unsigned int subcmd,
                                  void *buf, unsigned int *size)
{
    int ret;
    struct dms_ioctl_arg ioarg = {0};
    struct dsmi_emmc_standard_info_stru emmc_info = {0};
    struct devdrv_emmc_info_para ioarg_in = {0};

    (void)vfid;

    if (*size < sizeof(struct dsmi_emmc_standard_info_stru)) {
        DMS_ERR("Get emmc info failed. input size err\n");
        return DRV_ERROR_PARA_ERROR;
    }

    ioarg_in.dev_id = dev_id;
    ioarg_in.info_type = subcmd;

    ioarg.main_cmd = DMS_MAIN_CMD_EMMC;
    ioarg.sub_cmd = DMS_SUBCMD_GET_EMMC_INFO;
    ioarg.filter_len = 0;
    ioarg.input = &ioarg_in;
    ioarg.input_len = sizeof(struct devdrv_emmc_info_para);
    ioarg.output = (void *)(&emmc_info);
    ioarg.output_len = sizeof(struct dsmi_emmc_standard_info_stru);

    ret = errno_to_user_errno(DmsIoctl(DMS_IOCTL_CMD, &ioarg));
    if (ret != 0) {
        DMS_ERR("Get emmc info failed. (dev_id=%u; ret=%d)\n", dev_id, ret);
        return ret;
    }

    ret = memcpy_s(buf, *size, &emmc_info, sizeof(struct dsmi_emmc_standard_info_stru));
    if (ret != 0) {
        DMS_ERR("memcpy_s failed, (ret=%d)\n", ret);
        return DRV_ERROR_INNER_ERR;
    }
    *size = sizeof(struct dsmi_emmc_standard_info_stru);
    return DRV_ERROR_NONE;
}

STATIC int DmsGetEmmcManufacturerInfo(unsigned int dev_id, unsigned int vfid, unsigned int subcmd,
                                      void *buf, unsigned int *size)
{
    int ret;
    struct dms_ioctl_arg ioarg = {0};
    char emmc_info[EMMC_MANUFACTORY_INFO_LEN];

    (void)vfid;

    struct devdrv_emmc_info_para ioarg_in = {0};

    if (*size < EMMC_MANUFACTORY_INFO_LEN) {
        DMS_ERR("Get emmc info failed. input size err\n");
        return DRV_ERROR_PARA_ERROR;
    }

    ioarg_in.dev_id = dev_id;
    ioarg_in.info_type = subcmd;
    ioarg.main_cmd = DMS_MAIN_CMD_EMMC;
    ioarg.sub_cmd = DMS_SUBCMD_GET_EMMC_INFO;
    ioarg.filter_len = 0;
    ioarg.input = &ioarg_in;
    ioarg.input_len = sizeof(struct devdrv_emmc_info_para);
    ioarg.output = (void *)(emmc_info);
    ioarg.output_len = EMMC_MANUFACTORY_INFO_LEN;

    ret = errno_to_user_errno(DmsIoctl(DMS_IOCTL_CMD, &ioarg));
    if (ret != 0) {
        DMS_ERR("Get emmc info failed. (dev_id=%u; ret=%d)\n", dev_id, ret);
        return ret;
    }

    ret = memcpy_s(buf, *size, emmc_info, EMMC_MANUFACTORY_INFO_LEN);
    if (ret != 0) {
        DMS_ERR("memcpy_s failed, (ret=%d)\n", ret);
        return DRV_ERROR_INNER_ERR;
    }
    *size = EMMC_MANUFACTORY_INFO_LEN;
    return DRV_ERROR_NONE;
}

int dms_get_emmc_info(unsigned int dev_id, unsigned int vfid, unsigned int subcmd,
                   void *buf, unsigned int *size)
{
    int ret;

    if ((dev_id >= ASCEND_DEV_MAX_NUM) || (buf == NULL) || size == NULL) {
        DMS_ERR("Invalid dev_id or buf is NULL. (dev_id=%u)\n", dev_id);
        return DRV_ERROR_PARA_ERROR;
    }
    DMS_EVENT("Get emmc info subcmd = %d\n", subcmd);

    switch (subcmd) {
        case DSMI_EMMC_SUB_CMD_STANDARD_INFO:
            ret = dms_get_emmc_standard_info(dev_id, vfid, subcmd, buf, size);
            break;
        case DSMI_EMMC_SUB_CMD_MANUFACTURER_INFO:
            ret = DmsGetEmmcManufacturerInfo(dev_id, vfid, subcmd, buf, size);
            break;
        default:
            DMS_ERR("Invalid subcmd. (subcmd=%u)\n", subcmd);
            return DRV_ERROR_PARA_ERROR;
    }
    DMS_DEBUG("Get emmc info success.\n");
    return ret;
}
#else
#include "ascend_hal_error.h"
#include "dms_emmc.h"

int dms_get_emmc_info(unsigned int dev_id, unsigned int vfid, unsigned int sub_cmd, void *buf, unsigned int *size)
{
    (void)dev_id;
    (void)vfid;
    (void)sub_cmd;
    (void)buf;
    (void)size;
    return DRV_ERROR_NOT_SUPPORT;
}
#endif