Changes in / [1bebadee:730dce77] in mainline
- Files:
-
- 58 deleted
- 25 edited
Legend:
- Unmodified
- Added
- Removed
-
HelenOS.config
r1bebadee r730dce77 562 562 ! CONFIG_OPTIMIZE_FOR_SIZE (n/y) 563 563 564 % Number of consoles565 @ "1"566 @ "2"567 @ "3"568 @ "4"569 @ "5"570 @ "6"571 ! CONFIG_VC_COUNT(choice)572 573 %Kernel log on console 6574 ! CONFIG_KERNEL_LOG_VC_6 (y/n)575 576 564 % Barebone build with essential binaries only 577 565 ! CONFIG_BAREBONE (n/y) -
boot/Makefile.common
r1bebadee r730dce77 115 115 $(USPACE_PATH)/srv/devman/devman 116 116 117 RD_DRVS_ESSENTIAL = \ 118 infrastructure/root 119 120 RD_DRVS_NON_ESSENTIAL = \ 117 RD_DRVS = \ 118 infrastructure/root \ 121 119 infrastructure/rootvirt \ 122 120 test/test1 \ … … 159 157 $(USPACE_PATH)/app/dltest2/dltest2 \ 160 158 $(USPACE_PATH)/app/dload/dload \ 161 $(USPACE_PATH)/app/dplay/dplay \162 159 $(USPACE_PATH)/app/edit/edit \ 163 160 $(USPACE_PATH)/app/ext2info/ext2info \ … … 166 163 $(USPACE_PATH)/app/killall/killall \ 167 164 $(USPACE_PATH)/app/loc/loc \ 168 $(USPACE_PATH)/app/mixerctl/mixerctl \169 165 $(USPACE_PATH)/app/mkfat/mkfat \ 170 166 $(USPACE_PATH)/app/mkexfat/mkexfat \ … … 226 222 RD_SRVS = $(RD_SRVS_ESSENTIAL) 227 223 RD_APPS = $(RD_APPS_ESSENTIAL) 228 RD_DRVS = $(RD_DRVS_ESSENTIAL)229 224 else 230 225 RD_SRVS = $(RD_SRVS_ESSENTIAL) $(RD_SRVS_NON_ESSENTIAL) 231 226 RD_APPS = $(RD_APPS_ESSENTIAL) $(RD_APPS_NON_ESSENTIAL) 232 RD_DRVS = $(RD_DRVS_ESSENTIAL) $(RD_DRVS_NON_ESSENTAIL)233 227 endif 234 228 -
boot/arch/amd64/Makefile.inc
r1bebadee r730dce77 28 28 29 29 RD_SRVS_ESSENTIAL += \ 30 $(USPACE_PATH)/srv/audio/hound/hound \31 $(USPACE_PATH)/srv/devman/devman \32 30 $(USPACE_PATH)/srv/hw/irc/apic/apic \ 33 31 $(USPACE_PATH)/srv/hw/irc/i8259/i8259 … … 36 34 $(USPACE_PATH)/srv/bd/ata_bd/ata_bd 37 35 38 RD_DRVS _ESSENTIAL+= \36 RD_DRVS += \ 39 37 infrastructure/rootpc \ 40 38 bus/pci/pciintel \ 41 39 bus/isa \ 42 audio/sb16 \43 40 char/i8042 \ 41 char/ns8250 \ 44 42 char/ps2mouse \ 45 char/xtkbd 46 47 RD_DRVS_NON_ESSENTIAL += \ 48 char/ns8250 \ 43 char/xtkbd \ 49 44 bus/usb/ehci\ 50 45 bus/usb/ohci \ … … 61 56 bus/isa 62 57 63 RD_APPS_ESSENTIAL += \64 $(USPACE_PATH)/app/edit/edit \65 $(USPACE_PATH)/app/mixerctl/mixerctl \66 $(USPACE_PATH)/app/wavplay/wavplay \67 68 58 BOOT_OUTPUT = $(ROOT_PATH)/image.iso 69 59 PREBUILD = $(INITRD).img -
boot/arch/ppc32/Makefile.inc
r1bebadee r730dce77 42 42 $(USPACE_PATH)/srv/hw/bus/cuda_adb/cuda_adb 43 43 44 RD_DRVS _NON_ESSENTIAL+= \44 RD_DRVS += \ 45 45 infrastructure/rootmac 46 46 -
defaults/amd64/Makefile.config
r1bebadee r730dce77 25 25 # Kernel console support 26 26 CONFIG_KCONSOLE = y 27 28 # Number of shell consoles29 CONFIG_VC_COUNT = 530 27 31 28 # Kernel symbol information -
defaults/arm32/Makefile.config
r1bebadee r730dce77 16 16 # Kernel console support 17 17 CONFIG_KCONSOLE = y 18 19 # Number of shell consoles20 CONFIG_VC_COUNT = 521 18 22 19 # Kernel symbol information -
defaults/ia32/Makefile.config
r1bebadee r730dce77 31 31 # Kernel console support 32 32 CONFIG_KCONSOLE = y 33 34 # Number of shell consoles35 CONFIG_VC_COUNT = 536 33 37 34 # Kernel symbol information -
defaults/ia64/Makefile.config
r1bebadee r730dce77 29 29 CONFIG_KCONSOLE = y 30 30 31 # Number of shell consoles32 CONFIG_VC_COUNT = 533 34 31 # Kernel symbol information 35 32 CONFIG_SYMTAB = y -
defaults/mips32/Makefile.config
r1bebadee r730dce77 22 22 # Kernel console support 23 23 CONFIG_KCONSOLE = y 24 25 # Number of shell consoles26 CONFIG_VC_COUNT = 527 24 28 25 # Kernel symbol information -
defaults/mips64/Makefile.config
r1bebadee r730dce77 22 22 # Kernel console support 23 23 CONFIG_KCONSOLE = y 24 25 # Number of shell consoles26 CONFIG_VC_COUNT = 527 24 28 25 # Kernel symbol information -
defaults/ppc32/Makefile.config
r1bebadee r730dce77 16 16 # Kernel console support 17 17 CONFIG_KCONSOLE = y 18 19 # Number of shell consoles20 CONFIG_VC_COUNT = 521 18 22 19 # Kernel symbol information -
defaults/sparc64/Makefile.config
r1bebadee r730dce77 32 32 CONFIG_KCONSOLE = y 33 33 34 # Number of shell consoles35 CONFIG_VC_COUNT = 536 37 34 # Kernel symbol information 38 35 CONFIG_SYMTAB = y -
defaults/special/Makefile.config
r1bebadee r730dce77 17 17 CONFIG_KCONSOLE = y 18 18 19 # Number of shell consoles20 CONFIG_VC_COUNT = 521 22 19 # Kernel symbol information 23 20 CONFIG_SYMTAB = y -
uspace/Makefile
r1bebadee r730dce77 38 38 app/bnchmark \ 39 39 app/devctl \ 40 app/drec \41 40 app/edit \ 42 41 app/ext2info \ … … 49 48 app/loc \ 50 49 app/lsusb \ 51 app/mixerctl \52 50 app/mkfat \ 53 51 app/mkexfat \ … … 73 71 app/sysinfo \ 74 72 app/mkbd \ 75 app/wavplay \76 73 app/websrv \ 77 srv/audio/hound \78 74 srv/clipboard \ 79 75 srv/locsrv \ … … 108 104 srv/hid/remcons \ 109 105 srv/hw/char/s3c24xx_uart \ 110 drv/audio/sb16 \111 106 drv/infrastructure/root \ 112 107 drv/infrastructure/rootvirt \ … … 198 193 lib/drv \ 199 194 lib/fb \ 200 lib/hound \201 195 lib/net \ 202 196 lib/nic \ … … 207 201 lib/usbhid \ 208 202 lib/usbvirt \ 209 lib/pcm \210 203 lib/posix 211 204 -
uspace/Makefile.common
r1bebadee r730dce77 123 123 124 124 LIBDRV_PREFIX = $(LIB_PREFIX)/drv 125 LIBHOUND_PREFIX = $(LIB_PREFIX)/hound126 LIBPCM_PREFIX = $(LIB_PREFIX)/pcm127 125 LIBNET_PREFIX = $(LIB_PREFIX)/net 128 126 LIBNIC_PREFIX = $(LIB_PREFIX)/nic … … 252 250 253 251 ifneq ($(BINARY),) 254 %.disasm: $(BINARY) _prestrip252 %.disasm: $(BINARY) 255 253 ifeq ($(CONFIG_LINE_DEBUG),y) 256 254 $(OBJDUMP) -d -S $< > $@ … … 259 257 endif 260 258 261 .INTERMEDIATE: $(BINARY)_prestrip 262 263 $(BINARY)_prestrip: $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS) 264 $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $@ $(OBJECTS) $(LIBS) $(BASE_LIBS) 265 266 $(BINARY): $(BINARY)_prestrip $(BINARY).disasm 267 cp $(BINARY)_prestrip $@ 259 $(BINARY): $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS) 260 $(LD) -n $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS) 268 261 ifeq ($(CONFIG_STRIP_BINARIES),y) 269 262 $(STRIP) $(BINARY) -
uspace/app/init/init.c
r1bebadee r730dce77 339 339 #endif 340 340 341 spawn("/srv/hound"); 342 switch((unsigned)CONFIG_VC_COUNT) { 343 default: 344 case 6: getterm("term/vc5", "/app/bdsh", false); 345 case 5: getterm("term/vc4", "/app/bdsh", false); 346 case 4: getterm("term/vc3", "/app/bdsh", false); 347 case 3: getterm("term/vc2", "/app/bdsh", false); 348 case 2: getterm("term/vc1", "/app/bdsh", false); 349 case 1: getterm("term/vc0", "/app/bdsh", true); 350 } 351 #ifdef CONFIG_KERNEL_LOG_VC_6 341 getterm("term/vc0", "/app/bdsh", true); 342 getterm("term/vc1", "/app/bdsh", false); 343 getterm("term/vc2", "/app/bdsh", false); 344 getterm("term/vc3", "/app/bdsh", false); 345 getterm("term/vc4", "/app/bdsh", false); 346 getterm("term/vc5", "/app/bdsh", false); 352 347 getterm("term/vc6", "/app/klog", false); 353 #endif354 348 355 349 return 0; -
uspace/drv/bus/isa/isa.c
r1bebadee r730dce77 91 91 fibril_mutex_t mutex; 92 92 ddf_fun_t *fnode; 93 hw_resource_t resources[ISA_MAX_HW_RES];94 93 hw_resource_list_t hw_resources; 95 94 link_t bus_link; … … 208 207 209 208 fibril_mutex_initialize(&fun->mutex); 210 fun->hw_resources.resources = fun->resources;211 212 209 fun->fnode = fnode; 213 210 return fun; … … 521 518 } 522 519 520 static void fun_hw_res_alloc(isa_fun_t *fun) 521 { 522 fun->hw_resources.resources = 523 (hw_resource_t *) malloc(sizeof(hw_resource_t) * ISA_MAX_HW_RES); 524 } 525 526 static void fun_hw_res_free(isa_fun_t *fun) 527 { 528 free(fun->hw_resources.resources); 529 fun->hw_resources.resources = NULL; 530 } 531 523 532 static char *isa_fun_read_info(char *fun_conf, isa_bus_t *isa) 524 533 { … … 549 558 return NULL; 550 559 } 560 561 /* Allocate buffer for the list of hardware resources of the device. */ 562 fun_hw_res_alloc(fun); 551 563 552 564 /* Get properties of the device (match ids, irq and io range). */ … … 665 677 list_remove(&fun->bus_link); 666 678 679 fun_hw_res_free(fun); 667 680 ddf_fun_destroy(fun->fnode); 668 681 } -
uspace/lib/c/generic/device/hw_res.c
r1bebadee r730dce77 42 42 { 43 43 sysarg_t count = 0; 44 44 45 45 async_exch_t *exch = async_exchange_begin(sess); 46 if (exch == NULL)47 return ENOMEM;48 46 int rc = async_req_1_1(exch, DEV_IFACE_ID(HW_RES_DEV_IFACE), 49 47 HW_RES_GET_RESOURCE_LIST, &count); 50 48 51 49 if (rc != EOK) { 52 50 async_exchange_end(exch); 53 51 return rc; 54 52 } 55 53 56 54 size_t size = count * sizeof(hw_resource_t); 57 55 hw_resource_t *resources = (hw_resource_t *) malloc(size); … … 61 59 return ENOMEM; 62 60 } 63 61 64 62 rc = async_data_read_start(exch, resources, size); 65 63 async_exchange_end(exch); 66 64 67 65 if (rc != EOK) { 68 66 free(resources); 69 67 return rc; 70 68 } 71 69 72 70 hw_resources->resources = resources; 73 71 hw_resources->count = count; 74 72 75 73 return EOK; 76 74 } … … 79 77 { 80 78 async_exch_t *exch = async_exchange_begin(sess); 81 if (exch == NULL)82 return false;83 79 int rc = async_req_1_0(exch, DEV_IFACE_ID(HW_RES_DEV_IFACE), 84 80 HW_RES_ENABLE_INTERRUPT); 85 81 async_exchange_end(exch); 86 82 87 83 return (rc == EOK); 88 }89 90 /**91 * Setup DMA channel to specified place and mode.92 * @param channel DMA Channel 1,2,3 for 8 bit transfers, 5,6,7 for 16 bit.93 * @param pa Physical address of the buffer. Must be < 16MB for 16 bit and < 1MB94 * for 8 bit transfers.95 * @param size DMA buffer size, limited to 64K.96 * @param mode Mode of the DMA channel:97 * - Read or Write98 * - Allow automatic reset99 * - Use address decrement instead of increment100 * - Use SINGLE/BLOCK/ON DEMAND transfer mode101 * @return Error code.102 */103 int hw_res_dma_channel_setup(async_sess_t *sess,104 unsigned channel, uint32_t pa, uint16_t size, uint8_t mode)105 {106 async_exch_t *exch = async_exchange_begin(sess);107 if (exch == NULL)108 return ENOMEM;109 const uint32_t packed = size | (mode << 16);110 const int ret = async_req_4_0(exch, DEV_IFACE_ID(HW_RES_DEV_IFACE),111 HW_RES_DMA_CHANNEL_SETUP, channel, pa, packed);112 async_exchange_end(exch);113 114 return ret;115 84 } 116 85 -
uspace/lib/c/generic/device/hw_res_parsed.c
r1bebadee r730dce77 38 38 #include <errno.h> 39 39 40 static void hw_res_parse_add_dma_channel(hw_res_list_parsed_t *out, 41 const hw_resource_t *res, int flags) 42 { 43 assert(res); 44 assert((res->type == DMA_CHANNEL_8) || (res->type == DMA_CHANNEL_16)); 45 46 const unsigned channel = (res->type == DMA_CHANNEL_8) ? 47 res->res.dma_channel.dma8 : res->res.dma_channel.dma16; 48 const size_t count = out->dma_channels.count; 49 const int keep_duplicit = flags & HW_RES_KEEP_DUPLICIT; 50 51 if (!keep_duplicit) { 52 for (size_t i = 0; i < count; ++i) { 53 if (out->dma_channels.channels[i] == channel) 54 return; 55 } 56 } 57 58 out->dma_channels.channels[count] = channel; 59 ++out->dma_channels.count; 60 } 61 62 static void hw_res_parse_add_irq(hw_res_list_parsed_t *out, 63 const hw_resource_t *res, int flags) 40 static void hw_res_parse_add_irq(hw_res_list_parsed_t *out, hw_resource_t *res, 41 int flags) 64 42 { 65 43 assert(res && (res->type == INTERRUPT)); … … 81 59 82 60 static void hw_res_parse_add_io_range(hw_res_list_parsed_t *out, 83 consthw_resource_t *res, int flags)61 hw_resource_t *res, int flags) 84 62 { 85 63 assert(res && (res->type == IO_RANGE)); … … 112 90 113 91 static void hw_res_parse_add_mem_range(hw_res_list_parsed_t *out, 114 consthw_resource_t *res, int flags)92 hw_resource_t *res, int flags) 115 93 { 116 94 assert(res && (res->type == MEM_RANGE)); … … 154 132 * 155 133 */ 156 int hw_res_list_parse( consthw_resource_list_t *hw_resources,134 int hw_res_list_parse(hw_resource_list_t *hw_resources, 157 135 hw_res_list_parsed_t *out, int flags) 158 136 { … … 163 141 hw_res_list_parsed_clean(out); 164 142 165 out->irqs.irqs = calloc(res_count, sizeof(int)); 166 out->dma_channels.channels = calloc(res_count, sizeof(int)); 167 out->io_ranges.ranges = calloc(res_count, sizeof(io_range_t)); 168 out->mem_ranges.ranges = calloc(res_count, sizeof(mem_range_t)); 169 if (!out->irqs.irqs || !out->dma_channels.channels || 170 !out->io_ranges.ranges || !out->mem_ranges.ranges) { 171 hw_res_list_parsed_clean(out); 172 return ENOMEM; 173 } 143 out->irqs.irqs = malloc(res_count * sizeof(int)); 144 out->io_ranges.ranges = malloc(res_count * sizeof(io_range_t)); 145 out->mem_ranges.ranges = malloc(res_count * sizeof(mem_range_t)); 174 146 175 147 for (size_t i = 0; i < res_count; ++i) { 176 consthw_resource_t *resource = &(hw_resources->resources[i]);177 148 hw_resource_t *resource = &(hw_resources->resources[i]); 149 178 150 switch (resource->type) { 179 151 case INTERRUPT: … … 186 158 hw_res_parse_add_mem_range(out, resource, flags); 187 159 break; 188 case DMA_CHANNEL_8:189 case DMA_CHANNEL_16:190 hw_res_parse_add_dma_channel(out, resource, flags);191 break;192 160 default: 193 hw_res_list_parsed_clean(out);194 161 return EINVAL; 195 162 } 196 163 } 197 164 198 165 return EOK; 199 166 }; -
uspace/lib/c/include/device/hw_res_parsed.h
r1bebadee r730dce77 139 139 } 140 140 141 extern int hw_res_list_parse( 142 const hw_resource_list_t *, hw_res_list_parsed_t *, int); 141 extern int hw_res_list_parse(hw_resource_list_t *, hw_res_list_parsed_t *, int); 143 142 extern int hw_res_get_list_parsed(async_sess_t *, hw_res_list_parsed_t *, int); 144 143 -
uspace/lib/c/include/ipc/dev_iface.h
r1bebadee r730dce77 36 36 typedef enum { 37 37 HW_RES_DEV_IFACE = 0, 38 39 /** Audio device mixer interface */40 AUDIO_MIXER_IFACE,41 /** Audio device pcm buffer interface */42 AUDIO_PCM_BUFFER_IFACE,43 44 38 /** Character device interface */ 45 39 CHAR_DEV_IFACE, -
uspace/lib/drv/Makefile
r1bebadee r730dce77 29 29 30 30 USPACE_PREFIX = ../.. 31 EXTRA_CFLAGS = -Iinclude -I$(LIBUSB_PREFIX)/include -I$(LIBPCM_PREFIX)/include31 EXTRA_CFLAGS = -Iinclude -I$(LIBUSB_PREFIX)/include 32 32 LIBRARY = libdrv 33 33 … … 38 38 generic/log.c \ 39 39 generic/logbuf.c \ 40 generic/remote_audio_mixer.c \41 generic/remote_audio_pcm.c \42 40 generic/remote_hw_res.c \ 43 41 generic/remote_char_dev.c \ -
uspace/lib/drv/generic/dev_iface.c
r1bebadee r730dce77 46 46 #include "remote_usbhid.h" 47 47 #include "remote_pci.h" 48 #include "remote_audio_mixer.h"49 #include "remote_audio_pcm.h"50 48 #include "remote_ahci.h" 51 49 52 static constiface_dipatch_table_t remote_ifaces = {50 static iface_dipatch_table_t remote_ifaces = { 53 51 .ifaces = { 54 [AUDIO_MIXER_IFACE] = &remote_audio_mixer_iface, 55 [AUDIO_PCM_BUFFER_IFACE] = &remote_audio_pcm_iface, 56 [HW_RES_DEV_IFACE] = &remote_hw_res_iface, 57 [CHAR_DEV_IFACE] = &remote_char_dev_iface, 58 [NIC_DEV_IFACE] = &remote_nic_iface, 59 [PCI_DEV_IFACE] = &remote_pci_iface, 60 [USB_DEV_IFACE] = &remote_usb_iface, 61 [USBHC_DEV_IFACE] = &remote_usbhc_iface, 62 [USBHID_DEV_IFACE] = &remote_usbhid_iface, 63 [AHCI_DEV_IFACE] = &remote_ahci_iface, 52 &remote_hw_res_iface, 53 &remote_char_dev_iface, 54 &remote_nic_iface, 55 &remote_pci_iface, 56 &remote_usb_iface, 57 &remote_usbhc_iface, 58 &remote_usbhid_iface, 59 &remote_ahci_iface 64 60 } 65 61 }; -
uspace/lib/drv/generic/remote_hw_res.c
r1bebadee r730dce77 1 1 /* 2 2 * Copyright (c) 2010 Lenka Trochtova 3 * Copyright (c) 2011 Jan Vesely4 3 * All rights reserved. 5 4 * … … 44 43 static void remote_hw_res_enable_interrupt(ddf_fun_t *, void *, ipc_callid_t, 45 44 ipc_call_t *); 46 static void remote_hw_res_dma_channel_setup(ddf_fun_t *, void *, ipc_callid_t,47 ipc_call_t *);48 45 49 46 static remote_iface_func_ptr_t remote_hw_res_iface_ops [] = { 50 [HW_RES_GET_RESOURCE_LIST] = &remote_hw_res_get_resource_list, 51 [HW_RES_ENABLE_INTERRUPT] = &remote_hw_res_enable_interrupt, 52 [HW_RES_DMA_CHANNEL_SETUP] = &remote_hw_res_dma_channel_setup, 47 &remote_hw_res_get_resource_list, 48 &remote_hw_res_enable_interrupt 53 49 }; 54 50 … … 98 94 } 99 95 100 static void remote_hw_res_dma_channel_setup(ddf_fun_t *fun, void *ops,101 ipc_callid_t callid, ipc_call_t *call)102 {103 hw_res_ops_t *hw_res_ops = ops;104 105 if (hw_res_ops->dma_channel_setup == NULL) {106 async_answer_0(callid, ENOTSUP);107 return;108 }109 const unsigned channel = DEV_IPC_GET_ARG1(*call);110 const uint32_t address = DEV_IPC_GET_ARG2(*call);111 const uint16_t size = DEV_IPC_GET_ARG3(*call) & 0xffff;112 const uint8_t mode = DEV_IPC_GET_ARG3(*call) >> 16;113 114 const int ret = hw_res_ops->dma_channel_setup(115 fun, channel, address, size, mode);116 async_answer_0(callid, ret);117 }118 119 96 /** 120 97 * @} -
uspace/srv/locsrv/locsrv.c
r1bebadee r730dce77 1368 1368 categ_dir_add_cat(&cdir, cat); 1369 1369 1370 cat = category_new("audio-pcm");1371 categ_dir_add_cat(&cdir, cat);1372 1373 1370 return true; 1374 1371 }
Note:
See TracChangeset
for help on using the changeset viewer.