2022-04-14 21:48:18 +08:00
|
|
|
/*************************************************************************
|
|
|
|
* Copyright (C) 2021 Cambricon.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
|
|
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
|
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
|
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
|
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*************************************************************************/
|
|
|
|
#ifndef PYTORCH_MLU_HELPER_HPP_
|
|
|
|
#define PYTORCH_MLU_HELPER_HPP_
|
|
|
|
|
|
|
|
#ifdef MMCV_WITH_MLU
|
|
|
|
#include "aten.h"
|
|
|
|
|
|
|
|
#define NFU_ALIGN_SIZE 128
|
|
|
|
|
|
|
|
#define PAD_UP(x, y) (((x) / (y) + (int)((x) % (y) > 0)) * (y))
|
|
|
|
|
|
|
|
#define PAD_DOWN(x, y) (((x) / (y)) * (y))
|
|
|
|
|
2022-08-19 10:36:26 +08:00
|
|
|
#define CEIL_DIV(x, y) (((x) + (y)-1) / (y))
|
|
|
|
|
2022-06-08 14:13:28 +08:00
|
|
|
#define CEIL_ALIGN(x, y) (((x) + (y)-1) / (y) * (y))
|
|
|
|
|
2022-10-18 14:24:27 +08:00
|
|
|
inline int32_t getJobLimitCapability() {
|
|
|
|
CNcontext drv_ctx;
|
|
|
|
CNctxConfigParam ctx_conf_param;
|
|
|
|
TORCH_CHECK(
|
|
|
|
CN_SUCCESS == cnGetCtxConfigParam(drv_ctx, CN_CTX_CONFIG_UNION_LIMIT,
|
|
|
|
&ctx_conf_param),
|
|
|
|
"cnGetCtxConfigParam fails.");
|
|
|
|
return (int32_t)ctx_conf_param.unionLimit;
|
|
|
|
}
|
|
|
|
|
2022-08-19 10:36:26 +08:00
|
|
|
#endif // MMCV_WITH_MLU
|
2022-04-14 21:48:18 +08:00
|
|
|
|
|
|
|
#endif // PYTORCH_MLU_HELPER_HPP_
|