113 lines
3.1 KiB
C
113 lines
3.1 KiB
C
/***********************************************************
|
|
|
|
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
|
|
AUTHOR 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 PRIVATES_H
|
|
#define PRIVATES_H 1
|
|
|
|
#include "dix.h"
|
|
#include "resource.h"
|
|
|
|
/*****************************************************************
|
|
* STUFF FOR PRIVATES
|
|
*****************************************************************/
|
|
|
|
typedef void *DevPrivateKey;
|
|
struct _Private;
|
|
typedef struct _Private PrivateRec;
|
|
|
|
/*
|
|
* Request pre-allocated private space for your driver/module.
|
|
* Calling this is not necessary if only a pointer by itself is needed.
|
|
*/
|
|
extern int
|
|
dixRequestPrivate(const DevPrivateKey key, unsigned size);
|
|
|
|
/*
|
|
* Allocates a new private and attaches it to an existing object.
|
|
*/
|
|
extern pointer *
|
|
dixAllocatePrivate(PrivateRec **privates, const DevPrivateKey key);
|
|
|
|
/*
|
|
* Look up a private pointer.
|
|
*/
|
|
pointer
|
|
dixLookupPrivate(PrivateRec **privates, const DevPrivateKey key);
|
|
|
|
/*
|
|
* Look up the address of a private pointer.
|
|
*/
|
|
pointer *
|
|
dixLookupPrivateAddr(PrivateRec **privates, const DevPrivateKey key);
|
|
|
|
/*
|
|
* Set a private pointer.
|
|
*/
|
|
int
|
|
dixSetPrivate(PrivateRec **privates, const DevPrivateKey key, pointer val);
|
|
|
|
/*
|
|
* Register callbacks to be called on private allocation/freeing.
|
|
* The calldata argument to the callbacks is a PrivateCallbackPtr.
|
|
*/
|
|
typedef struct _PrivateCallback {
|
|
DevPrivateKey key; /* private registration key */
|
|
pointer *value; /* address of private pointer */
|
|
} PrivateCallbackRec;
|
|
|
|
extern int
|
|
dixRegisterPrivateInitFunc(const DevPrivateKey key,
|
|
CallbackProcPtr callback, pointer userdata);
|
|
|
|
extern int
|
|
dixRegisterPrivateDeleteFunc(const DevPrivateKey key,
|
|
CallbackProcPtr callback, pointer userdata);
|
|
|
|
/*
|
|
* Frees private data.
|
|
*/
|
|
extern void
|
|
dixFreePrivates(PrivateRec *privates);
|
|
|
|
/*
|
|
* Resets the subsystem, called from the main loop.
|
|
*/
|
|
extern int
|
|
dixResetPrivates(void);
|
|
|
|
/*
|
|
* These next two functions are necessary because the position of
|
|
* the devPrivates field varies by structure and calling code might
|
|
* only know the resource type, not the structure definition.
|
|
*/
|
|
|
|
/*
|
|
* Looks up the offset where the devPrivates field is located.
|
|
* Returns -1 if no offset has been registered for the resource type.
|
|
*/
|
|
extern int
|
|
dixLookupPrivateOffset(RESTYPE type);
|
|
|
|
/*
|
|
* Specifies the offset where the devPrivates field is located.
|
|
* A negative value indicates no devPrivates field is available.
|
|
*/
|
|
extern int
|
|
dixRegisterPrivateOffset(RESTYPE type, int offset);
|
|
|
|
/*
|
|
* Convenience macro for adding an offset to an object pointer
|
|
* when making a call to one of the devPrivates functions
|
|
*/
|
|
#define DEVPRIV_AT(ptr, offset) ((PrivateRec **)((char *)ptr + offset))
|
|
|
|
#endif /* PRIVATES_H */
|