mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-07 14:24:18 +08:00
d2912cb15b
Based on 2 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation # extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 4122 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Enrico Weigelt <info@metux.net> Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190604081206.933168790@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
59 lines
1.3 KiB
C
59 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright © 2009 - Maxim Levitsky
|
|
* Common routines & support for SmartMedia/xD format
|
|
*/
|
|
#include <linux/bitops.h>
|
|
#include <linux/mtd/mtd.h>
|
|
|
|
/* Full oob structure as written on the flash */
|
|
struct sm_oob {
|
|
uint32_t reserved;
|
|
uint8_t data_status;
|
|
uint8_t block_status;
|
|
uint8_t lba_copy1[2];
|
|
uint8_t ecc2[3];
|
|
uint8_t lba_copy2[2];
|
|
uint8_t ecc1[3];
|
|
} __packed;
|
|
|
|
|
|
/* one sector is always 512 bytes, but it can consist of two nand pages */
|
|
#define SM_SECTOR_SIZE 512
|
|
|
|
/* oob area is also 16 bytes, but might be from two pages */
|
|
#define SM_OOB_SIZE 16
|
|
|
|
/* This is maximum zone size, and all devices that have more that one zone
|
|
have this size */
|
|
#define SM_MAX_ZONE_SIZE 1024
|
|
|
|
/* support for small page nand */
|
|
#define SM_SMALL_PAGE 256
|
|
#define SM_SMALL_OOB_SIZE 8
|
|
|
|
|
|
int sm_register_device(struct mtd_info *mtd, int smartmedia);
|
|
|
|
|
|
static inline int sm_sector_valid(struct sm_oob *oob)
|
|
{
|
|
return hweight16(oob->data_status) >= 5;
|
|
}
|
|
|
|
static inline int sm_block_valid(struct sm_oob *oob)
|
|
{
|
|
return hweight16(oob->block_status) >= 7;
|
|
}
|
|
|
|
static inline int sm_block_erased(struct sm_oob *oob)
|
|
{
|
|
static const uint32_t erased_pattern[4] = {
|
|
0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF };
|
|
|
|
/* First test for erased block */
|
|
if (!memcmp(oob, erased_pattern, sizeof(*oob)))
|
|
return 1;
|
|
return 0;
|
|
}
|