 b52f4914f3
			
		
	
	
	b52f4914f3
	
	
	
		
			
			If CONFIG_COMMON_CLK is selected then __clk_get and __clk_put are
defined in drivers/clk/clk.c and declared in include/linux/clkdev.h.
Sylwester's series[0] to properly support clk_{get,put} in the common
clock framework made changes to the asm-specific clkdev.h headers, but
not the asm-generic version. Tomeu's recent changes[1] to introduce a
provider/consumer split in the clock framework uncovered this problem,
causing the following build error on any architecture using the
asm-generic clkdev.h (e.g. x86 architecture and the ACPI LPSS driver):
In file included from drivers/acpi/acpi_lpss.c:15:0:
include/linux/clkdev.h:59:5: error: conflicting types for ‘__clk_get’
 int __clk_get(struct clk_core *clk);
     ^
In file included from arch/x86/include/generated/asm/clkdev.h:1:0,
                 from include/linux/clkdev.h:15,
                 from drivers/acpi/acpi_lpss.c:15:
include/asm-generic/clkdev.h:20:19: note: previous definition of ‘__clk_get’ was here
 static inline int __clk_get(struct clk *clk) { return 1; }
                   ^
Fixed by only declarating  __clk_get and __clk_put when
CONFIG_COMMON_CLK is set.
[0] http://lkml.kernel.org/r/<1386177127-2894-5-git-send-email-s.nawrocki@samsung.com>
[1] http://lkml.kernel.org/r/<1409758148-20104-1-git-send-email-tomeu.vizoso@collabora.com>
Signed-off-by: Mike Turquette <mturquette@linaro.org>
		
	
			
		
			
				
	
	
		
			30 lines
		
	
	
	
		
			706 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
	
		
			706 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  include/asm-generic/clkdev.h
 | |
|  *
 | |
|  * Based on the ARM clkdev.h:
 | |
|  *  Copyright (C) 2008 Russell King.
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  * Helper for the clk API to assist looking up a struct clk.
 | |
|  */
 | |
| #ifndef __ASM_CLKDEV_H
 | |
| #define __ASM_CLKDEV_H
 | |
| 
 | |
| #include <linux/slab.h>
 | |
| 
 | |
| #ifndef CONFIG_COMMON_CLK
 | |
| struct clk;
 | |
| 
 | |
| static inline int __clk_get(struct clk *clk) { return 1; }
 | |
| static inline void __clk_put(struct clk *clk) { }
 | |
| #endif
 | |
| 
 | |
| static inline struct clk_lookup_alloc *__clkdev_alloc(size_t size)
 | |
| {
 | |
| 	return kzalloc(size, GFP_KERNEL);
 | |
| }
 | |
| 
 | |
| #endif
 |