/* * Copyright (c) 2019 The Linux Foundation. All rights reserved. * * Permission to use, copy, modify, and/or distribute this software for * any purpose with or without fee is hereby granted, provided that the * above copyright notice and this permission notice appear in all * copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR * PERFORMANCE OF THIS SOFTWARE. */ /** * DOC: qdf_dev * This file provides OS dependent device related APIs */ #include "qdf_dev.h" #include "qdf_mem.h" #include "qdf_util.h" #include "qdf_module.h" #include #if 1 #if CONFIG_THERMAL #include #endif #endif QDF_STATUS qdf_dev_alloc_mem(struct device *qdfdev, void **mrptr, uint32_t reqsize, uint32_t mask) { if (!qdfdev) return QDF_STATUS_E_INVAL; *mrptr = devm_kzalloc(qdfdev, reqsize, mask); return QDF_STATUS_SUCCESS; } qdf_export_symbol(qdf_dev_alloc_mem); QDF_STATUS qdf_dev_release_mem(struct qdf_dev *qdfdev, void *mrptr) { if (!mrptr) return QDF_STATUS_E_INVAL; devm_kfree((struct device *)qdfdev, mrptr); return QDF_STATUS_SUCCESS; } qdf_export_symbol(qdf_dev_release_mem); void qdf_device_remove_file(struct device *dev, struct device_attribute *attr) { device_remove_file(dev,attr); } #if 1 #if CONFIG_THERMAL #if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0) void qdf_thermal_cooling_device_unregister(struct thermal_cooling_device * dev) { return thermal_cooling_device_unregister(dev); } qdf_export_symbol(qdf_thermal_cooling_device_unregister); struct thermal_cooling_device * qdf_thermal_of_cooling_device_register(struct device_node * node, char * cool_type, void * data, const struct thermal_cooling_device_ops * cool_ops) { return thermal_of_cooling_device_register(node, cool_type, data, cool_ops); } qdf_export_symbol(qdf_thermal_of_cooling_device_register); #endif #endif #endif