2012-12-04 18:42:15 +08:00
|
|
|
/*
|
|
|
|
* V4L2 clock service
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012-2013, Guennadi Liakhovetski <g.liakhovetski@gmx.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* ATTENTION: This is a temporary API and it shall be replaced by the generic
|
|
|
|
* clock API, when the latter becomes widely available.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MEDIA_V4L2_CLK_H
|
|
|
|
#define MEDIA_V4L2_CLK_H
|
|
|
|
|
|
|
|
#include <linux/atomic.h>
|
2013-08-28 21:28:26 +08:00
|
|
|
#include <linux/export.h>
|
2012-12-04 18:42:15 +08:00
|
|
|
#include <linux/list.h>
|
|
|
|
#include <linux/mutex.h>
|
|
|
|
|
|
|
|
struct module;
|
|
|
|
struct device;
|
|
|
|
|
2015-02-01 19:12:33 +08:00
|
|
|
struct clk;
|
2012-12-04 18:42:15 +08:00
|
|
|
struct v4l2_clk {
|
|
|
|
struct list_head list;
|
|
|
|
const struct v4l2_clk_ops *ops;
|
|
|
|
const char *dev_id;
|
|
|
|
int enable;
|
|
|
|
struct mutex lock; /* Protect the enable count */
|
|
|
|
atomic_t use_count;
|
2015-02-01 19:12:33 +08:00
|
|
|
struct clk *clk;
|
2012-12-04 18:42:15 +08:00
|
|
|
void *priv;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct v4l2_clk_ops {
|
|
|
|
struct module *owner;
|
|
|
|
int (*enable)(struct v4l2_clk *clk);
|
|
|
|
void (*disable)(struct v4l2_clk *clk);
|
|
|
|
unsigned long (*get_rate)(struct v4l2_clk *clk);
|
|
|
|
int (*set_rate)(struct v4l2_clk *clk, unsigned long);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct v4l2_clk *v4l2_clk_register(const struct v4l2_clk_ops *ops,
|
|
|
|
const char *dev_name,
|
2015-02-01 07:21:32 +08:00
|
|
|
void *priv);
|
2012-12-04 18:42:15 +08:00
|
|
|
void v4l2_clk_unregister(struct v4l2_clk *clk);
|
|
|
|
struct v4l2_clk *v4l2_clk_get(struct device *dev, const char *id);
|
|
|
|
void v4l2_clk_put(struct v4l2_clk *clk);
|
|
|
|
int v4l2_clk_enable(struct v4l2_clk *clk);
|
|
|
|
void v4l2_clk_disable(struct v4l2_clk *clk);
|
|
|
|
unsigned long v4l2_clk_get_rate(struct v4l2_clk *clk);
|
|
|
|
int v4l2_clk_set_rate(struct v4l2_clk *clk, unsigned long rate);
|
|
|
|
|
2013-08-28 21:28:26 +08:00
|
|
|
struct module;
|
|
|
|
|
|
|
|
struct v4l2_clk *__v4l2_clk_register_fixed(const char *dev_id,
|
2015-02-01 07:21:32 +08:00
|
|
|
unsigned long rate, struct module *owner);
|
2013-08-28 21:28:26 +08:00
|
|
|
void v4l2_clk_unregister_fixed(struct v4l2_clk *clk);
|
|
|
|
|
|
|
|
static inline struct v4l2_clk *v4l2_clk_register_fixed(const char *dev_id,
|
|
|
|
unsigned long rate)
|
|
|
|
{
|
2015-02-01 07:21:32 +08:00
|
|
|
return __v4l2_clk_register_fixed(dev_id, rate, THIS_MODULE);
|
2013-08-28 21:28:26 +08:00
|
|
|
}
|
|
|
|
|
2015-10-28 17:48:54 +08:00
|
|
|
#define V4L2_CLK_NAME_SIZE 64
|
|
|
|
|
2013-08-28 21:28:27 +08:00
|
|
|
#define v4l2_clk_name_i2c(name, size, adap, client) snprintf(name, size, \
|
|
|
|
"%d-%04x", adap, client)
|
|
|
|
|
2017-07-22 03:28:33 +08:00
|
|
|
#define v4l2_clk_name_of(name, size, node) snprintf(name, size, \
|
|
|
|
"of-%pOF", node)
|
2015-10-28 17:48:53 +08:00
|
|
|
|
2012-12-04 18:42:15 +08:00
|
|
|
#endif
|