i2c: Create common default i2c_[set|get]_bus_speed() functions
authorPeter Tyser <ptyser@xes-inc.com>
Sun, 19 Apr 2009 03:34:01 +0000 (22:34 -0500)
committerWolfgang Denk <wd@denx.de>
Fri, 12 Jun 2009 18:39:45 +0000 (20:39 +0200)
New default, weak i2c_get_bus_speed() and i2c_set_bus_speed() functions
replace a number of architecture-specific implementations.

Also, providing default functions will allow all boards to enable
CONFIG_I2C_CMD_TREE.  This was previously not possible since the
tree-form of the i2c command provides the ability to display and modify
the i2c bus speed which requires i2c_[set|get]_bus_speed() to be
present.

Signed-off-by: Peter Tyser <ptyser@xes-inc.com>
common/cmd_i2c.c
cpu/arm920t/at91rm9200/i2c.c
cpu/mpc512x/i2c.c
cpu/mpc8260/i2c.c
cpu/ppc4xx/i2c.c
drivers/i2c/soft_i2c.c

index 16439ac489c4948fc833bd38e456eea8905f4be2..c071df732650e5b41a59772683a2bf676121dbd9 100644 (file)
@@ -138,6 +138,24 @@ DECLARE_GLOBAL_DATA_PTR;
 static int
 mod_i2c_mem(cmd_tbl_t *cmdtp, int incrflag, int flag, int argc, char *argv[]);
 
+/* TODO: Implement architecture-specific get/set functions */
+unsigned int __def_i2c_get_bus_speed(void)
+{
+       return CONFIG_SYS_I2C_SPEED;
+}
+unsigned int i2c_get_bus_speed(void)
+       __attribute__((weak, alias("__def_i2c_get_bus_speed")));
+
+int __def_i2c_set_bus_speed(unsigned int speed)
+{
+       if (speed != CONFIG_SYS_I2C_SPEED)
+               return -1;
+
+       return 0;
+}
+int i2c_set_bus_speed(unsigned int)
+       __attribute__((weak, alias("__def_i2c_set_bus_speed")));
+
 /*
  * Syntax:
  *     imd {i2c_chip} {addr}{.0, .1, .2} {len}
index 9fd72d3977b3bf363825e8ef47f4086b8d1c47d1..1711088ad31a00b513fb7ba21d5cac403cc466e8 100644 (file)
@@ -189,14 +189,4 @@ i2c_init(int speed, int slaveaddr)
        return;
 }
 
-int i2c_set_bus_speed(unsigned int speed)
-{
-       return -1;
-}
-
-unsigned int i2c_get_bus_speed(void)
-{
-       return CONFIG_SYS_I2C_SPEED;
-}
-
 #endif /* CONFIG_HARD_I2C */
index 4f6bc864048d7ac84a7ca9de61f937e587d1d3f7..0da906a514a2e929713775e50c7fc094e5388f38 100644 (file)
@@ -397,18 +397,4 @@ unsigned int i2c_get_bus_num (void)
        return bus_num;
 }
 
-/* TODO */
-unsigned int i2c_get_bus_speed (void)
-{
-       return -1;
-}
-
-int i2c_set_bus_speed (unsigned int speed)
-{
-       if (speed != CONFIG_SYS_I2C_SPEED)
-               return -1;
-
-       return 0;
-}
-
 #endif /* CONFIG_HARD_I2C */
index 2b954b48fcb4ceb1c0826f4579d73435e73980dd..d2bdcc2d827f99e1560a334f996a9f1f860c79ba 100644 (file)
@@ -780,19 +780,6 @@ int i2c_set_bus_num(unsigned int bus)
 #endif
        return 0;
 }
-/* TODO: add 100/400k switching */
-unsigned int i2c_get_bus_speed(void)
-{
-       return CONFIG_SYS_I2C_SPEED;
-}
-
-int i2c_set_bus_speed(unsigned int speed)
-{
-       if (speed != CONFIG_SYS_I2C_SPEED)
-               return -1;
-
-       return 0;
-}
 
 #endif /* CONFIG_I2C_MULTI_BUS */
 #endif /* CONFIG_HARD_I2C */
index 9d416ca5e8fdab6eac8e376dfdabb302f09f2edd..e3e1bab64f5473ad8fe71d1cd9fb08bd7352581f 100644 (file)
@@ -438,18 +438,4 @@ int i2c_set_bus_num(unsigned int bus)
        return 0;
 }
 #endif /* CONFIG_I2C_MULTI_BUS */
-
-/* TODO: add 100/400k switching */
-unsigned int i2c_get_bus_speed(void)
-{
-       return CONFIG_SYS_I2C_SPEED;
-}
-
-int i2c_set_bus_speed(unsigned int speed)
-{
-       if (speed != CONFIG_SYS_I2C_SPEED)
-               return -1;
-
-       return 0;
-}
 #endif /* CONFIG_HARD_I2C */
index 185634d51003d4a3512b52f050f15a20d5dc0fb7..59883a58f674e96d696e98de6df2e9d13b630d1f 100644 (file)
@@ -244,20 +244,6 @@ int i2c_set_bus_num(unsigned int bus)
 }
 #endif
 
-/* TODO: add 100/400k switching */
-unsigned int i2c_get_bus_speed(void)
-{
-       return CONFIG_SYS_I2C_SPEED;
-}
-
-int i2c_set_bus_speed(unsigned int speed)
-{
-       if (speed != CONFIG_SYS_I2C_SPEED)
-               return -1;
-
-       return 0;
-}
-
 /*-----------------------------------------------------------------------
  * if ack == I2C_ACK, ACK the byte so can continue reading, else
  * send I2C_NOACK to end the read.