summaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-imx/include/mach/ocotp.h
blob: 430bc756beffcba322b0e0e5ae325292c0419820 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#ifndef __MACH_IMX_OCOTP_H
#define __MACH_IMX_OCOTP_H

#define OCOTP_WORD_MASK_WIDTH	8
#define OCOTP_WORD_MASK_SHIFT	0
#define OCOTP_WORD(n)		((((n) - 0x400) >> 4) & ((1 << OCOTP_WORD_MASK_WIDTH) - 1))

#define OCOTP_BIT_MASK_WIDTH	5
#define OCOTP_BIT_MASK_SHIFT	(OCOTP_WORD_MASK_SHIFT + OCOTP_WORD_MASK_WIDTH)
#define OCOTP_BIT(n)		(((n) & ((1 << OCOTP_BIT_MASK_WIDTH) - 1)) << OCOTP_BIT_MASK_SHIFT)

#define OCOTP_WIDTH_MASK_WIDTH	5
#define OCOTP_WIDTH_MASK_SHIFT	(OCOTP_BIT_MASK_SHIFT + OCOTP_BIT_MASK_WIDTH)
#define OCOTP_WIDTH(n)		((((n) - 1) & ((1 << OCOTP_WIDTH_MASK_WIDTH) - 1)) << OCOTP_WIDTH_MASK_SHIFT)

int imx_ocotp_read_field(uint32_t field, unsigned *value);
int imx_ocotp_write_field(uint32_t field, unsigned value);
int imx_ocotp_permanent_write(int enable);

#endif /* __MACH_IMX_OCOTP_H */