From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752969Ab1HTUOS (ORCPT ); Sat, 20 Aug 2011 16:14:18 -0400 Received: from mail-yi0-f46.google.com ([209.85.218.46]:62253 "EHLO mail-yi0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752625Ab1HTUOO (ORCPT ); Sat, 20 Aug 2011 16:14:14 -0400 Message-ID: <4E501592.4080907@landley.net> Date: Sat, 20 Aug 2011 15:14:10 -0500 From: Rob Landley User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.2.18) Gecko/20110617 Thunderbird/3.1.11 MIME-Version: 1.0 To: linux-kernel@vger.kernel.org, gerg@uclinux.org, linux-m68k@vger.kernel.org, geert@linux-m68k.org Subject: Re: m68k with mmu doesn't compile after 66d857b08b8c3ed References: <4E5008A1.8070105@landley.net> In-Reply-To: <4E5008A1.8070105@landley.net> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 08/20/2011 02:18 PM, Rob Landley wrote: > The m68k build in 3.0 dies with this: > > CC arch/m68k/kernel/dma.o > In file included from arch/m68k/kernel/dma.c:4: > arch/m68k/kernel/dma_no.c: In function 'dma_sync_single_for_cpu': > arch/m68k/kernel/dma_no.c:44: error: implicit declaration of function > 'flush_dcache_range' > make[1]: *** [arch/m68k/kernel/dma.o] Error 1 > make: *** [arch/m68k/kernel] Error 2 > > That file includes , which for m68k is: > > #ifdef __uClinux__ > #include "cacheflush_no.h" > #else > #include "cacheflush_mm.h" > #endif > > The nommu header (cacheflush_no.h) does #define flush_dcache_range(), > but the clacheflush_mm.h version does not. I.E. you can only currently > build m68k for Coldfire, you can no longer build it for an actual m68k. > > (A git log of Linus' tree shows cacheflush_mm.h hasn't been touched > since 2010, and I pulled earlier today.) > > Rob I worked around the above problem with this rather disgusting hack: --- a/arch/m68k/include/asm/cacheflush_mm.h +++ b/arch/m68k/include/asm/cacheflush_mm.h @@ -129,6 +129,7 @@ static inline void __flush_page_to_ram(void *vaddr) } #define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 1 +#define flush_dcache_range(page, len) __flush_cache_all() #define flush_dcache_page(page) __flush_page_to_ram(page_address(page)) #define flush_dcache_mmap_lock(mapping) do { } while (0) #define flush_dcache_mmap_unlock(mapping) do { } while (0) And then it died with: AS arch/m68k/kernel/entry.o arch/m68k/kernel/entry_no.S: Assembler messages: arch/m68k/kernel/entry_no.S:46: Error: Unknown operator -- statement `save_all' ignored arch/m68k/kernel/entry_no.S:55: Error: Unknown operator -- statement `save_all' ignored This is because arch/m68k/include/asm/entry_no.h has this: #else /* !CONFIG_COLDFIRE */ /* * Standard 68k interrupt entry and exit macros. */ .macro SAVE_ALL clrl %sp@- /* stkadj */ movel %d0,%sp@- /* orig d0 */ movel %d0,%sp@- /* d0 */ moveml %d1-%d5/%a0-%a2,%sp@- .endm And arch/m68k/include/asm/entry_mm.h does not. Rob