--- a/arch/mips/adm5120/common/platform.c
 +++ b/arch/mips/adm5120/common/platform.c
-@@ -190,7 +190,6 @@ struct amba_pl010_data adm5120_uart0_dat
+@@ -190,7 +190,7 @@ struct amba_pl010_data adm5120_uart0_dat
  
  struct amba_device adm5120_uart0_device = {
        .dev            = {
 -              .bus_id = "APB:UART0",
++              .init_name = "apb:uart0",
                .platform_data = &adm5120_uart0_data,
        },
        .res            = {
-@@ -208,7 +207,6 @@ struct amba_pl010_data adm5120_uart1_dat
+@@ -208,7 +208,7 @@ struct amba_pl010_data adm5120_uart1_dat
  
  struct amba_device adm5120_uart1_device = {
        .dev            = {
 -              .bus_id = "APB:UART1",
++              .init_name = "apb:uart1",
                .platform_data = &adm5120_uart1_data,
        },
        .res            = {
 
--- /dev/null
+--- a/arch/mips/adm5120/common/clock.c
++++ b/arch/mips/adm5120/common/clock.c
+@@ -19,6 +19,7 @@
+ #include <linux/module.h>
+ #include <linux/err.h>
+ #include <linux/clk.h>
++#include <linux/device.h>
+ 
+ #include <asm/mach-adm5120/adm5120_defs.h>
+ 
+@@ -32,7 +33,9 @@ static struct clk uart_clk = {
+ 
+ struct clk *clk_get(struct device *dev, const char *id)
+ {
+-      if (!strcmp(id, "UARTCLK"))
++      char *name = dev_name(dev);
++
++      if (!strcmp(name, "apb:uart0") || !strcmp(name, "apb:uart1"))
+               return &uart_clk;
+ 
+       return ERR_PTR(-ENOENT);