2021-11-22 21:01:38 +08:00
|
|
|
/**
|
|
|
|
* Copyright 2021 Huawei Technologies Co., Ltd
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
#ifndef MINDSPORE_INCLUDE_C_API_CONTEXT_C_H
|
|
|
|
#define MINDSPORE_INCLUDE_C_API_CONTEXT_C_H
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "include/c_api/types_c.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef void *MSContextHandle;
|
|
|
|
typedef void *MSDeviceInfoHandle;
|
|
|
|
|
|
|
|
/// \brief Create a context object.
|
|
|
|
///
|
|
|
|
/// \return Context object handle.
|
|
|
|
MS_API MSContextHandle MSContextCreate();
|
|
|
|
|
|
|
|
/// \brief Destroy the context object.
|
|
|
|
///
|
2021-11-24 11:03:24 +08:00
|
|
|
/// \param[in] context Context object handle address.
|
|
|
|
MS_API void MSContextDestroy(MSContextHandle *context);
|
2021-11-22 21:01:38 +08:00
|
|
|
|
|
|
|
/// \brief Set the number of threads at runtime.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
/// \param[in] thread_num the number of threads at runtime.
|
|
|
|
MS_API void MSContextSetThreadNum(MSContextHandle context, int32_t thread_num);
|
|
|
|
|
|
|
|
/// \brief Obtain the current thread number setting.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
///
|
|
|
|
/// \return The current thread number setting.
|
|
|
|
MS_API int32_t MSContextGetThreadNum(const MSContextHandle context);
|
|
|
|
|
|
|
|
/// \brief Set the thread affinity to CPU cores.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
/// \param[in] mode: 0: no affinities, 1: big cores first, 2: little cores first
|
|
|
|
MS_API void MSContextSetThreadAffinityMode(MSContextHandle context, int mode);
|
|
|
|
|
|
|
|
/// \brief Obtain the thread affinity of CPU cores.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
///
|
|
|
|
/// \return Thread affinity to CPU cores. 0: no affinities, 1: big cores first, 2: little cores first
|
|
|
|
MS_API int MSContextGetThreadAffinityMode(const MSContextHandle context);
|
|
|
|
|
|
|
|
/// \brief Set the thread lists to CPU cores.
|
|
|
|
///
|
|
|
|
/// \note If core_list and mode are set by MSContextSetThreadAffinityMode at the same time,
|
|
|
|
/// the core_list is effective, but the mode is not effective.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
/// \param[in] core_list: a array of thread core lists.
|
|
|
|
/// \param[in] core_num The number of core.
|
|
|
|
MS_API void MSContextSetThreadAffinityCoreList(MSContextHandle context, const int32_t *core_list, size_t core_num);
|
|
|
|
|
|
|
|
/// \brief Obtain the thread lists of CPU cores.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
/// \param[out] core_num The number of core.
|
|
|
|
///
|
|
|
|
/// \return a array of thread core lists.
|
|
|
|
MS_API const int32_t *MSContextGetThreadAffinityCoreList(const MSContextHandle context, size_t *core_num);
|
|
|
|
|
|
|
|
/// \brief Set the status whether to perform model inference or training in parallel.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
/// \param[in] is_parallel: true, parallel; false, not in parallel.
|
|
|
|
MS_API void MSContextSetEnableParallel(MSContextHandle context, bool is_parallel);
|
|
|
|
|
|
|
|
/// \brief Obtain the status whether to perform model inference or training in parallel.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
///
|
|
|
|
/// \return Bool value that indicates whether in parallel.
|
|
|
|
MS_API bool MSContextGetEnableParallel(const MSContextHandle context);
|
|
|
|
|
|
|
|
/// \brief Add device info to context object.
|
|
|
|
///
|
|
|
|
/// \param[in] context Context object handle.
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
MS_API void MSContextAddDeviceInfo(MSContextHandle context, MSDeviceInfoHandle device_info);
|
|
|
|
|
|
|
|
/// \brief Create a device info object.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
///
|
|
|
|
/// \return Device info object handle.
|
|
|
|
MS_API MSDeviceInfoHandle MSDeviceInfoCreate(MSDeviceType device_type);
|
|
|
|
|
|
|
|
/// \brief Destroy the device info object.
|
|
|
|
///
|
2021-11-24 11:03:24 +08:00
|
|
|
/// \param[in] device_info Device info object handle address.
|
|
|
|
MS_API void MSDeviceInfoDestroy(MSDeviceInfoHandle *device_info);
|
2021-11-22 21:01:38 +08:00
|
|
|
|
|
|
|
/// \brief Set provider's name.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
/// \param[in] provider define the provider's name.
|
|
|
|
MS_API void MSDeviceInfoSetProvider(MSDeviceInfoHandle device_info, const char *provider);
|
|
|
|
|
|
|
|
/// \brief Obtain provider's name
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
///
|
|
|
|
/// \return provider's name.
|
|
|
|
MS_API const char *MSDeviceInfoGetProvider(const MSDeviceInfoHandle device_info);
|
|
|
|
|
|
|
|
/// \brief Set provider's device type.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
/// \param[in] device define the provider's device type. EG: CPU.
|
|
|
|
MS_API void MSDeviceInfoSetProviderDevice(MSDeviceInfoHandle device_info, const char *device);
|
|
|
|
|
|
|
|
/// \brief Obtain provider's device type.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
///
|
|
|
|
/// \return provider's device type.
|
|
|
|
MS_API const char *MSDeviceInfoGetProviderDevice(const MSDeviceInfoHandle device_info);
|
|
|
|
|
|
|
|
/// \brief Obtain the device type of the device info.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
///
|
|
|
|
/// \return Device Type of the device info.
|
|
|
|
MS_API MSDeviceType MSDeviceInfoGetDeviceType(const MSDeviceInfoHandle device_info);
|
|
|
|
|
|
|
|
/// \brief Set enables to perform the float16 inference, Only valid for CPU/GPU.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
/// \param[in] is_fp16 Enable float16 inference or not.
|
|
|
|
MS_API void MSDeviceInfoSetEnableFP16(MSDeviceInfoHandle device_info, bool is_fp16);
|
|
|
|
|
|
|
|
/// \brief Obtain enables to perform the float16 inference, Only valid for CPU/GPU.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
///
|
|
|
|
/// \return Whether enable float16 inference.
|
|
|
|
MS_API bool MSDeviceInfoGetEnableFP16(const MSDeviceInfoHandle device_info);
|
|
|
|
|
|
|
|
/// \brief Set the NPU frequency, Only valid for NPU.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
/// \param[in] frequency Can be set to 1 (low power consumption), 2 (balanced), 3 (high performance), 4 (extreme
|
|
|
|
/// performance), default as 3.
|
|
|
|
MS_API void MSDeviceInfoSetFrequency(MSDeviceInfoHandle device_info, int frequency);
|
|
|
|
|
|
|
|
/// \brief Obtain the NPU frequency, Only valid for NPU.
|
|
|
|
///
|
|
|
|
/// \param[in] device_info Device info object handle.
|
|
|
|
///
|
|
|
|
/// \return NPU frequency
|
|
|
|
MS_API int MSDeviceInfoGetFrequency(const MSDeviceInfoHandle device_info);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif // MINDSPORE_INCLUDE_C_API_CONTEXT_C_H
|