kernel_samsung_a53x/drivers/dma-buf/heaps/samsung/rbinregion.h
2024-06-15 16:02:09 -03:00

67 lines
1.9 KiB
C
Executable file

#ifndef _RBIN_REGION_H
#define _RBIN_REGION_H
#include <linux/atomic.h>
#include <linux/kernel.h>
#include <linux/types.h>
#include <linux/mm.h>
#include <linux/genalloc.h>
#include <linux/highmem.h>
#include "../page_pool.h"
#define E_NOREGION 55 // returned when region is disabled
struct rr_handle {
int pool_id; /* Pool index : corresponds to filesystem */
int rb_index; /* Redblack tree index: value equals inode number */
int ra_index; /* Radix tree index : value equals page->index */
int usage; /* indicates current usage of corresponding page */
struct list_head lru; /* use lru of struct page instead */
};
enum usage {
RC_FREED,
RC_INUSE,
DMABUF_FREED,
DMABUF_INUSE,
};
struct region_ops {
void (*evict)(unsigned long);
};
struct rbin_region {
unsigned long start_pfn;
unsigned long nr_pages;
struct rr_handle *handles;
struct list_head freelist; /* protected by lru_lock. handle->lru */
struct list_head usedlist; /* protected by lru_lock. handle->lru */
const struct region_ops *ops;
spinlock_t lru_lock;
spinlock_t region_lock;
struct gen_pool *pool;
int dmabuf_inflight;
int rc_inflight;
bool rc_disabled;
unsigned long timeout; /* timeout for rbincache enable */
};
extern atomic_t rbin_allocated_pages;
extern atomic_t rbin_cached_pages;
extern atomic_t rbin_free_pages;
extern atomic_t rbin_pool_pages;
extern struct kobject *rbin_kobject;
struct rr_handle *region_store_cache(struct page *, int, int, int);
int region_load_cache(struct rr_handle *, struct page *, int, int, int);
int region_flush_cache(struct rr_handle *);
phys_addr_t dmabuf_rbin_allocate(unsigned long);
void dmabuf_rbin_free(phys_addr_t, unsigned long);
void wake_dmabuf_rbin_heap_prereclaim(void);
void wake_dmabuf_rbin_heap_shrink(void);
void init_region(unsigned long, unsigned long, const struct region_ops *);
int init_rbincache(unsigned long, unsigned long);
int init_rbinregion(unsigned long, unsigned long);
#endif /* _RBIN_REGION_H*/