Changeset c188c62 in mainline for uspace/drv/bus
- Timestamp:
- 2017-10-05T18:00:52Z (8 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- 81b9d3e
- Parents:
- e27e36e
- Location:
- uspace/drv/bus/adb/cuda_adb
- Files:
- 
      - 3 edited
 
 - 
          
  cuda_adb.c (modified) (5 diffs)
- 
          
  cuda_adb.h (modified) (3 diffs)
- 
          
  main.c (modified) (3 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      uspace/drv/bus/adb/cuda_adb/cuda_adb.cre27e36e rc188c62 148 148 } 149 149 150 int cuda_add(cuda_t *cuda )150 int cuda_add(cuda_t *cuda, cuda_res_t *res) 151 151 { 152 152 adb_dev_t *kbd = NULL; … … 154 154 int rc; 155 155 156 cuda->phys_base = res->base; 157 156 158 rc = cuda_dev_create(cuda, "kbd", &kbd); 157 159 if (rc != EOK) … … 166 168 167 169 cuda->addr_dev[9] = mouse; 168 169 170 170 171 rc = cuda_init(cuda); … … 225 226 int rc; 226 227 227 if (sysinfo_get_value("cuda.address.physical", &(cuda->cuda_physical)) != EOK)228 return EIO;229 230 228 void *vaddr; 231 rc = pio_enable((void *) cuda-> cuda_physical, sizeof(cuda_regs_t),229 rc = pio_enable((void *) cuda->phys_base, sizeof(cuda_regs_t), 232 230 &vaddr); 233 231 if (rc != EOK) … … 244 242 pio_write_8(&cuda->regs->ier, IER_CLR | ALL_INT); 245 243 246 cuda_irq_code.ranges[0].base = (uintptr_t) cuda-> cuda_physical;244 cuda_irq_code.ranges[0].base = (uintptr_t) cuda->phys_base; 247 245 cuda_irq_code.cmds[0].addr = (void *) &((cuda_regs_t *) 248 cuda-> cuda_physical)->ifr;246 cuda->phys_base)->ifr; 249 247 async_irq_subscribe(10, cuda_irq_handler, cuda, &cuda_irq_code); 250 248 
- 
      uspace/drv/bus/adb/cuda_adb/cuda_adb.hre27e36e rc188c62 57 57 }; 58 58 59 typedef struct { 60 uintptr_t base; 61 int irq; 62 } cuda_res_t; 63 59 64 /** ADB bus device */ 60 65 typedef struct { … … 68 73 typedef struct cude { 69 74 struct cuda_regs *regs; 70 uintptr_t cuda_physical;75 uintptr_t phys_base; 71 76 ddf_dev_t *dev; 72 77 … … 82 87 } cuda_t; 83 88 84 extern int cuda_add(cuda_t * );89 extern int cuda_add(cuda_t *, cuda_res_t *); 85 90 extern int cuda_remove(cuda_t *); 86 91 extern int cuda_gone(cuda_t *); 
- 
      uspace/drv/bus/adb/cuda_adb/main.cre27e36e rc188c62 35 35 #include <ddf/driver.h> 36 36 #include <ddf/log.h> 37 #include <device/hw_res_parsed.h> 37 38 #include <errno.h> 38 39 #include <stdio.h> … … 61 62 }; 62 63 64 static int cuda_get_res(ddf_dev_t *dev, cuda_res_t *res) 65 { 66 async_sess_t *parent_sess; 67 hw_res_list_parsed_t hw_res; 68 int rc; 69 70 parent_sess = ddf_dev_parent_sess_create(dev); 71 if (parent_sess == NULL) 72 return ENOMEM; 73 74 hw_res_list_parsed_init(&hw_res); 75 rc = hw_res_get_list_parsed(parent_sess, &hw_res, 0); 76 if (rc != EOK) 77 return rc; 78 79 if (hw_res.io_ranges.count != 1) { 80 rc = EINVAL; 81 goto error; 82 } 83 84 res->base = RNGABS(hw_res.io_ranges.ranges[0]); 85 86 if (hw_res.irqs.count != 1) { 87 rc = EINVAL; 88 goto error; 89 } 90 91 res->irq = hw_res.irqs.irqs[0]; 92 93 return EOK; 94 error: 95 hw_res_list_parsed_clean(&hw_res); 96 return rc; 97 } 98 63 99 static int cuda_dev_add(ddf_dev_t *dev) 64 100 { 65 101 cuda_t *cuda; 102 cuda_res_t cuda_res; 103 int rc; 66 104 67 printf("cuda_dev_add\n");68 105 ddf_msg(LVL_DEBUG, "cuda_dev_add(%p)", dev); 69 106 cuda = ddf_dev_data_alloc(dev, sizeof(cuda_t)); … … 75 112 cuda->dev = dev; 76 113 list_initialize(&cuda->devs); 77 printf("call cuda_add\n"); 78 int rc = cuda_add(cuda); 79 printf("cuda_add->%d\n", rc); 80 return rc; 114 115 rc = cuda_get_res(dev, &cuda_res); 116 if (rc != EOK) { 117 ddf_msg(LVL_ERROR, "Failed getting hardware resource list.\n"); 118 return EIO; 119 } 120 121 return cuda_add(cuda, &cuda_res); 81 122 } 82 123 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
