Refactor module to new kfile interface. Spit test function in new file.
[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  * \version $Id$
37  * \author Daniele Basile <asterix@develer.com>
38  */
39
40
41 #ifndef DRV_FLASH25_H
42 #define DRV_FLASH25_H
43
44 #include <kern/kfile.h>
45 #include <cfg/compiler.h>
46
47
48 #include <appconfig.h>
49
50 /**
51  * Type definition for serial flash memory.
52  */
53 typedef uint32_t flash25Addr_t;
54 typedef uint32_t flash25Size_t;
55 typedef uint8_t flash25Offset_t;
56
57 /**
58  * Flash25 KFile context structure.
59  */
60 typedef struct KFileFlash25
61 {
62         KFile fd;                       ///< File descriptor.
63         KFile *channel;                 ///< Dataflash comm channel (usually SPI).
64 } KFileFlash25;
65
66 /**
67  * ID for dataflash.
68  */
69 #define KFT_FLASH25 MAKE_ID('F', 'L', '2', '5')
70
71
72 /**
73  * Convert + ASSERT from generic KFile to KFileFlash25.
74  */
75 INLINE KFileFlash25 * KFILEFLASH25(KFile *fd)
76 {
77         ASSERT(fd->_type == KFT_FLASH25);
78         return (KFileFlash25 *)fd;
79 }
80
81 /**
82  * Memory definition.
83  *
84  * \note Below are defined valid serial flash memory support to
85  * this drive. Every time we call flash25_init() function we check
86  * if memory defined are right (see flash25.c form more detail).
87  * \{
88  */
89 #define FLASH25_AT25F2048         1
90
91 #if CONFIG_FLASH25 == FLASH25_AT25F2048
92         #define FLASH25_MANUFACTURER_ID    0x1F  // ATMEL
93         #define FLASH25_DEVICE_ID          0x63  // Device ID
94         #define FLASH25_PAGE_SIZE          256   // Page size in byte
95         #define FLASH25_NUM_SECTOR         4     // Number of section in serial memory
96         #define FLASH25_SECTOR_SIZE        65536UL // Section size in byte
97         #define FLASH25_MEM_SIZE           FLASH25_NUM_SECTOR * FLASH25_SECTOR_SIZE
98         #define FLASH25_NUM_PAGE           FLASH25_MEM_SIZE / FLASH25_PAGE_SIZE
99 #elif
100         #error Nothing memory defined in CONFIG_FLASH25 are support.
101 #endif
102
103 #define RDY_BIT     0x1 // Statuts of write cycle
104 /* \} */
105
106 /**
107  * Serial flash opcode commands.
108  */
109 typedef enum {
110         FLASH25_WREN            = 0x6,  ///< Set write enable latch
111         FLASH25_WRDI            = 0x4,  ///< Reset enable write latch
112         FLASH25_RDSR            = 0x5,  ///< Read status register
113         FLASH25_WRSR            = 0x1,  ///< Write status register
114         FLASH25_READ            = 0x3,  ///< Read data from memory array
115         FLASH25_PROGRAM         = 0x2,  ///< Program data into memory array
116         FLASH25_SECTORE_ERASE   = 0x52, ///< Erase one sector in memory array
117         FLASH25_CHIP_ERASE      = 0x62, ///< Erase all sector in memory array
118         FLASH25_RDID            = 0x15 ///< Read Manufacturer and product ID
119 } Flash25Opcode;
120
121 /**
122  * Serial flash sector memory address.
123  */
124 #if CONFIG_FLASH25 != FLASH25_AT25F2048
125         #error Nothing memory defined in CONFIG_FLASH25 are support.
126 #endif
127
128 typedef enum {
129         FLASH25_SECT1            = 0x0,      ///< Sector 1 (0x0 -0xFFFF)
130         FLASH25_SECT2            = 0x10000,  ///< Sector 2 (0x10000 -0x1FFFF)
131         FLASH25_SECT3            = 0x20000,  ///< Sector 3 (0x20000 -0x2FFFF)
132         FLASH25_SECT4            = 0x30000,  ///< Sector 4 (0x30000 -0x3FFFF)
133 } Flash25Sector;
134
135 void flash25_init(KFileFlash25 *fd, KFile *ch);
136 void flash25_chipErase(KFileFlash25 *fd);
137 void flash25_sectorErase(KFileFlash25 *fd, Flash25Sector sector);
138 bool flash25_test(KFile *channel);
139
140 #endif /* DRV_FLASH25_H */
141