[U-Boot] [PATCH 04/19] drivers: timer: omap_timer: add timer driver for omap devices based on dm

Mugunthan V N mugunthanvnm at ti.com
Sun Nov 29 14:19:13 CET 2015


On Saturday 28 November 2015 05:22 PM, Bin Meng wrote:
> Hi Mugunthan,
> 
> On Fri, Nov 27, 2015 at 4:31 PM, Mugunthan V N <mugunthanvnm at ti.com> wrote:
>> Adding a timer driver for omap devices based on driver model
>> and device tree.
>>
>> Signed-off-by: Mugunthan V N <mugunthanvnm at ti.com>
>> ---
>>  drivers/timer/Kconfig      |   6 +++
>>  drivers/timer/Makefile     |   1 +
>>  drivers/timer/omap-timer.c | 108 +++++++++++++++++++++++++++++++++++++++++++++
>>  3 files changed, 115 insertions(+)
>>  create mode 100644 drivers/timer/omap-timer.c
>>
>> diff --git a/drivers/timer/Kconfig b/drivers/timer/Kconfig
>> index 601e493..98ba012 100644
>> --- a/drivers/timer/Kconfig
>> +++ b/drivers/timer/Kconfig
>> @@ -23,4 +23,10 @@ config SANDBOX_TIMER
>>           Select this to enable an emulated timer for sandbox. It gets
>>           time from host os.
>>
>> +config OMAP_TIMER
>> +       bool "Omap Timer support"
> 
> nits: Timer -> timer. Please see dm/master branch which has a commit
> to fix all these nits in the existing timer drivers.

Will fix it in next revision

> 
>> +       depends on TIMER
>> +       help
>> +         Select this to enable an timer for Omap devices.
>> +
>>  endmenu
>> diff --git a/drivers/timer/Makefile b/drivers/timer/Makefile
>> index 300946e..2eb9cfc 100644
>> --- a/drivers/timer/Makefile
>> +++ b/drivers/timer/Makefile
>> @@ -7,3 +7,4 @@
>>  obj-$(CONFIG_TIMER)            += timer-uclass.o
>>  obj-$(CONFIG_ALTERA_TIMER)     += altera_timer.o
>>  obj-$(CONFIG_SANDBOX_TIMER)    += sandbox_timer.o
>> +obj-$(CONFIG_OMAP_TIMER)       += omap-timer.o
>> diff --git a/drivers/timer/omap-timer.c b/drivers/timer/omap-timer.c
>> new file mode 100644
>> index 0000000..2532e74
>> --- /dev/null
>> +++ b/drivers/timer/omap-timer.c
>> @@ -0,0 +1,108 @@
>> +/*
>> + * TI OMAP Timer driver
> 
> nits: Timer -> timer
> 
>> + *
>> + * Copyright (C) 2015, Texas Instruments, Incorporated
>> + *
>> + * SPDX-License-Identifier: GPL-2.0+
>> + */
>> +
>> +#include <common.h>
>> +#include <dm.h>
>> +#include <errno.h>
>> +#include <timer.h>
>> +#include <asm/io.h>
>> +#include <asm/arch/clock.h>
>> +
>> +DECLARE_GLOBAL_DATA_PTR;
>> +
>> +/* Timer register bits */
>> +#define TCLR_START                     BIT(0)  /* Start=1 */
>> +#define TCLR_AUTO_RELOAD               BIT(1)  /* Auto reload */
>> +#define TCLR_PRE_EN                    BIT(5)  /* Pre-scaler enable */
>> +#define TCLR_PTV_SHIFT                 (2)     /* Pre-scaler shift value */
>> +
>> +#define TIMER_CLOCK             (V_SCLK / (2 << CONFIG_SYS_PTV))
>> +
>> +struct omap_gptimer_regs {
>> +       unsigned int tidr;              /* offset 0x00 */
>> +       unsigned char res1[12];
>> +       unsigned int tiocp_cfg;         /* offset 0x10 */
>> +       unsigned char res2[12];
>> +       unsigned int tier;              /* offset 0x20 */
>> +       unsigned int tistatr;           /* offset 0x24 */
>> +       unsigned int tistat;            /* offset 0x28 */
>> +       unsigned int tisr;              /* offset 0x2c */
>> +       unsigned int tcicr;             /* offset 0x30 */
>> +       unsigned int twer;              /* offset 0x34 */
>> +       unsigned int tclr;              /* offset 0x38 */
>> +       unsigned int tcrr;              /* offset 0x3c */
>> +       unsigned int tldr;              /* offset 0x40 */
>> +       unsigned int ttgr;              /* offset 0x44 */
>> +       unsigned int twpc;              /* offset 0x48 */
>> +       unsigned int tmar;              /* offset 0x4c */
>> +       unsigned int tcar1;             /* offset 0x50 */
>> +       unsigned int tscir;             /* offset 0x54 */
>> +       unsigned int tcar2;             /* offset 0x58 */
>> +};
>> +
>> +/* Omap Timer Priv */
>> +struct omap_timer_priv {
>> +       struct omap_gptimer_regs *regs;
>> +};
>> +
>> +static int omap_timer_get_count(struct udevice *dev, unsigned long *count)
> 
> Please rebase your series on top of dm/master, where this API
> parameter 'count' has been changed to u64.

Hmmm, will rebase to dm/master and submit my next revision.

Regards
Mugunthan V N


More information about the U-Boot mailing list