[GIT PULL] ARM perf updates for 3.3
Russell King - ARM Linux
linux at arm.linux.org.uk
Mon Dec 5 16:11:36 EST 2011
Tony,
Can you please treat this with the utmost urgency. If I don't get a
reply from you within the next two hours, then I'm committing this
merge resolution whether or not it's correct for you - as I have other
stuff which needs to be committed to my tree and I can't wait any
longer for your reply.
Thanks.
On Sat, Dec 03, 2011 at 09:26:59AM +0000, Russell King - ARM Linux wrote:
> On Fri, Dec 02, 2011 at 05:02:31PM +0000, Will Deacon wrote:
> > Hi Russell,
> >
> > Please pull these updates to the ARM perf code for 3.3. The highlights are
> > probably the CTI stuff (which is in preparation for OMAP4 support coming from
> > Lei Ming, Benoit and Paul) and the cleanup of the event numbers for ARMv7 so
> > that they are easier to follow. I was hoping to add Cortex-A7 support but I
> > haven't got my paws on an FPGA yet.
> >
> > I've not included my contextidr patch with this pull because it conflicts
> > quite badly with the LPAE patches. I can rework this for 3.4 later on (I
> > already have a fixup).
>
> While merging this, I get conflicts in gic.c and omap's common.h. I'm
> intending to resolve them as below - please check this _before_ I commit
> it (which means my tree is frozen until this is resolved.)
>
> diff --cc arch/arm/common/gic.c
> index a1feb6b,410a546..0000000
> --- a/arch/arm/common/gic.c
> +++ b/arch/arm/common/gic.c
> @@@ -696,12 -582,16 +697,14 @@@ void __init gic_init_bases(unsigned in
> * For primary GICs, skip over SGIs.
> * For secondary GICs, skip over PPIs, too.
> */
> + domain->hwirq_base = 32;
> if (gic_nr == 0) {
> - domain->hwirq_base = 16;
> - if (irq_start > 0)
> - irq_start = (irq_start & ~31) + 16;
> - } else
> - domain->hwirq_base = 32;
> - gic_cpu_base_addr = cpu_base;
> -
> + if ((irq_start & 31) > 0) {
> + domain->hwirq_base = 16;
> + if (irq_start != -1)
> + irq_start = (irq_start & ~31) + 16;
> + }
> + }
>
> /*
> * Find out how many interrupts are supported.
> diff --cc arch/arm/plat-omap/include/plat/common.h
> index 346098f,3ff3e36..0000000
> --- a/arch/arm/plat-omap/include/plat/common.h
> +++ b/arch/arm/plat-omap/include/plat/common.h
> @@@ -27,12 -27,97 +27,15 @@@
> #ifndef __ARCH_ARM_MACH_OMAP_COMMON_H
> #define __ARCH_ARM_MACH_OMAP_COMMON_H
>
> -#include <linux/delay.h>
> -
> #include <plat/i2c.h>
> + #include <plat/omap_hwmod.h>
>
> -struct sys_timer;
> -
> -extern void omap_map_common_io(void);
> -extern struct sys_timer omap1_timer;
> -extern struct sys_timer omap2_timer;
> -extern struct sys_timer omap3_timer;
> -extern struct sys_timer omap3_secure_timer;
> -extern struct sys_timer omap4_timer;
> -extern bool omap_32k_timer_init(void);
> extern int __init omap_init_clocksource_32k(void);
> extern unsigned long long notrace omap_32k_sched_clock(void);
>
> extern void omap_reserve(void);
> -
> -void omap2420_init_early(void);
> -void omap2430_init_early(void);
> -void omap3430_init_early(void);
> -void omap35xx_init_early(void);
> -void omap3630_init_early(void);
> -void omap3_init_early(void); /* Do not use this one */
> -void am35xx_init_early(void);
> -void ti816x_init_early(void);
> -void omap4430_init_early(void);
> -
> + extern int omap_dss_reset(struct omap_hwmod *);
> +
> void omap_sram_init(void);
>
> -/*
> - * IO bases for various OMAP processors
> - * Except the tap base, rest all the io bases
> - * listed are physical addresses.
> - */
> -struct omap_globals {
> - u32 class; /* OMAP class to detect */
> - void __iomem *tap; /* Control module ID code */
> - void __iomem *sdrc; /* SDRAM Controller */
> - void __iomem *sms; /* SDRAM Memory Scheduler */
> - void __iomem *ctrl; /* System Control Module */
> - void __iomem *ctrl_pad; /* PAD Control Module */
> - void __iomem *prm; /* Power and Reset Management */
> - void __iomem *cm; /* Clock Management */
> - void __iomem *cm2;
> -};
> -
> -void omap2_set_globals_242x(void);
> -void omap2_set_globals_243x(void);
> -void omap2_set_globals_3xxx(void);
> -void omap2_set_globals_443x(void);
> -void omap2_set_globals_ti816x(void);
> -
> -/* These get called from omap2_set_globals_xxxx(), do not call these */
> -void omap2_set_globals_tap(struct omap_globals *);
> -void omap2_set_globals_sdrc(struct omap_globals *);
> -void omap2_set_globals_control(struct omap_globals *);
> -void omap2_set_globals_prcm(struct omap_globals *);
> -
> -void omap242x_map_io(void);
> -void omap243x_map_io(void);
> -void omap3_map_io(void);
> -void omap4_map_io(void);
> -
> -
> -/**
> - * omap_test_timeout - busy-loop, testing a condition
> - * @cond: condition to test until it evaluates to true
> - * @timeout: maximum number of microseconds in the timeout
> - * @index: loop index (integer)
> - *
> - * Loop waiting for @cond to become true or until at least @timeout
> - * microseconds have passed. To use, define some integer @index in the
> - * calling code. After running, if @index == @timeout, then the loop has
> - * timed out.
> - */
> -#define omap_test_timeout(cond, timeout, index) \
> -({ \
> - for (index = 0; index < timeout; index++) { \
> - if (cond) \
> - break; \
> - udelay(1); \
> - } \
> -})
> -
> -extern struct device *omap2_get_mpuss_device(void);
> -extern struct device *omap2_get_iva_device(void);
> -extern struct device *omap2_get_l3_device(void);
> -extern struct device *omap4_get_dsp_device(void);
> -
> #endif /* __ARCH_ARM_MACH_OMAP_COMMON_H */
>
>
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
More information about the linux-arm-kernel
mailing list