Changeset 3550c393 in mainline


Ignore:
Timestamp:
2005-12-11T21:36:42Z (19 years ago)
Author:
Ondrej Palkovsky <ondrap@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
ba276f7
Parents:
0c8e692
Message:

Symtab returns correct addresses even when symtab is befor bss.
Some tab completion optimization.

Files:
6 edited

Legend:

Unmodified
Added
Removed
  • Makefile

    r0c8e692 r3550c393  
    189189        $(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump
    190190        tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin
     191        # Do it once again, this time to get correct even the symbols
     192        # on architectures, that have bss after symtab
     193        $(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab generic/src/debug/real_map.bin generic/src/debug/sizeok_map.o
     194        $(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) generic/src/debug/sizeok_map.o -o $@ -Map kernel.map.pre
     195        $(OBJDUMP) -t $(ARCH_OBJECTS) $(GENARCH_OBJECTS) $(GENERIC_OBJECTS) > kernel.objdump
     196        tools/genmap.py kernel.map.pre kernel.objdump generic/src/debug/real_map.bin
     197       
    191198
    192199generic/src/debug/real_map.o: generic/src/debug/real_map.bin
  • arch/amd64/_link.ld.in

    r0c8e692 r3550c393  
    4949
    5050                *(.eh_frame);
    51                 *(.bss);                /* uninitialized static variables */
    5251
    5352                symbol_table = .;
    5453                *(symtab.*);            /* Symbol table, must be LAST symbol!*/
     54
     55                *(.bss);                /* uninitialized static variables */
    5556
    5657                kdata_end = .;
  • arch/ia32/_link.ld.in

    r0c8e692 r3550c393  
    4747                hardcoded_unmapped_kdata_size = .;
    4848                LONG(unmapped_kdata_end - unmapped_kdata_start);
    49                 *(.bss);                        /* uninitialized static variables */
    5049                symbol_table = .;
    5150                *(symtab.*);                    /* Symbol table, must be LAST symbol! */
    52 
     51                *(.bss);                        /* uninitialized static variables */
    5352                kdata_end = .;
    5453        }
  • generic/src/console/cmd.c

    r0c8e692 r3550c393  
    359359                printf("Calling f(): 0x%p: %s\n", symaddr, symbol);
    360360                f =  (__native (*)(void)) symaddr;
    361                 printf("Result: 0x%X\n", f());
     361                printf("Result: 0x%p\n", f());
    362362        }
    363363       
     
    383383                printf("Calling f(0x%x): 0x%p: %s\n", arg1, symaddr, symbol);
    384384                f =  (__native (*)(__native)) symaddr;
    385                 printf("Result: 0x%x\n", f(arg1));
     385                printf("Result: 0x%p\n", f(arg1));
    386386        }
    387387       
     
    409409                       arg1, arg2, symaddr, symbol);
    410410                f =  (__native (*)(__native,__native)) symaddr;
    411                 printf("Result: 0x%x\n", f(arg1, arg2));
     411                printf("Result: 0x%p\n", f(arg1, arg2));
    412412        }
    413413       
     
    436436                       arg1, arg2, arg3, symaddr, symbol);
    437437                f =  (__native (*)(__native,__native,__native)) symaddr;
    438                 printf("Result: 0x%x\n", f(arg1, arg2, arg3));
     438                printf("Result: 0x%p\n", f(arg1, arg2, arg3));
    439439        }
    440440       
  • generic/src/console/kconsole.c

    r0c8e692 r3550c393  
    216216                return 0;
    217217
    218         if (found > 1) {
     218        if (found > 1 && !strlen(output)) {
    219219                printf("\n");
    220220                startpos = NULL;
     
    287287                        for (i=0;tmp[i] && curlen < MAX_CMDLINE;i++,curlen++)
    288288                                insert_char(current, tmp[i], i+position);
    289                         if (found == 1) { /* One match */
    290                                 for (i=position;i<curlen;i++)
     289
     290                        if (strlen(tmp) || found==1) { /* If we have a hint */
     291                                for (i=position;i<curlen;i++)
    291292                                        putchar(current[i]);
    292293                                position += strlen(tmp);
    293294                                /* Add space to end */
    294                                 if (position == curlen && curlen < MAX_CMDLINE) {
     295                                if (found == 1 && position == curlen && \
     296                                    curlen < MAX_CMDLINE) {
    295297                                        current[position] = ' ';
    296298                                        curlen++;
     
    298300                                        putchar(' ');
    299301                                }
    300                         } else {
     302                        } else { /* No hint, table was printed */
    301303                                printf("%s> ", prompt);
    302304                                for (i=0; i<curlen;i++)
  • generic/src/debug/symtab.c

    r0c8e692 r3550c393  
    173173                return 0;
    174174
    175         if (found > 1) {
     175        if (found > 1 && !strlen(output)) {
    176176                printf("\n");
    177177                startpos = 0;
Note: See TracChangeset for help on using the changeset viewer.