From 46831ebc02fceaf8102d25afed49525a9ca91fd4 Mon Sep 17 00:00:00 2001 From: juhosg Date: Wed, 3 Jun 2009 18:17:07 +0000 Subject: [ar71xx] add flash locking code git-svn-id: svn://svn.openwrt.org/openwrt/trunk@16311 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c | 24 +++++++++++++++++++++- .../arch/mips/include/asm/mach-ar71xx/ar71xx.h | 4 ++++ 2 files changed, 27 insertions(+), 1 deletion(-) (limited to 'target/linux/ar71xx/files/arch/mips') diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c b/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c index f224e82c0..ea7ae143b 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c @@ -1,7 +1,7 @@ /* * AR71xx SoC routines * - * Copyright (C) 2008 Gabor Juhos + * Copyright (C) 2008-2009 Gabor Juhos * Copyright (C) 2008 Imre Kaloz * * This program is free software; you can redistribute it and/or modify it @@ -12,9 +12,13 @@ #include #include #include +#include #include +static DEFINE_MUTEX(ar71xx_flash_mutex); +static int ar71xx_flash_lock_enabled; + void __iomem *ar71xx_ddr_base; EXPORT_SYMBOL_GPL(ar71xx_ddr_base); @@ -98,3 +102,21 @@ void ar71xx_ddr_flush(u32 reg) } EXPORT_SYMBOL_GPL(ar71xx_ddr_flush); +void __init ar71xx_flash_lock_enable(void) +{ + ar71xx_flash_lock_enabled = 1; +} + +void ar71xx_flash_acquire(void) +{ + if (ar71xx_flash_lock_enabled) + mutex_lock(&ar71xx_flash_mutex); +} +EXPORT_SYMBOL_GPL(ar71xx_flash_acquire); + +void ar71xx_flash_release(void) +{ + if (ar71xx_flash_lock_enabled) + mutex_unlock(&ar71xx_flash_mutex); +} +EXPORT_SYMBOL_GPL(ar71xx_flash_release); diff --git a/target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h b/target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h index 86272789b..19a546e56 100644 --- a/target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h +++ b/target/linux/ar71xx/files/arch/mips/include/asm/mach-ar71xx/ar71xx.h @@ -422,6 +422,10 @@ void ar71xx_device_start(u32 mask); #define SPI_IOC_CS2 SPI_IOC_CS(2) #define SPI_IOC_CS_ALL (SPI_IOC_CS0 | SPI_IOC_CS1 | SPI_IOC_CS2) +void ar71xx_flash_lock_enable(void) __init; +void ar71xx_flash_acquire(void); +void ar71xx_flash_release(void); + /* * MII_CTRL block */ -- cgit v1.2.3