xref: /rk3399_rockchip-uboot/drivers/misc/mc9sdz60.c (revision 1221ce459d04a428f8880f58581f671b736c3c27)
101bb24b6SStefano Babic /*
201bb24b6SStefano Babic  * (C) Copyright 2010 Stefano Babic <sbabic@denx.de>
301bb24b6SStefano Babic  *
41a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
501bb24b6SStefano Babic  */
601bb24b6SStefano Babic 
701bb24b6SStefano Babic 
801bb24b6SStefano Babic #include <config.h>
901bb24b6SStefano Babic #include <common.h>
10*1221ce45SMasahiro Yamada #include <linux/errno.h>
1101bb24b6SStefano Babic #include <linux/types.h>
1201bb24b6SStefano Babic #include <i2c.h>
1301bb24b6SStefano Babic #include <mc9sdz60.h>
1401bb24b6SStefano Babic 
1501bb24b6SStefano Babic #ifndef CONFIG_SYS_FSL_MC9SDZ60_I2C_ADDR
1601bb24b6SStefano Babic #error "You have to configure I2C address for MC9SDZ60"
1701bb24b6SStefano Babic #endif
1801bb24b6SStefano Babic 
1901bb24b6SStefano Babic 
mc9sdz60_reg_read(enum mc9sdz60_reg reg)2001bb24b6SStefano Babic u8 mc9sdz60_reg_read(enum mc9sdz60_reg reg)
2101bb24b6SStefano Babic {
2201bb24b6SStefano Babic 	u8 val;
2301bb24b6SStefano Babic 
2401bb24b6SStefano Babic 	if (i2c_read(CONFIG_SYS_FSL_MC9SDZ60_I2C_ADDR, reg, 1, &val, 1)) {
2501bb24b6SStefano Babic 		puts("Error reading MC9SDZ60 register\n");
2601bb24b6SStefano Babic 		return -1;
2701bb24b6SStefano Babic 	}
2801bb24b6SStefano Babic 
2901bb24b6SStefano Babic 	return val;
3001bb24b6SStefano Babic }
3101bb24b6SStefano Babic 
mc9sdz60_reg_write(enum mc9sdz60_reg reg,u8 val)3201bb24b6SStefano Babic void mc9sdz60_reg_write(enum mc9sdz60_reg reg, u8 val)
3301bb24b6SStefano Babic {
3401bb24b6SStefano Babic 	i2c_write(CONFIG_SYS_FSL_MC9SDZ60_I2C_ADDR, reg, 1, &val, 1);
3501bb24b6SStefano Babic }
36