/* SPDX-License-Identifier: GPL-2.0 */ #ifndef __NVBIOS_I2C_H__ #define __NVBIOS_I2C_H__ enum dcb_i2c_type { /* matches bios type field prior to ccb 4.1 */ DCB_I2C_NV04_BIT = 0x00, DCB_I2C_NV4E_BIT = 0x04, DCB_I2C_NVIO_BIT = 0x05, DCB_I2C_NVIO_AUX = 0x06, /* made up - mostly */ DCB_I2C_PMGR = 0x80, DCB_I2C_UNUSED = 0xff }; struct dcb_i2c_entry { enum dcb_i2c_type type; u8 drive; u8 sense; u8 share; u8 auxch; }; u16 dcb_i2c_table(struct nvkm_bios *, u8 *ver, u8 *hdr, u8 *cnt, u8 *len); u16 dcb_i2c_entry(struct nvkm_bios *, u8 index, u8 *ver, u8 *len); int dcb_i2c_parse(struct nvkm_bios *, u8 index, struct dcb_i2c_entry *); #endif