2  * PIKA Warp(tm) board specific routines
 
   4  * Copyright (c) 2008 PIKA Technologies
 
   5  *   Sean MacLennan <smaclennan@pikatech.com>
 
   7  * This program is free software; you can redistribute  it and/or modify it
 
   8  * under  the terms of  the GNU General  Public License as published by the
 
   9  * Free Software Foundation;  either version 2 of the  License, or (at your
 
  10  * option) any later version.
 
  12 #include <linux/init.h>
 
  13 #include <linux/of_platform.h>
 
  14 #include <linux/kthread.h>
 
  15 #include <linux/i2c.h>
 
  16 #include <linux/interrupt.h>
 
  17 #include <linux/delay.h>
 
  19 #include <asm/machdep.h>
 
  24 #include <asm/ppc4xx.h>
 
  26 static __initdata struct of_device_id warp_of_bus[] = {
 
  27         { .compatible = "ibm,plb4", },
 
  28         { .compatible = "ibm,opb", },
 
  29         { .compatible = "ibm,ebc", },
 
  33 static int __init warp_device_probe(void)
 
  35         of_platform_bus_probe(NULL, warp_of_bus, NULL);
 
  38 machine_device_initcall(warp, warp_device_probe);
 
  40 static int __init warp_probe(void)
 
  42         unsigned long root = of_get_flat_dt_root();
 
  44         return of_flat_dt_is_compatible(root, "pika,warp");
 
  47 define_machine(warp) {
 
  50         .progress       = udbg_progress,
 
  51         .init_IRQ       = uic_init_tree,
 
  52         .get_irq        = uic_get_irq,
 
  53         .restart        = ppc4xx_reset_system,
 
  54         .calibrate_decr = generic_calibrate_decr,
 
  58 /* I am not sure this is the best place for this... */
 
  59 static int __init warp_post_info(void)
 
  61         struct device_node *np;
 
  65         /* Sighhhh... POST information is in the sd area. */
 
  66         np = of_find_compatible_node(NULL, NULL, "pika,fpga-sd");
 
  70         fpga = of_iomap(np, 0);
 
  75         post1 = in_be32(fpga + 0x40);
 
  76         post2 = in_be32(fpga + 0x44);
 
  81                 printk(KERN_INFO "Warp POST %08x %08x\n", post1, post2);
 
  83                 printk(KERN_INFO "Warp POST OK\n");
 
  87 machine_late_initcall(warp, warp_post_info);
 
  90 #ifdef CONFIG_SENSORS_AD7414
 
  92 static LIST_HEAD(dtm_shutdown_list);
 
  93 static void __iomem *dtm_fpga;
 
  94 static void __iomem *gpio_base;
 
  98         struct list_head list;
 
  99         void (*func)(void *arg);
 
 104 int pika_dtm_register_shutdown(void (*func)(void *arg), void *arg)
 
 106         struct dtm_shutdown *shutdown;
 
 108         shutdown = kmalloc(sizeof(struct dtm_shutdown), GFP_KERNEL);
 
 109         if (shutdown == NULL)
 
 112         shutdown->func = func;
 
 115         list_add(&shutdown->list, &dtm_shutdown_list);
 
 120 int pika_dtm_unregister_shutdown(void (*func)(void *arg), void *arg)
 
 122         struct dtm_shutdown *shutdown;
 
 124         list_for_each_entry(shutdown, &dtm_shutdown_list, list)
 
 125                 if (shutdown->func == func && shutdown->arg == arg) {
 
 126                         list_del(&shutdown->list);
 
 134 static irqreturn_t temp_isr(int irq, void *context)
 
 136         struct dtm_shutdown *shutdown;
 
 140         /* Run through the shutdown list. */
 
 141         list_for_each_entry(shutdown, &dtm_shutdown_list, list)
 
 142                 shutdown->func(shutdown->arg);
 
 144         printk(KERN_EMERG "\n\nCritical Temperature Shutdown\n");
 
 148                         unsigned reset = in_be32(dtm_fpga + 0x14);
 
 149                         out_be32(dtm_fpga + 0x14, reset);
 
 153                         unsigned leds = in_be32(gpio_base);
 
 155                         /* green off, red toggle */
 
 159                         out_be32(gpio_base, leds);
 
 166 static int pika_setup_leds(void)
 
 168         struct device_node *np;
 
 172         np = of_find_compatible_node(NULL, NULL, "linux,gpio-led");
 
 174                 printk(KERN_ERR __FILE__ ": Unable to find gpio-led\n");
 
 178         gpios = of_get_property(np, "gpios", &len);
 
 180         if (!gpios || len < 4) {
 
 181                 printk(KERN_ERR __FILE__
 
 182                        ": Unable to get gpios property (%d)\n", len);
 
 186         np = of_find_node_by_phandle(gpios[0]);
 
 188                 printk(KERN_ERR __FILE__ ": Unable to find gpio\n");
 
 192         gpio_base = of_iomap(np, 0);
 
 195                 printk(KERN_ERR __FILE__ ": Unable to map gpio");
 
 202 static void pika_setup_critical_temp(struct i2c_client *client)
 
 204         struct device_node *np;
 
 207         /* Do this before enabling critical temp interrupt since we
 
 208          * may immediately interrupt.
 
 212         /* These registers are in 1 degree increments. */
 
 213         i2c_smbus_write_byte_data(client, 2, 65); /* Thigh */
 
 214         i2c_smbus_write_byte_data(client, 3,  0); /* Tlow */
 
 216         np = of_find_compatible_node(NULL, NULL, "adi,ad7414");
 
 218                 printk(KERN_ERR __FILE__ ": Unable to find ad7414\n");
 
 222         irq = irq_of_parse_and_map(np, 0);
 
 225                 printk(KERN_ERR __FILE__ ": Unable to get ad7414 irq\n");
 
 229         rc = request_irq(irq, temp_isr, 0, "ad7414", NULL);
 
 231                 printk(KERN_ERR __FILE__
 
 232                        ": Unable to request ad7414 irq %d = %d\n", irq, rc);
 
 237 static inline void pika_dtm_check_fan(void __iomem *fpga)
 
 239         static int fan_state;
 
 240         u32 fan = in_be32(fpga + 0x34) & (1 << 14);
 
 242         if (fan_state != fan) {
 
 245                         printk(KERN_WARNING "Fan rotation error detected."
 
 246                                    " Please check hardware.\n");
 
 250 static int pika_dtm_thread(void __iomem *fpga)
 
 252         struct i2c_adapter *adap;
 
 253         struct i2c_client *client;
 
 255         /* We loop in case either driver was compiled as a module and
 
 256          * has not been insmoded yet.
 
 258         while (!(adap = i2c_get_adapter(0))) {
 
 259                 set_current_state(TASK_INTERRUPTIBLE);
 
 260                 schedule_timeout(HZ);
 
 264                 list_for_each_entry(client, &adap->clients, list)
 
 265                         if (client->addr == 0x4a)
 
 268                 set_current_state(TASK_INTERRUPTIBLE);
 
 269                 schedule_timeout(HZ);
 
 273         i2c_put_adapter(adap);
 
 275         pika_setup_critical_temp(client);
 
 277         printk(KERN_INFO "PIKA DTM thread running.\n");
 
 279         while (!kthread_should_stop()) {
 
 282                 val = i2c_smbus_read_word_data(client, 0);
 
 284                         dev_dbg(&client->dev, "DTM read temp failed.\n");
 
 286                         s16 temp = swab16(val);
 
 287                         out_be32(fpga + 0x20, temp);
 
 290                 pika_dtm_check_fan(fpga);
 
 292                 set_current_state(TASK_INTERRUPTIBLE);
 
 293                 schedule_timeout(HZ);
 
 300 static int __init pika_dtm_start(void)
 
 302         struct task_struct *dtm_thread;
 
 303         struct device_node *np;
 
 305         np = of_find_compatible_node(NULL, NULL, "pika,fpga");
 
 309         dtm_fpga = of_iomap(np, 0);
 
 311         if (dtm_fpga == NULL)
 
 314         dtm_thread = kthread_run(pika_dtm_thread, dtm_fpga, "pika-dtm");
 
 315         if (IS_ERR(dtm_thread)) {
 
 317                 return PTR_ERR(dtm_thread);
 
 322 machine_late_initcall(warp, pika_dtm_start);
 
 324 #else /* !CONFIG_SENSORS_AD7414 */
 
 326 int pika_dtm_register_shutdown(void (*func)(void *arg), void *arg)
 
 331 int pika_dtm_unregister_shutdown(void (*func)(void *arg), void *arg)
 
 338 EXPORT_SYMBOL(pika_dtm_register_shutdown);
 
 339 EXPORT_SYMBOL(pika_dtm_unregister_shutdown);