From 977f8a30103b9c4992cab8f49357fe0d4274004f Mon Sep 17 00:00:00 2001
From: Jonas Gorski <jonas.gorski@gmail.com>
Date: Thu, 3 May 2012 14:55:26 +0200
Subject: [PATCH 69/80] MIPS: BCM63XX: pass caldata info to flash

---
 arch/mips/bcm63xx/boards/board_bcm963xx.c              |    2 +-
 arch/mips/bcm63xx/dev-flash.c                          |    9 ++++++++-
 arch/mips/include/asm/mach-bcm63xx/bcm63xx_dev_flash.h |    4 +++-
 3 files changed, 12 insertions(+), 3 deletions(-)

--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
@@ -1036,7 +1036,7 @@ int __init board_register_devices(void)
 	if (board.num_spis)
 		spi_register_board_info(board.spis, board.num_spis);
 
-	bcm63xx_flash_register();
+	bcm63xx_flash_register(board.has_caldata, board.caldata);
 
 	/* count number of LEDs defined by this device */
 	while (led_count < ARRAY_SIZE(board.leds) && board.leds[led_count].name)
--- a/arch/mips/bcm63xx/dev-flash.c
+++ b/arch/mips/bcm63xx/dev-flash.c
@@ -35,12 +35,15 @@ static struct mtd_partition mtd_partitio
 	}
 };
 
+static struct mtd_part_parser_data bcm63xx_parser_data;
+
 static const char *bcm63xx_part_types[] = { "bcm63xxpart", "RedBoot", NULL };
 
 static struct physmap_flash_data flash_data = {
 	.width			= 2,
 	.parts			= mtd_partitions,
 	.part_probe_types	= bcm63xx_part_types,
+	.pp_data		= &bcm63xx_parser_data,
 };
 
 static struct resource mtd_resources[] = {
@@ -62,6 +65,7 @@ static struct platform_device mtd_dev =
 
 static struct flash_platform_data bcm63xx_flash_data = {
 	.part_probe_types	= bcm63xx_part_types,
+	.pp_data		= &bcm63xx_parser_data,
 };
 
 static struct spi_board_info bcm63xx_spi_flash_info[] = {
@@ -189,9 +193,13 @@ void __init bcm63xx_flash_detect(void)
 	}
 }
 
-int __init bcm63xx_flash_register(void)
+int __init bcm63xx_flash_register(int num_caldata, struct ath9k_caldata *caldata)
 {
 	u32 val;
+	unsigned int i;
+
+	for (i = 0; i < num_caldata; i++)
+		bcm63xx_parser_data.caldata[i] = caldata[i].caldata_offset;
 
 	switch (flash_type) {
 	case BCM63XX_FLASH_TYPE_PARALLEL:
--- a/arch/mips/include/asm/mach-bcm63xx/bcm63xx_dev_flash.h
+++ b/arch/mips/include/asm/mach-bcm63xx/bcm63xx_dev_flash.h
@@ -1,6 +1,8 @@
 #ifndef __BCM63XX_FLASH_H
 #define __BCM63XX_FLASH_H
 
+#include <board_bcm963xx.h>
+
 enum {
 	BCM63XX_FLASH_TYPE_PARALLEL,
 	BCM63XX_FLASH_TYPE_SERIAL,
@@ -9,7 +11,7 @@ enum {
 
 void bcm63xx_flash_detect(void);
 
-int __init bcm63xx_flash_register(void);
+int __init bcm63xx_flash_register(int num_caldata, struct ath9k_caldata *caldata);
 
 int bcm63xx_flash_get_type(void);