mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-22 18:05:14 +00:00
83d290c56f
When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
116 lines
3.4 KiB
C
116 lines
3.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Copyright (C) 2005-2009 Samsung Electronics
|
|
* Minkyu Kang <mk7.kang@samsung.com>
|
|
* Kyungmin Park <kyungmin.park@samsung.com>
|
|
*/
|
|
|
|
#ifndef __SAMSUNG_ONENAND_H__
|
|
#define __SAMSUNG_ONENAND_H__
|
|
|
|
/*
|
|
* OneNAND Controller
|
|
*/
|
|
|
|
#ifndef __ASSEMBLY__
|
|
struct samsung_onenand {
|
|
unsigned int mem_cfg; /* 0x0000 */
|
|
unsigned char res1[0xc];
|
|
unsigned int burst_len; /* 0x0010 */
|
|
unsigned char res2[0xc];
|
|
unsigned int mem_reset; /* 0x0020 */
|
|
unsigned char res3[0xc];
|
|
unsigned int int_err_stat; /* 0x0030 */
|
|
unsigned char res4[0xc];
|
|
unsigned int int_err_mask; /* 0x0040 */
|
|
unsigned char res5[0xc];
|
|
unsigned int int_err_ack; /* 0x0050 */
|
|
unsigned char res6[0xc];
|
|
unsigned int ecc_err_stat; /* 0x0060 */
|
|
unsigned char res7[0xc];
|
|
unsigned int manufact_id; /* 0x0070 */
|
|
unsigned char res8[0xc];
|
|
unsigned int device_id; /* 0x0080 */
|
|
unsigned char res9[0xc];
|
|
unsigned int data_buf_size; /* 0x0090 */
|
|
unsigned char res10[0xc];
|
|
unsigned int boot_buf_size; /* 0x00A0 */
|
|
unsigned char res11[0xc];
|
|
unsigned int buf_amount; /* 0x00B0 */
|
|
unsigned char res12[0xc];
|
|
unsigned int tech; /* 0x00C0 */
|
|
unsigned char res13[0xc];
|
|
unsigned int fba; /* 0x00D0 */
|
|
unsigned char res14[0xc];
|
|
unsigned int fpa; /* 0x00E0 */
|
|
unsigned char res15[0xc];
|
|
unsigned int fsa; /* 0x00F0 */
|
|
unsigned char res16[0x3c];
|
|
unsigned int sync_mode; /* 0x0130 */
|
|
unsigned char res17[0xc];
|
|
unsigned int trans_spare; /* 0x0140 */
|
|
unsigned char res18[0x3c];
|
|
unsigned int err_page_addr; /* 0x0180 */
|
|
unsigned char res19[0x1c];
|
|
unsigned int int_pin_en; /* 0x01A0 */
|
|
unsigned char res20[0x1c];
|
|
unsigned int acc_clock; /* 0x01C0 */
|
|
unsigned char res21[0x1c];
|
|
unsigned int err_blk_addr; /* 0x01E0 */
|
|
unsigned char res22[0xc];
|
|
unsigned int flash_ver_id; /* 0x01F0 */
|
|
unsigned char res23[0x6c];
|
|
unsigned int watchdog_cnt_low; /* 0x0260 */
|
|
unsigned char res24[0xc];
|
|
unsigned int watchdog_cnt_hi; /* 0x0270 */
|
|
unsigned char res25[0xc];
|
|
unsigned int sync_write; /* 0x0280 */
|
|
unsigned char res26[0x1c];
|
|
unsigned int cold_reset; /* 0x02A0 */
|
|
unsigned char res27[0xc];
|
|
unsigned int ddp_device; /* 0x02B0 */
|
|
unsigned char res28[0xc];
|
|
unsigned int multi_plane; /* 0x02C0 */
|
|
unsigned char res29[0x1c];
|
|
unsigned int trans_mode; /* 0x02E0 */
|
|
unsigned char res30[0x1c];
|
|
unsigned int ecc_err_stat2; /* 0x0300 */
|
|
unsigned char res31[0xc];
|
|
unsigned int ecc_err_stat3; /* 0x0310 */
|
|
unsigned char res32[0xc];
|
|
unsigned int ecc_err_stat4; /* 0x0320 */
|
|
unsigned char res33[0x1c];
|
|
unsigned int dev_page_size; /* 0x0340 */
|
|
unsigned char res34[0x4c];
|
|
unsigned int int_mon_status; /* 0x0390 */
|
|
};
|
|
#endif
|
|
|
|
#define ONENAND_MEM_RESET_HOT 0x3
|
|
#define ONENAND_MEM_RESET_COLD 0x2
|
|
#define ONENAND_MEM_RESET_WARM 0x1
|
|
|
|
#define INT_ERR_ALL 0x3fff
|
|
#define CACHE_OP_ERR (1 << 13)
|
|
#define RST_CMP (1 << 12)
|
|
#define RDY_ACT (1 << 11)
|
|
#define INT_ACT (1 << 10)
|
|
#define UNSUP_CMD (1 << 9)
|
|
#define LOCKED_BLK (1 << 8)
|
|
#define BLK_RW_CMP (1 << 7)
|
|
#define ERS_CMP (1 << 6)
|
|
#define PGM_CMP (1 << 5)
|
|
#define LOAD_CMP (1 << 4)
|
|
#define ERS_FAIL (1 << 3)
|
|
#define PGM_FAIL (1 << 2)
|
|
#define INT_TO (1 << 1)
|
|
#define LD_FAIL_ECC_ERR (1 << 0)
|
|
|
|
#define TSRF (1 << 0)
|
|
|
|
/* common initialize function */
|
|
extern void s3c_onenand_init(struct mtd_info *);
|
|
extern int s5pc110_chip_probe(struct mtd_info *);
|
|
extern int s5pc210_chip_probe(struct mtd_info *);
|
|
|
|
#endif
|