Merged in ziggurat29/nuttx/stm32l4_smartfs_test (pull request #97)
fixes to n25qxxx mtd driver for smartfs support, etc...
This commit is contained in:
commit
74037a7951
@ -210,22 +210,60 @@ FAR struct mtd_dev_s *mtd_temp;
|
|||||||
g_mtd_fs = mtd_temp;
|
g_mtd_fs = mtd_temp;
|
||||||
|
|
||||||
#ifdef CONFIG_MTD_PARTITION
|
#ifdef CONFIG_MTD_PARTITION
|
||||||
/* Setup a partition of 256KiB for our file system. */
|
{
|
||||||
|
FAR struct mtd_geometry_s geo;
|
||||||
|
off_t nblocks;
|
||||||
|
|
||||||
#if defined(CONFIG_N25QXXX_SECTOR512)
|
/* Setup a partition of 256KiB for our file system. */
|
||||||
mtd_temp = mtd_partition(g_mtd_fs, 0, 512);
|
|
||||||
#else
|
ret = MTD_IOCTL(g_mtd_fs, MTDIOC_GEOMETRY, (unsigned long)(uintptr_t)&geo);
|
||||||
mtd_temp = mtd_partition(g_mtd_fs, 0, 64);
|
if (ret < 0)
|
||||||
|
{
|
||||||
|
_err("ERROR: MTDIOC_GEOMETRY failed\n");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
nblocks = (256*1024) / geo.blocksize;
|
||||||
|
|
||||||
|
mtd_temp = mtd_partition(g_mtd_fs, 0, nblocks);
|
||||||
|
if (!mtd_temp)
|
||||||
|
{
|
||||||
|
_err("ERROR: mtd_partition failed\n");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_mtd_fs = mtd_temp;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!g_mtd_fs)
|
|
||||||
|
#ifdef HAVE_N25QXXX_SMARTFS
|
||||||
|
/* Configure the device with no partition support */
|
||||||
|
|
||||||
|
ret = smart_initialize(N25QXXX_SMART_MINOR, g_mtd_fs, NULL);
|
||||||
|
if (ret != OK)
|
||||||
{
|
{
|
||||||
_err("ERROR: mtd_partition failed\n");
|
_err("ERROR: Failed to initialize SmartFS: %d\n", ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined(HAVE_N25QXXX_NXFFS)
|
||||||
|
/* Initialize to provide NXFFS on the N25QXXX MTD interface */
|
||||||
|
|
||||||
|
ret = nxffs_initialize(g_mtd_fs);
|
||||||
|
if (ret < 0)
|
||||||
|
{
|
||||||
|
_err("ERROR: NXFFS initialization failed: %d\n", ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Mount the file system at /mnt/nxffs */
|
||||||
|
|
||||||
|
ret = mount(NULL, "/mnt/nxffs", "nxffs", 0, NULL);
|
||||||
|
if (ret < 0)
|
||||||
|
{
|
||||||
|
_err("ERROR: Failed to mount the NXFFS volume: %d\n", errno);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_mtd_fs = mtd_temp;
|
#else /* if defined(HAVE_N25QXXX_CHARDEV) */
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Use the FTL layer to wrap the MTD driver as a block driver */
|
/* Use the FTL layer to wrap the MTD driver as a block driver */
|
||||||
|
|
||||||
ret = ftl_initialize(N25QXXX_MTD_MINOR, g_mtd_fs);
|
ret = ftl_initialize(N25QXXX_MTD_MINOR, g_mtd_fs);
|
||||||
@ -256,6 +294,7 @@ FAR struct mtd_dev_s *mtd_temp;
|
|||||||
_err("ERROR: bchdev_register %s failed: %d\n", chardev, ret);
|
_err("ERROR: bchdev_register %s failed: %d\n", chardev, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -87,7 +87,6 @@
|
|||||||
# define CONFIG_N25QXXX_DUMMIES 6
|
# define CONFIG_N25QXXX_DUMMIES 6
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* N25QXXX Commands *****************************************************************/
|
/* N25QXXX Commands *****************************************************************/
|
||||||
/* Configuration, Status, Erase, Program Commands ***********************************/
|
/* Configuration, Status, Erase, Program Commands ***********************************/
|
||||||
/* Command Value Description: */
|
/* Command Value Description: */
|
||||||
@ -98,7 +97,7 @@
|
|||||||
* 0x01 | SR */
|
* 0x01 | SR */
|
||||||
#define N25QXXX_READ_VOLCFG 0x85 /* Read volatile configuration register: *
|
#define N25QXXX_READ_VOLCFG 0x85 /* Read volatile configuration register: *
|
||||||
* 0x85 | VCR */
|
* 0x85 | VCR */
|
||||||
#define N25QXXX_WRITE_VOLCFG 0x81 /* Write status register: *
|
#define N25QXXX_WRITE_VOLCFG 0x81 /* Write svolatile configuration register: *
|
||||||
* 0x81 | VCR */
|
* 0x81 | VCR */
|
||||||
#define N25QXXX_WRITE_ENABLE 0x06 /* Write enable: *
|
#define N25QXXX_WRITE_ENABLE 0x06 /* Write enable: *
|
||||||
* 0x06 */
|
* 0x06 */
|
||||||
@ -123,7 +122,7 @@
|
|||||||
/* Command Value Description: */
|
/* Command Value Description: */
|
||||||
/* Data sequence */
|
/* Data sequence */
|
||||||
|
|
||||||
/* ID/Security Commands *************************&***********************************/
|
/* ID/Security Commands *************************************************************/
|
||||||
/* Command Value Description: */
|
/* Command Value Description: */
|
||||||
/* Data sequence */
|
/* Data sequence */
|
||||||
#define N25QXXX_JEDEC_ID 0x9f /* JEDEC ID: *
|
#define N25QXXX_JEDEC_ID 0x9f /* JEDEC ID: *
|
||||||
@ -141,8 +140,8 @@
|
|||||||
|
|
||||||
/* N25QXXX JEDIC IDs */
|
/* N25QXXX JEDIC IDs */
|
||||||
|
|
||||||
#define N25QXXX3V_JEDEC_DEVICE_TYPE 0xba /* 3v memory device type */
|
#define N25QXXX3V_JEDEC_DEVICE_TYPE 0xba /* 3v memory device type */
|
||||||
#define N25QXXX2V_JEDEC_DEVICE_TYPE 0xbb /* 2v memory device type */
|
#define N25QXXX2V_JEDEC_DEVICE_TYPE 0xbb /* 2v memory device type */
|
||||||
|
|
||||||
#define N25Q016_JEDEC_CAPACITY 0x15 /* N25Q016 (2 MB) memory capacity */
|
#define N25Q016_JEDEC_CAPACITY 0x15 /* N25Q016 (2 MB) memory capacity */
|
||||||
#define N25Q032_JEDEC_CAPACITY 0x16 /* N25Q032 (4 MB) memory capacity */
|
#define N25Q032_JEDEC_CAPACITY 0x16 /* N25Q032 (4 MB) memory capacity */
|
||||||
@ -168,7 +167,7 @@
|
|||||||
#define STATUS_TB_MASK (1 << 5) /* Bit 5: Top / Bottom Protect */
|
#define STATUS_TB_MASK (1 << 5) /* Bit 5: Top / Bottom Protect */
|
||||||
# define STATUS_TB_TOP (0 << 5) /* 0 = BP2-BP0 protect Top down */
|
# define STATUS_TB_TOP (0 << 5) /* 0 = BP2-BP0 protect Top down */
|
||||||
# define STATUS_TB_BOTTOM (1 << 5) /* 1 = BP2-BP0 protect Bottom up */
|
# define STATUS_TB_BOTTOM (1 << 5) /* 1 = BP2-BP0 protect Bottom up */
|
||||||
#define STATUS_BP3_MASK (1 << 5) /* Bit 6: BP3 */
|
#define STATUS_BP3_MASK (1 << 5) /* Bit 6: BP3 */
|
||||||
#define STATUS_SRP0_MASK (1 << 7) /* Bit 7: Status register protect 0 */
|
#define STATUS_SRP0_MASK (1 << 7) /* Bit 7: Status register protect 0 */
|
||||||
# define STATUS_SRP0_UNLOCKED (0 << 7) /* 0 = WP# no effect / PS Lock Down */
|
# define STATUS_SRP0_UNLOCKED (0 << 7) /* 0 = WP# no effect / PS Lock Down */
|
||||||
# define STATUS_SRP0_LOCKED (1 << 7) /* 1 = WP# protect / OTP Lock Down */
|
# define STATUS_SRP0_LOCKED (1 << 7) /* 1 = WP# protect / OTP Lock Down */
|
||||||
@ -979,7 +978,7 @@ static int n25qxxx_flush_cache(struct n25qxxx_dev_s *priv)
|
|||||||
ferr("ERROR: n25qxxx_write_page failed: %d\n", ret);
|
ferr("ERROR: n25qxxx_write_page failed: %d\n", ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The case is no long dirty and the FLASH is no longer erased */
|
/* The cache is no long dirty and the FLASH is no longer erased */
|
||||||
|
|
||||||
CLR_DIRTY(priv);
|
CLR_DIRTY(priv);
|
||||||
CLR_ERASED(priv);
|
CLR_ERASED(priv);
|
||||||
@ -1002,7 +1001,7 @@ static FAR uint8_t *n25qxxx_read_cache(struct n25qxxx_dev_s *priv, off_t sector)
|
|||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* Convert from the 512 byte sector to the erase sector size of the device. For
|
/* Convert from the 512 byte sector to the erase sector size of the device. For
|
||||||
* exmample, if the actual erase sector size if 4Kb (1 << 12), then we first
|
* example, if the actual erase sector size is 4Kb (1 << 12), then we first
|
||||||
* shift to the right by 3 to get the sector number in 4096 increments.
|
* shift to the right by 3 to get the sector number in 4096 increments.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -1218,11 +1217,11 @@ static ssize_t n25qxxx_bread(FAR struct mtd_dev_s *dev, off_t startblock,
|
|||||||
nbytes >>= N25QXXX_SECTOR512_SHIFT;
|
nbytes >>= N25QXXX_SECTOR512_SHIFT;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
nbytes = n25qxxx_read(dev, startblock << priv->sectorshift,
|
nbytes = n25qxxx_read(dev, startblock << priv->pageshift,
|
||||||
nblocks << priv->sectorshift, buffer);
|
nblocks << priv->pageshift, buffer);
|
||||||
if (nbytes > 0)
|
if (nbytes > 0)
|
||||||
{
|
{
|
||||||
nbytes >>= priv->sectorshift;
|
nbytes >>= priv->pageshift;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1253,8 +1252,8 @@ static ssize_t n25qxxx_bwrite(FAR struct mtd_dev_s *dev, off_t startblock,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
ret = n25qxxx_write_page(priv, buffer, startblock << priv->sectorshift,
|
ret = n25qxxx_write_page(priv, buffer, startblock << priv->pageshift,
|
||||||
nblocks << priv->sectorshift);
|
nblocks << priv->pageshift);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
ferr("ERROR: n25qxxx_write_page failed: %d\n", ret);
|
ferr("ERROR: n25qxxx_write_page failed: %d\n", ret);
|
||||||
@ -1328,7 +1327,7 @@ static int n25qxxx_ioctl(FAR struct mtd_dev_s *dev, int cmd, unsigned long arg)
|
|||||||
geo->erasesize = (1 << N25QXXX_SECTOR512_SHIFT);
|
geo->erasesize = (1 << N25QXXX_SECTOR512_SHIFT);
|
||||||
geo->neraseblocks = priv->nsectors << (priv->sectorshift - N25QXXX_SECTOR512_SHIFT);
|
geo->neraseblocks = priv->nsectors << (priv->sectorshift - N25QXXX_SECTOR512_SHIFT);
|
||||||
#else
|
#else
|
||||||
geo->blocksize = (1 << priv->sectorshift);
|
geo->blocksize = (1 << priv->pageshift);
|
||||||
geo->erasesize = (1 << priv->sectorshift);
|
geo->erasesize = (1 << priv->sectorshift);
|
||||||
geo->neraseblocks = priv->nsectors;
|
geo->neraseblocks = priv->nsectors;
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user