Re: [PATCH v3 40/71] ARC: OProfile support

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Vineet,

On 24/01/13 11:06, Vineet Gupta wrote:
> Signed-off-by: Vineet Gupta <vgupta@xxxxxxxxxxxx>
> Cc: Robert Richter <rric@xxxxxxxxxx>
> Cc: oprofile-list@xxxxxxxxxxxx
> ---
>  arch/arc/Kconfig           |    1 +
>  arch/arc/Makefile          |    2 ++
>  arch/arc/oprofile/Makefile |    9 +++++++++
>  arch/arc/oprofile/common.c |   22 ++++++++++++++++++++++
>  4 files changed, 34 insertions(+), 0 deletions(-)
>  create mode 100644 arch/arc/oprofile/Makefile
>  create mode 100644 arch/arc/oprofile/common.c
> 
> diff --git a/arch/arc/Kconfig b/arch/arc/Kconfig
> index 409b937..405ea7a 100644
> --- a/arch/arc/Kconfig
> +++ b/arch/arc/Kconfig
> @@ -25,6 +25,7 @@ config ARC
>  	select HAVE_ARCH_TRACEHOOK
>  	select HAVE_GENERIC_HARDIRQS
>  	select HAVE_MEMBLOCK
> +	select HAVE_OPROFILE
>  	select IRQ_DOMAIN
>  	select MODULES_USE_ELF_RELA
>  	select NO_BOOTMEM
> diff --git a/arch/arc/Makefile b/arch/arc/Makefile
> index 4247f48..4f28f5b 100644
> --- a/arch/arc/Makefile
> +++ b/arch/arc/Makefile
> @@ -100,6 +100,8 @@ ifneq ($(platform-y),)
>  core-y		+= arch/arc/plat-$(PLATFORM)/
>  endif
>  
> +drivers-$(CONFIG_OPROFILE)	+= arch/arc/oprofile/
> +
>  libs-y		+= arch/arc/lib/ $(LIBGCC)
>  
>  #default target for make without any arguements.
> diff --git a/arch/arc/oprofile/Makefile b/arch/arc/oprofile/Makefile
> new file mode 100644
> index 0000000..ce417a6
> --- /dev/null
> +++ b/arch/arc/oprofile/Makefile
> @@ -0,0 +1,9 @@
> +obj-$(CONFIG_OPROFILE) += oprofile.o
> +
> +DRIVER_OBJS = $(addprefix ../../../drivers/oprofile/, \
> +		oprof.o cpu_buffer.o buffer_sync.o \
> +		event_buffer.o oprofile_files.o \
> +		oprofilefs.o oprofile_stats.o \
> +		timer_int.o )
> +
> +oprofile-y	:= $(DRIVER_OBJS) common.o
> diff --git a/arch/arc/oprofile/common.c b/arch/arc/oprofile/common.c
> new file mode 100644
> index 0000000..917ae16
> --- /dev/null
> +++ b/arch/arc/oprofile/common.c
> @@ -0,0 +1,22 @@
> +/*
> + * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
> + *
> + * 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.
> + *
> + * Based on orig code from @author John Levon <levon@xxxxxxxxxxxxxxxxx>
> + */
> +
> +#include <linux/oprofile.h>
> +#include <linux/perf_event.h>
> +
> +int __init oprofile_arch_init(struct oprofile_operations *ops)
> +{
> +	return oprofile_perf_init(ops);

You don't appear to define CONFIG_HW_PERF_EVENTS, so
include/linux/oprofile.h will presumably define oprofile_perf_init as
just a pr_info(...); return -ENODEV;

Similarly drivers/oprofile/oprofile_perf.o doesn't seem to be being built.

I'm probably missing something somewhere?

Cheers
James

> +}
> +
> +void oprofile_arch_exit(void)
> +{
> +	oprofile_perf_exit();
> +}
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-arch" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel]     [Kernel Newbies]     [x86 Platform Driver]     [Netdev]     [Linux Wireless]     [Netfilter]     [Bugtraq]     [Linux Filesystems]     [Yosemite Discussion]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Device Mapper]

  Powered by Linux