diff options
Diffstat (limited to 'drivers/hwspinlock/hwspinlock_internal.h')
| -rw-r--r-- | drivers/hwspinlock/hwspinlock_internal.h | 61 | 
1 files changed, 61 insertions, 0 deletions
| diff --git a/drivers/hwspinlock/hwspinlock_internal.h b/drivers/hwspinlock/hwspinlock_internal.h new file mode 100644 index 000000000000..69935e6b93e5 --- /dev/null +++ b/drivers/hwspinlock/hwspinlock_internal.h @@ -0,0 +1,61 @@ +/* + * Hardware spinlocks internal header + * + * Copyright (C) 2010 Texas Instruments Incorporated - http://www.ti.com + * + * Contact: Ohad Ben-Cohen <[email protected]> + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 as published + * by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + */ + +#ifndef __HWSPINLOCK_HWSPINLOCK_H +#define __HWSPINLOCK_HWSPINLOCK_H + +#include <linux/spinlock.h> +#include <linux/device.h> + +/** + * struct hwspinlock_ops - platform-specific hwspinlock handlers + * + * @trylock: make a single attempt to take the lock. returns 0 on + *	     failure and true on success. may _not_ sleep. + * @unlock:  release the lock. always succeed. may _not_ sleep. + * @relax:   optional, platform-specific relax handler, called by hwspinlock + *	     core while spinning on a lock, between two successive + *	     invocations of @trylock. may _not_ sleep. + */ +struct hwspinlock_ops { +	int (*trylock)(struct hwspinlock *lock); +	void (*unlock)(struct hwspinlock *lock); +	void (*relax)(struct hwspinlock *lock); +}; + +/** + * struct hwspinlock - this struct represents a single hwspinlock instance + * + * @dev: underlying device, will be used to invoke runtime PM api + * @ops: platform-specific hwspinlock handlers + * @id: a global, unique, system-wide, index of the lock. + * @lock: initialized and used by hwspinlock core + * @owner: underlying implementation module, used to maintain module ref count + * + * Note: currently simplicity was opted for, but later we can squeeze some + * memory bytes by grouping the dev, ops and owner members in a single + * per-platform struct, and have all hwspinlocks point at it. + */ +struct hwspinlock { +	struct device *dev; +	const struct hwspinlock_ops *ops; +	int id; +	spinlock_t lock; +	struct module *owner; +}; + +#endif /* __HWSPINLOCK_HWSPINLOCK_H */ |