blob: 902b5f56a7498ed00a83ca93ab1fb538bf7f63f8 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Benoît Thébaudeaua8e88552013-04-23 10:17:40 +00002/*
3 * (C) Copyright 2009-2013 ADVANSEE
4 * Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
5 *
6 * Based on the mpc512x iim code:
7 * Copyright 2008 Silicon Turnkey Express, Inc.
8 * Martha Marx <mmarx@silicontkx.com>
Benoît Thébaudeaua8e88552013-04-23 10:17:40 +00009 */
10
11#ifndef _FUSE_H_
12#define _FUSE_H_
13
Tom Rinidec7ea02024-05-20 13:35:03 -060014#include <linux/types.h>
Harsha Vardhan V M80f12282025-03-19 14:17:12 +053015#include <linux/errno.h>
Tom Rinidec7ea02024-05-20 13:35:03 -060016
Benoît Thébaudeaua8e88552013-04-23 10:17:40 +000017/*
18 * Read/Sense/Program/Override interface:
19 * bank: Fuse bank
20 * word: Fuse word within the bank
21 * val: Value to read/write
22 *
23 * Returns: 0 on success, not 0 on failure
24 */
25int fuse_read(u32 bank, u32 word, u32 *val);
26int fuse_sense(u32 bank, u32 word, u32 *val);
27int fuse_prog(u32 bank, u32 word, u32 val);
28int fuse_override(u32 bank, u32 word, u32 val);
Harsha Vardhan V M80f12282025-03-19 14:17:12 +053029#ifdef CONFIG_CMD_FUSE_WRITEBUFF
30int fuse_writebuff(ulong addr);
31#else
32static inline int fuse_writebuff(ulong addr)
33{
34 return -EPERM;
35}
36#endif /* CONFIG_CMD_FUSE_WRITEBUFF */
Benoît Thébaudeaua8e88552013-04-23 10:17:40 +000037
38#endif /* _FUSE_H_ */