162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * The On Chip Memory (OCMEM) allocator allows various clients to allocate 462306a36Sopenharmony_ci * memory from OCMEM based on performance, latency and power requirements. 562306a36Sopenharmony_ci * This is typically used by the GPU, camera/video, and audio components on 662306a36Sopenharmony_ci * some Snapdragon SoCs. 762306a36Sopenharmony_ci * 862306a36Sopenharmony_ci * Copyright (C) 2019 Brian Masney <masneyb@onstation.org> 962306a36Sopenharmony_ci * Copyright (C) 2015 Red Hat. Author: Rob Clark <robdclark@gmail.com> 1062306a36Sopenharmony_ci */ 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include <linux/device.h> 1362306a36Sopenharmony_ci#include <linux/err.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#ifndef __OCMEM_H__ 1662306a36Sopenharmony_ci#define __OCMEM_H__ 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_cienum ocmem_client { 1962306a36Sopenharmony_ci /* GMEM clients */ 2062306a36Sopenharmony_ci OCMEM_GRAPHICS = 0x0, 2162306a36Sopenharmony_ci /* 2262306a36Sopenharmony_ci * TODO add more once ocmem_allocate() is clever enough to 2362306a36Sopenharmony_ci * deal with multiple clients. 2462306a36Sopenharmony_ci */ 2562306a36Sopenharmony_ci OCMEM_CLIENT_MAX, 2662306a36Sopenharmony_ci}; 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_cistruct ocmem; 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_cistruct ocmem_buf { 3162306a36Sopenharmony_ci unsigned long offset; 3262306a36Sopenharmony_ci unsigned long addr; 3362306a36Sopenharmony_ci unsigned long len; 3462306a36Sopenharmony_ci}; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci#if IS_ENABLED(CONFIG_QCOM_OCMEM) 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_cistruct ocmem *of_get_ocmem(struct device *dev); 3962306a36Sopenharmony_cistruct ocmem_buf *ocmem_allocate(struct ocmem *ocmem, enum ocmem_client client, 4062306a36Sopenharmony_ci unsigned long size); 4162306a36Sopenharmony_civoid ocmem_free(struct ocmem *ocmem, enum ocmem_client client, 4262306a36Sopenharmony_ci struct ocmem_buf *buf); 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci#else /* IS_ENABLED(CONFIG_QCOM_OCMEM) */ 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_cistatic inline struct ocmem *of_get_ocmem(struct device *dev) 4762306a36Sopenharmony_ci{ 4862306a36Sopenharmony_ci return ERR_PTR(-ENODEV); 4962306a36Sopenharmony_ci} 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cistatic inline struct ocmem_buf *ocmem_allocate(struct ocmem *ocmem, 5262306a36Sopenharmony_ci enum ocmem_client client, 5362306a36Sopenharmony_ci unsigned long size) 5462306a36Sopenharmony_ci{ 5562306a36Sopenharmony_ci return ERR_PTR(-ENODEV); 5662306a36Sopenharmony_ci} 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_cistatic inline void ocmem_free(struct ocmem *ocmem, enum ocmem_client client, 5962306a36Sopenharmony_ci struct ocmem_buf *buf) 6062306a36Sopenharmony_ci{ 6162306a36Sopenharmony_ci} 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci#endif /* IS_ENABLED(CONFIG_QCOM_OCMEM) */ 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci#endif /* __OCMEM_H__ */ 66