Changeset d9cf684a in mainline
- Timestamp:
- 2011-12-22T14:10:31Z (13 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- fe5e9629
- Parents:
- a438de4
- Location:
- uspace
- Files:
-
- 2 added
- 8 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/drv/bus/isa/Makefile
ra438de4 rd9cf684a 1 1 # 2 2 # Copyright (c) 2010 Lenka Trochtova 3 # Copyright (c) 2011 Jan Vesely 3 4 # All rights reserved. 4 5 # … … 33 34 34 35 SOURCES = \ 36 i8237.c \ 35 37 isa.c 36 38 -
uspace/drv/bus/isa/isa.c
ra438de4 rd9cf684a 2 2 * Copyright (c) 2010 Lenka Trochtova 3 3 * Copyright (c) 2011 Jiri Svoboda 4 * Copyright (c) 2011 Jan Vesely 4 5 * All rights reserved. 5 6 * … … 52 53 #include <fcntl.h> 53 54 #include <sys/stat.h> 55 #include <ipc/irc.h> 56 #include <ipc/services.h> 57 #include <sysinfo.h> 58 #include <ns.h> 54 59 55 60 #include <ddf/driver.h> … … 61 66 #include <device/hw_res.h> 62 67 68 #include "i8237.h" 69 63 70 #define NAME "isa" 64 71 #define CHILD_FUN_CONF_PATH "/drv/isa/isa.dev" … … 70 77 #define ISA_FUN(fun) ((isa_fun_t *) ((fun)->driver_data)) 71 78 72 #define ISA_MAX_HW_RES 479 #define ISA_MAX_HW_RES 5 73 80 74 81 typedef struct { … … 96 103 static bool isa_enable_fun_interrupt(ddf_fun_t *fnode) 97 104 { 98 /* TODO */ 99 100 return false; 105 /* This is an old ugly way, copied from pci driver */ 106 assert(fnode); 107 isa_fun_t *isa_fun = fnode->driver_data; 108 109 sysarg_t apic; 110 sysarg_t i8259; 111 112 async_sess_t *irc_sess = NULL; 113 114 if (((sysinfo_get_value("apic", &apic) == EOK) && (apic)) 115 || ((sysinfo_get_value("i8259", &i8259) == EOK) && (i8259))) { 116 irc_sess = service_connect_blocking(EXCHANGE_SERIALIZE, 117 SERVICE_IRC, 0, 0); 118 } 119 120 if (!irc_sess) 121 return false; 122 123 assert(isa_fun); 124 const hw_resource_list_t *res = &isa_fun->hw_resources; 125 assert(res); 126 for (size_t i = 0; i < res->count; ++i) { 127 if (res->resources[i].type == INTERRUPT) { 128 const int irq = res->resources[i].res.interrupt.irq; 129 130 async_exch_t *exch = async_exchange_begin(irc_sess); 131 const int rc = 132 async_req_1_0(exch, IRC_ENABLE_INTERRUPT, irq); 133 async_exchange_end(exch); 134 135 if (rc != EOK) { 136 async_hangup(irc_sess); 137 return false; 138 } 139 } 140 } 141 142 async_hangup(irc_sess); 143 return true; 144 } 145 146 static int isa_dma_channel_fun_setup(ddf_fun_t *fnode, 147 unsigned int channel, uint32_t pa, uint16_t size, uint8_t mode) 148 { 149 assert(fnode); 150 isa_fun_t *isa_fun = fnode->driver_data; 151 const hw_resource_list_t *res = &isa_fun->hw_resources; 152 assert(res); 153 154 const unsigned int ch = channel; 155 for (size_t i = 0; i < res->count; ++i) { 156 if (((res->resources[i].type == DMA_CHANNEL_16) && 157 (res->resources[i].res.dma_channel.dma16 == ch)) || 158 ((res->resources[i].type == DMA_CHANNEL_8) && 159 (res->resources[i].res.dma_channel.dma8 == ch))) { 160 return dma_setup_channel(channel, pa, size, mode); 161 } 162 } 163 164 return EINVAL; 101 165 } 102 166 103 167 static hw_res_ops_t isa_fun_hw_res_ops = { 104 &isa_get_fun_resources, 105 &isa_enable_fun_interrupt 168 .get_resource_list = isa_get_fun_resources, 169 .enable_interrupt = isa_enable_fun_interrupt, 170 .dma_channel_setup = isa_dma_channel_fun_setup, 106 171 }; 107 172 … … 274 339 } 275 340 341 static void isa_fun_set_dma(isa_fun_t *fun, int dma) 342 { 343 size_t count = fun->hw_resources.count; 344 hw_resource_t *resources = fun->hw_resources.resources; 345 346 if (count < ISA_MAX_HW_RES) { 347 if ((dma > 0) && (dma < 4)) { 348 resources[count].type = DMA_CHANNEL_8; 349 resources[count].res.dma_channel.dma8 = dma; 350 351 fun->hw_resources.count++; 352 ddf_msg(LVL_NOTE, "Added dma 0x%x to function %s", dma, 353 fun->fnode->name); 354 355 return; 356 } 357 358 if ((dma > 4) && (dma < 8)) { 359 resources[count].type = DMA_CHANNEL_16; 360 resources[count].res.dma_channel.dma16 = dma; 361 362 fun->hw_resources.count++; 363 ddf_msg(LVL_NOTE, "Added dma 0x%x to function %s", dma, 364 fun->fnode->name); 365 366 return; 367 } 368 369 ddf_msg(LVL_WARN, "Skipped dma 0x%x for function %s", dma, 370 fun->fnode->name); 371 } 372 } 373 276 374 static void isa_fun_set_io_range(isa_fun_t *fun, size_t addr, size_t len) 277 375 { … … 303 401 if (val != end) 304 402 isa_fun_set_irq(fun, irq); 403 } 404 405 static void fun_parse_dma(isa_fun_t *fun, char *val) 406 { 407 unsigned int dma = 0; 408 char *end = NULL; 409 410 val = skip_spaces(val); 411 dma = (unsigned int) strtol(val, &end, 10); 412 413 if (val != end) 414 isa_fun_set_dma(fun, dma); 305 415 } 306 416 … … 396 506 if (!prop_parse(fun, line, "io_range", &fun_parse_io_range) && 397 507 !prop_parse(fun, line, "irq", &fun_parse_irq) && 508 !prop_parse(fun, line, "dma", &fun_parse_dma) && 398 509 !prop_parse(fun, line, "match", &fun_parse_match_id)) { 399 510 … … 406 517 { 407 518 fun->hw_resources.resources = 408 (hw_resource_t *) malloc(sizeof(hw_resource_t) * ISA_MAX_HW_RES);519 (hw_resource_t *) malloc(sizeof(hw_resource_t) * ISA_MAX_HW_RES); 409 520 } 410 521 … … 590 701 591 702 592 static void isa_init() 703 static void isa_init() 593 704 { 594 705 ddf_log_init(NAME, LVL_ERROR); -
uspace/drv/bus/isa/isa.dev
ra438de4 rd9cf684a 18 18 irq 5 19 19 io_range 300 20 20 21 sb16: 22 match 100 isa/sb16 23 io_range 220 20 24 io_range 330 2 25 irq 5 26 dma 1 27 dma 5 -
uspace/drv/bus/pci/pciintel/pci.c
ra438de4 rd9cf684a 187 187 188 188 static hw_res_ops_t pciintel_hw_res_ops = { 189 &pciintel_get_resources,190 &pciintel_enable_interrupt189 .get_resource_list = &pciintel_get_resources, 190 .enable_interrupt = &pciintel_enable_interrupt, 191 191 }; 192 192 -
uspace/drv/infrastructure/rootpc/rootpc.c
ra438de4 rd9cf684a 109 109 110 110 static hw_res_ops_t fun_hw_res_ops = { 111 &rootpc_get_resources,112 &rootpc_enable_interrupt111 .get_resource_list = &rootpc_get_resources, 112 .enable_interrupt = &rootpc_enable_interrupt, 113 113 }; 114 114 -
uspace/lib/c/include/device/hw_res.h
ra438de4 rd9cf684a 40 40 #include <bool.h> 41 41 42 #define DMA_MODE_ON_DEMAND 0 43 #define DMA_MODE_WRITE (1 << 2) 44 #define DMA_MODE_READ (1 << 3) 45 #define DMA_MODE_AUTO (1 << 4) 46 #define DMA_MODE_DOWN (1 << 5) 47 #define DMA_MODE_SINGLE (1 << 6) 48 #define DMA_MODE_BLOCK (1 << 7) 49 42 50 /** HW resource provider interface */ 43 51 typedef enum { 44 52 HW_RES_GET_RESOURCE_LIST = 0, 45 HW_RES_ENABLE_INTERRUPT 53 HW_RES_ENABLE_INTERRUPT, 54 HW_RES_DMA_CHANNEL_SETUP, 46 55 } hw_res_method_t; 47 56 … … 50 59 INTERRUPT, 51 60 IO_RANGE, 52 MEM_RANGE 61 MEM_RANGE, 62 DMA_CHANNEL_8, 63 DMA_CHANNEL_16, 53 64 } hw_res_type_t; 54 65 … … 77 88 int irq; 78 89 } interrupt; 90 91 union { 92 unsigned int dma8; 93 unsigned int dma16; 94 } dma_channel; 79 95 } res; 80 96 } hw_resource_t; … … 98 114 extern bool hw_res_enable_interrupt(async_sess_t *); 99 115 116 extern int hw_res_dma_channel_setup(async_sess_t *, unsigned int, uint32_t, 117 uint16_t, uint8_t); 118 100 119 #endif 101 120 -
uspace/lib/c/include/device/hw_res_parsed.h
ra438de4 rd9cf684a 72 72 } irq_list_t; 73 73 74 /** List of ISA DMA channels */ 75 typedef struct dma_list { 76 /** Channel count */ 77 size_t count; 78 79 /** Array of channels */ 80 unsigned int *channels; 81 } dma_list_t; 82 74 83 /** List of memory areas */ 75 84 typedef struct addr_range_list { … … 91 100 /** List of IRQs */ 92 101 irq_list_t irqs; 102 103 /** List of DMA channels */ 104 dma_list_t dma_channels; 93 105 94 106 /** List of memory areas */ … … 113 125 free(list->io_ranges.ranges); 114 126 free(list->mem_ranges.ranges); 127 free(list->dma_channels.channels); 115 128 116 129 bzero(list, sizeof(hw_res_list_parsed_t)); -
uspace/lib/drv/include/ops/hw_res.h
ra438de4 rd9cf684a 1 1 /* 2 * Copyright (c) 2010 Lenka Trochtova 2 * Copyright (c) 2010 Lenka Trochtova 3 * Copyright (c) 2011 Jan Vesely 3 4 * All rights reserved. 4 5 * … … 42 43 43 44 typedef struct { 44 hw_resource_list_t *(*get_resource_list)(ddf_fun_t *); 45 bool (*enable_interrupt)(ddf_fun_t *); 45 hw_resource_list_t *(*get_resource_list)(ddf_fun_t *); 46 bool (*enable_interrupt)(ddf_fun_t *); 47 int (*dma_channel_setup)(ddf_fun_t *, unsigned, uint32_t, uint16_t, uint8_t); 46 48 } hw_res_ops_t; 47 49
Note:
See TracChangeset
for help on using the changeset viewer.