1450N/A/*
1450N/A * Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved.
1450N/A *
1450N/A * Permission is hereby granted, free of charge, to any person obtaining a
1450N/A * copy of this software and associated documentation files (the "Software"),
1450N/A * to deal in the Software without restriction, including without limitation
1450N/A * the rights to use, copy, modify, merge, publish, distribute, sublicense,
1450N/A * and/or sell copies of the Software, and to permit persons to whom the
1450N/A * Software is furnished to do so, subject to the following conditions:
1450N/A *
1450N/A * The above copyright notice and this permission notice (including the next
1450N/A * paragraph) shall be included in all copies or substantial portions of the
1450N/A * Software.
1450N/A *
1450N/A * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1450N/A * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1450N/A * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
1450N/A * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
1450N/A * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
1450N/A * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
1450N/A * DEALINGS IN THE SOFTWARE.
1450N/A */
1450N/A
1450N/A/*
1450N/A * Copyright (c) 2012 Intel Corporation. All rights reserved.
1450N/A */
1450N/A
1450N/A#ifndef __DRM_IDR_H__
1450N/A#define __DRM_IDR_H__
1450N/A
1450N/A#include <sys/avl.h>
1450N/A
1450N/Astruct idr_used_id {
1450N/A struct avl_node link;
1450N/A uint32_t id;
1450N/A void *obj;
1450N/A};
1450N/A
1450N/Astruct idr_free_id {
1450N/A struct idr_free_id *next;
1450N/A uint32_t id;
1450N/A};
1450N/A
1450N/Astruct idr_free_id_range {
1450N/A struct idr_free_id_range *next;
1450N/A uint32_t start;
1450N/A uint32_t end;
1450N/A uint32_t min_unused_id;
1450N/A struct idr_free_id *free_ids;
1450N/A};
1450N/A
1450N/Astruct idr {
1450N/A struct avl_tree used_ids;
1450N/A struct idr_free_id_range *free_id_ranges;
1450N/A kmutex_t lock;
1450N/A};
1450N/A
1450N/Aextern void idr_init(struct idr *idrp);
1450N/Aextern int idr_get_new_above(struct idr *idrp, void *obj, int start, int *newid);
1450N/Aextern void* idr_find(struct idr *idrp, uint32_t id);
1450N/Aextern int idr_remove(struct idr *idrp, uint32_t id);
1450N/Aextern void* idr_replace(struct idr *idrp, void *obj, uint32_t id);
1450N/Aextern int idr_pre_get(struct idr *idrp, int flag);
1450N/Aextern int idr_for_each(struct idr *idrp, int (*fn)(int id, void *obj, void *data), void *data);
1450N/Aextern void idr_remove_all(struct idr *idrp);
1450N/Aextern void idr_destroy(struct idr* idrp);
1450N/A
1450N/A#define DRM_GEM_OBJIDR_HASHNODE 1024
1450N/A
1450N/Astruct idr_list {
1450N/A struct idr_list *next, *prev;
1450N/A void *obj;
1450N/A uint32_t handle;
1450N/A caddr_t contain_ptr;
1450N/A};
1450N/A
1450N/A#define idr_list_for_each(entry, head) \
1450N/A for (int key = 0; key < DRM_GEM_OBJIDR_HASHNODE; key++) \
1450N/A list_for_each(entry, &(head)->next[key])
1450N/A
1450N/Aextern int idr_list_pre_get(struct idr_list *head, int flag);
1450N/Aextern void idr_list_init(struct idr_list *head);
1450N/Aextern int idr_list_get_new_above(struct idr_list *head,
1450N/A void *obj,
1450N/A int *handlep);
1450N/Aextern void *idr_list_find(struct idr_list *head, uint32_t name);
1450N/Aextern int idr_list_remove(struct idr_list *head, uint32_t name);
1450N/Aextern void idr_list_free(struct idr_list *head);
1450N/Aextern int idr_list_empty(struct idr_list *head);
1450N/A#endif /* __DRM_IDR_H__ */