Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2009(C) Marvell International Ltd. and its affiliates |
| 3 | * Prafulla Wadaskar <prafulla@marvell.com> |
| 4 | * |
| 5 | * Based on drivers/mtd/spi/stmicro.c |
| 6 | * |
| 7 | * Copyright 2008, Network Appliance Inc. |
| 8 | * Jason McMullan <mcmullan@netapp.com> |
| 9 | * |
| 10 | * Copyright (C) 2004-2007 Freescale Semiconductor, Inc. |
| 11 | * TsiChung Liew (Tsi-Chung.Liew@freescale.com) |
| 12 | * |
Wolfgang Denk | d79de1d | 2013-07-08 09:37:19 +0200 | [diff] [blame] | 13 | * SPDX-License-Identifier: GPL-2.0+ |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 14 | */ |
| 15 | |
| 16 | #include <common.h> |
| 17 | #include <malloc.h> |
| 18 | #include <spi_flash.h> |
| 19 | |
| 20 | #include "spi_flash_internal.h" |
| 21 | |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 22 | struct macronix_spi_flash_params { |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 23 | u16 idcode; |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 24 | u16 nr_blocks; |
| 25 | const char *name; |
| 26 | }; |
| 27 | |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 28 | static const struct macronix_spi_flash_params macronix_spi_flash_table[] = { |
| 29 | { |
Macpaul Lin | 479404e | 2011-04-20 16:51:39 +0000 | [diff] [blame] | 30 | .idcode = 0x2013, |
Macpaul Lin | 479404e | 2011-04-20 16:51:39 +0000 | [diff] [blame] | 31 | .nr_blocks = 8, |
| 32 | .name = "MX25L4005", |
| 33 | }, |
| 34 | { |
| 35 | .idcode = 0x2014, |
Macpaul Lin | 479404e | 2011-04-20 16:51:39 +0000 | [diff] [blame] | 36 | .nr_blocks = 16, |
| 37 | .name = "MX25L8005", |
| 38 | }, |
| 39 | { |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 40 | .idcode = 0x2015, |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 41 | .nr_blocks = 32, |
| 42 | .name = "MX25L1605D", |
| 43 | }, |
| 44 | { |
| 45 | .idcode = 0x2016, |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 46 | .nr_blocks = 64, |
| 47 | .name = "MX25L3205D", |
| 48 | }, |
| 49 | { |
| 50 | .idcode = 0x2017, |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 51 | .nr_blocks = 128, |
| 52 | .name = "MX25L6405D", |
| 53 | }, |
| 54 | { |
| 55 | .idcode = 0x2018, |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 56 | .nr_blocks = 256, |
| 57 | .name = "MX25L12805D", |
| 58 | }, |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 59 | { |
| 60 | .idcode = 0x2618, |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 61 | .nr_blocks = 256, |
| 62 | .name = "MX25L12855E", |
| 63 | }, |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 64 | }; |
| 65 | |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 66 | struct spi_flash *spi_flash_probe_macronix(struct spi_slave *spi, u8 *idcode) |
| 67 | { |
| 68 | const struct macronix_spi_flash_params *params; |
Mike Frysinger | ce7cc04 | 2011-06-28 07:38:10 +0000 | [diff] [blame] | 69 | struct spi_flash *flash; |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 70 | unsigned int i; |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 71 | u16 id = idcode[2] | idcode[1] << 8; |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 72 | |
| 73 | for (i = 0; i < ARRAY_SIZE(macronix_spi_flash_table); i++) { |
| 74 | params = ¯onix_spi_flash_table[i]; |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 75 | if (params->idcode == id) |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 76 | break; |
| 77 | } |
| 78 | |
| 79 | if (i == ARRAY_SIZE(macronix_spi_flash_table)) { |
Prafulla Wadaskar | 5af0c23 | 2009-07-06 20:29:15 +0530 | [diff] [blame] | 80 | debug("SF: Unsupported Macronix ID %04x\n", id); |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 81 | return NULL; |
| 82 | } |
| 83 | |
Simon Glass | f7e55f2 | 2013-03-11 06:08:03 +0000 | [diff] [blame] | 84 | flash = spi_flash_alloc_base(spi, params->name); |
Mike Frysinger | ce7cc04 | 2011-06-28 07:38:10 +0000 | [diff] [blame] | 85 | if (!flash) { |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 86 | debug("SF: Failed to allocate memory\n"); |
| 87 | return NULL; |
| 88 | } |
| 89 | |
Mike Frysinger | a494078 | 2012-03-04 22:56:52 -0500 | [diff] [blame] | 90 | flash->page_size = 256; |
| 91 | flash->sector_size = 256 * 16 * 16; |
Mike Frysinger | ce7cc04 | 2011-06-28 07:38:10 +0000 | [diff] [blame] | 92 | flash->size = flash->sector_size * params->nr_blocks; |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 93 | |
Simon Guinot | cfd72b6 | 2011-05-02 11:01:38 +0000 | [diff] [blame] | 94 | /* Clear BP# bits for read-only flash */ |
Mike Frysinger | 6fe6d0d | 2012-03-04 23:18:17 -0500 | [diff] [blame] | 95 | spi_flash_cmd_write_status(flash, 0); |
Simon Guinot | cfd72b6 | 2011-05-02 11:01:38 +0000 | [diff] [blame] | 96 | |
Mike Frysinger | ce7cc04 | 2011-06-28 07:38:10 +0000 | [diff] [blame] | 97 | return flash; |
Prafulla Wadaskar | 0956907 | 2009-04-06 21:24:43 +0530 | [diff] [blame] | 98 | } |