2019-06-03 13:44:50 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2012-09-29 00:34:49 +08:00
|
|
|
/*
|
|
|
|
* DMTIMER platform data for TI OMAP platforms
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012 Texas Instruments
|
|
|
|
* Author: Jon Hunter <jon-hunter@ti.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __PLATFORM_DATA_DMTIMER_OMAP_H__
|
|
|
|
#define __PLATFORM_DATA_DMTIMER_OMAP_H__
|
|
|
|
|
2018-02-15 14:01:47 +08:00
|
|
|
struct omap_dm_timer_ops {
|
|
|
|
struct omap_dm_timer *(*request_by_node)(struct device_node *np);
|
|
|
|
struct omap_dm_timer *(*request_specific)(int timer_id);
|
|
|
|
struct omap_dm_timer *(*request)(void);
|
|
|
|
|
|
|
|
int (*free)(struct omap_dm_timer *timer);
|
|
|
|
|
|
|
|
void (*enable)(struct omap_dm_timer *timer);
|
|
|
|
void (*disable)(struct omap_dm_timer *timer);
|
|
|
|
|
|
|
|
int (*get_irq)(struct omap_dm_timer *timer);
|
|
|
|
int (*set_int_enable)(struct omap_dm_timer *timer,
|
|
|
|
unsigned int value);
|
|
|
|
int (*set_int_disable)(struct omap_dm_timer *timer, u32 mask);
|
|
|
|
|
|
|
|
struct clk *(*get_fclk)(struct omap_dm_timer *timer);
|
|
|
|
|
|
|
|
int (*start)(struct omap_dm_timer *timer);
|
|
|
|
int (*stop)(struct omap_dm_timer *timer);
|
|
|
|
int (*set_source)(struct omap_dm_timer *timer, int source);
|
|
|
|
|
2020-03-05 16:27:15 +08:00
|
|
|
int (*set_load)(struct omap_dm_timer *timer, unsigned int value);
|
2018-02-15 14:01:47 +08:00
|
|
|
int (*set_match)(struct omap_dm_timer *timer, int enable,
|
|
|
|
unsigned int match);
|
|
|
|
int (*set_pwm)(struct omap_dm_timer *timer, int def_on,
|
2020-03-05 16:27:15 +08:00
|
|
|
int toggle, int trigger, int autoreload);
|
2020-03-05 16:27:14 +08:00
|
|
|
int (*get_pwm_status)(struct omap_dm_timer *timer);
|
2018-02-15 14:01:47 +08:00
|
|
|
int (*set_prescaler)(struct omap_dm_timer *timer, int prescaler);
|
|
|
|
|
|
|
|
unsigned int (*read_counter)(struct omap_dm_timer *timer);
|
|
|
|
int (*write_counter)(struct omap_dm_timer *timer,
|
|
|
|
unsigned int value);
|
|
|
|
unsigned int (*read_status)(struct omap_dm_timer *timer);
|
|
|
|
int (*write_status)(struct omap_dm_timer *timer,
|
|
|
|
unsigned int value);
|
|
|
|
};
|
|
|
|
|
2012-09-29 00:34:49 +08:00
|
|
|
struct dmtimer_platform_data {
|
|
|
|
/* set_timer_src - Only used for OMAP1 devices */
|
|
|
|
int (*set_timer_src)(struct platform_device *pdev, int source);
|
|
|
|
u32 timer_capability;
|
|
|
|
u32 timer_errata;
|
|
|
|
int (*get_context_loss_count)(struct device *);
|
2018-02-15 14:01:47 +08:00
|
|
|
const struct omap_dm_timer_ops *timer_ops;
|
2012-09-29 00:34:49 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* __PLATFORM_DATA_DMTIMER_OMAP_H__ */
|