Move kfile interface to the io/ directory.
[bertos.git] / bertos / drv / flash25.h
1 /**
2  * \file
3  * <!--
4  * This file is part of BeRTOS.
5  *
6  * Bertos is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19  *
20  * As a special exception, you may use this file as part of a free software
21  * library without restriction.  Specifically, if other files instantiate
22  * templates or use macros or inline functions from this file, or you compile
23  * this file and link it with other files to produce an executable, this
24  * file does not by itself cause the resulting executable to be covered by
25  * the GNU General Public License.  This exception does not however
26  * invalidate any other reasons why the executable file might be covered by
27  * the GNU General Public License.
28  *
29  * Copyright 2007 Develer S.r.l. (http://www.develer.com/)
30  *
31  * -->
32  *
33  * \brief Function library for serial Flash memory.
34  *
35  *
36  * \author Daniele Basile <asterix@develer.com>
37  *
38  * $WIZ$ module_name = "flash25"
39  * $WIZ$ module_depends = "kfile"
40  * $WIZ$ module_configuration = "bertos/cfg/cfg_flash25.h"
41  */
42
43
44 #ifndef DRV_FLASH25_H
45 #define DRV_FLASH25_H
46
47 #include "cfg/cfg_flash25.h"
48 #include <cfg/compiler.h>
49
50 #include <io/kfile.h>
51
52 /**
53  * Type definition for serial flash memory.
54  */
55 typedef uint32_t flash25Addr_t;
56 typedef uint32_t flash25Size_t;
57 typedef uint8_t flash25Offset_t;
58
59 /**
60  * Flash25 KFile context structure.
61  */
62 typedef struct Flash25
63 {
64         KFile fd;                       ///< File descriptor.
65         KFile *channel;                 ///< Dataflash comm channel (usually SPI).
66 } Flash25;
67
68 /**
69  * ID for dataflash.
70  */
71 #define KFT_FLASH25 MAKE_ID('F', 'L', '2', '5')
72
73
74 /**
75  * Convert + ASSERT from generic KFile to Flash25.
76  */
77 INLINE Flash25 * FLASH25_CAST(KFile *fd)
78 {
79         ASSERT(fd->_type == KFT_FLASH25);
80         return (Flash25 *)fd;
81 }
82
83 /**
84  * Memory definition.
85  *
86  * \note Below are defined valid serial flash memory support to
87  * this drive. Every time we call flash25_init() function we check
88  * if memory defined are right (see flash25.c form more detail).
89  *
90  * $WIZ$ flash25_list = "FLASH25_AT25F2048"
91  */
92 #define FLASH25_AT25F2048         1
93
94 #if CONFIG_FLASH25 == FLASH25_AT25F2048
95         #define FLASH25_MANUFACTURER_ID    0x1F  // ATMEL
96         #define FLASH25_DEVICE_ID          0x63  // Device ID
97         #define FLASH25_PAGE_SIZE          256   // Page size in byte
98         #define FLASH25_NUM_SECTOR         4     // Number of section in serial memory
99         #define FLASH25_SECTOR_SIZE        65536UL // Section size in byte
100         #define FLASH25_MEM_SIZE           FLASH25_NUM_SECTOR * FLASH25_SECTOR_SIZE
101         #define FLASH25_NUM_PAGE           FLASH25_MEM_SIZE / FLASH25_PAGE_SIZE
102 #else
103         #error Nothing memory defined in CONFIG_FLASH25 are support.
104 #endif
105
106 #define RDY_BIT     0x1 // Statuts of write cycle
107
108 /**
109  * Serial flash opcode commands.
110  */
111 typedef enum {
112         FLASH25_WREN            = 0x6,  ///< Set write enable latch
113         FLASH25_WRDI            = 0x4,  ///< Reset enable write latch
114         FLASH25_RDSR            = 0x5,  ///< Read status register
115         FLASH25_WRSR            = 0x1,  ///< Write status register
116         FLASH25_READ            = 0x3,  ///< Read data from memory array
117         FLASH25_PROGRAM         = 0x2,  ///< Program data into memory array
118         FLASH25_SECTORE_ERASE   = 0x52, ///< Erase one sector in memory array
119         FLASH25_CHIP_ERASE      = 0x62, ///< Erase all sector in memory array
120         FLASH25_RDID            = 0x15 ///< Read Manufacturer and product ID
121 } Flash25Opcode;
122
123 /**
124  * Serial flash sector memory address.
125  */
126 #if CONFIG_FLASH25 != FLASH25_AT25F2048
127         #error Nothing memory defined in CONFIG_FLASH25 are support.
128 #endif
129
130 typedef enum {
131         FLASH25_SECT1            = 0x0,      ///< Sector 1 (0x0 -0xFFFF)
132         FLASH25_SECT2            = 0x10000,  ///< Sector 2 (0x10000 -0x1FFFF)
133         FLASH25_SECT3            = 0x20000,  ///< Sector 3 (0x20000 -0x2FFFF)
134         FLASH25_SECT4            = 0x30000,  ///< Sector 4 (0x30000 -0x3FFFF)
135 } Flash25Sector;
136
137 void flash25_init(Flash25 *fd, KFile *ch);
138 void flash25_chipErase(Flash25 *fd);
139 void flash25_sectorErase(Flash25 *fd, Flash25Sector sector);
140 bool flash25_test(KFile *channel);
141
142 #endif /* DRV_FLASH25_H */
143