Changeset 160


Ignore:
Timestamp:
Jun 12, 2012, 4:21:27 PM (13 years ago)
Author:
karaoui
Message:

giet-vm new version

Location:
soft/giet_vm
Files:
128 added
18 edited

Legend:

Unmodified
Added
Removed
  • soft/giet_vm/Makefile

    r158 r160  
    44DU=mipsel-unknown-elf-objdump
    55
    6 SYS_OBJS = reset.o \
    7            boot_handler.o \
    8            giet.o \
    9            switch.o \
    10            common.o \
    11            ctx_handler.o \
    12            drivers.o \
    13            exc_handler.o \
    14            irq_handler.o \
    15            sys_handler.o
     6SYS_OBJS = giet.o \
     7                switch.o \
     8                common.o \
     9                ctx_handler.o \
     10                drivers.o \
     11                exc_handler.o \
     12                irq_handler.o \
     13                sys_handler.o \
     14                init.o          \
     15                task_init.o
    1616
    17 PGCD_OBJS   = pgcd_stdio.o \
    18               pgcd_main.o
    19 
    20 HELLO_OBJS  = hello_stdio.o \
    21               hello_main.o
    22 
    23 FIFO_OBJS   = fifo_stdio.o \
    24               fifo_main.o \
    25               fifo_mwmr.o
    26 
    27 ROUTER_OBJS = router_stdio.o \
    28               router_main.o \
    29               router_mwmr.o
     17BOOT_OBJS = reset.o \
     18                boot_handler.o
    3019
    3120SYS_PATH    = sys
    32 HELLO_PATH  = hello
    33 FIFO_PATH   = fifo
    34 PGCD_PATH   = pgcd
    35 ROUTER_PATH = router
     21BOOT_PATH   = boot
    3622MAP_PATH    = xml
    3723LIBS_PATH   = libs
     24BUILD_DIR_NAME  = build
    3825
    39 CFLAGS=-Wall -ffreestanding -mno-gpopt -mips32
     26CFLAGS=-Wall -ffreestanding -mno-gpopt -mips32 -g
    4027
    4128SYS_INCLUDE = -I$(SYS_PATH) -I$(MAP_PATH) -I$(LIBS_PATH) -I.
    42 HELLO_INCLUDE= -I$(HELLO_PATH) -I$(LIBS_PATH)
    43 FIFO_INCLUDE= -I$(FIFO_PATH) -I$(LIBS_PATH)
    44 PGCD_INCLUDE= -I$(PGCD_PATH) -I$(LIBS_PATH)
    45 ROUTER_INCLUDE= -I$(ROUTER_PATH) -I$(LIBS_PATH)
    4629
    47 all: sys.bin hello.bin router.bin fifo.bin pgcd.bin map.bin
     30BOOT_INCLUDE = -I$(BOOT_PATH) -I$(MAP_PATH) -I$(LIBS_PATH) -I.
     31
     32#commons between sys and boot are: common.ld , mips_registers.h...
     33
     34TRASH= /dev/null||true
     35
     36.PHONY: apps prepare
     37
     38all: prepare soft.bin
     39       
     40
     41## merge all *.bin to soft.bin
     42soft.bin: boot.bin sys.bin map.bin apps
     43        make -C mover
     44        mover/mover.x -sm map.bin
     45        $(DU) -D $@ > $@.txt
     46
     47## prepare the environement
     48prepare:
     49        @mkdir $(BUILD_DIR_NAME) 2>$(TRASH)
    4850
    4951## mapping compilation
    50 
    5152map.bin: map.xml
     53        make -C xml                             #compile the parser
    5254        xml/xml2bin map.xml map.bin
    5355
    5456## system compilation
    55 
    5657sys.bin: $(SYS_OBJS) $(SYS_PATH)/sys.ld
    57         $(LD) -o $@ -T $(SYS_PATH)/sys.ld $(SYS_OBJS)
    58         $(DU) -D $@ > $@.txt
     58        (cd $(BUILD_DIR_NAME); $(LD) -o ../$@ -T ../$(SYS_PATH)/sys.ld $(SYS_OBJS) )
     59        (cd $(BUILD_DIR_NAME); $(DU) -D ../$@ > $@.txt)
    5960
    6061switch.o: $(SYS_PATH)/switch.s giet_config.h
    61         $(AS) -g -mips32 -o $@ $<
     62        $(AS) -g -mips32 -o $(BUILD_DIR_NAME)/$@ $<
    6263
    6364giet.o: $(SYS_PATH)/giet.s giet_config.h
    64         $(AS) -g -mips32 -o $@ $<
     65        $(AS) -g -mips32 -o $(BUILD_DIR_NAME)/$@ $<
    6566
    66 reset.o: $(SYS_PATH)/reset.S giet_config.h
    67         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
    68         $(DU) -D $@ > $@.txt
    69 
    70 boot_handler.o: $(SYS_PATH)/boot_handler.c $(SYS_PATH)/boot_handler.h giet_config.h
    71         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     67task_init.o: $(SYS_PATH)/task_init.S giet_config.h
     68        #$(AS) -g -mips32 -o $(BUILD_DIR_NAME)/$@ $<
     69        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
     70        $(DU) -D $(BUILD_DIR_NAME)/$@ > $(BUILD_DIR_NAME)/$@.txt
    7271
    7372ctx_handler.o: $(SYS_PATH)/ctx_handler.c $(SYS_PATH)/ctx_handler.h giet_config.h
    74         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     73        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    7574
    7675exc_handler.o: $(SYS_PATH)/exc_handler.c $(SYS_PATH)/exc_handler.h giet_config.h
    77         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     76        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    7877
    7978irq_handler.o: $(SYS_PATH)/irq_handler.c $(SYS_PATH)/irq_handler.h giet_config.h
    80         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     79        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    8180
    8281sys_handler.o: $(SYS_PATH)/sys_handler.c $(SYS_PATH)/sys_handler.h giet_config.h
    83         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     82        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    8483
    8584drivers.o: $(SYS_PATH)/drivers.c $(SYS_PATH)/drivers.h giet_config.h
    86         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     85        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    8786
    8887common.o: $(SYS_PATH)/common.c $(SYS_PATH)/common.h giet_config.h
    89         $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $@ $<
     88        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    9089
    91 ## application "hello" compilation
     90init.o: $(SYS_PATH)/init.c giet_config.h
     91        $(CC) $(CFLAGS) $(SYS_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    9292
    93 hello.bin: $(HELLO_OBJS) $(HELLO_PATH)/hello.ld
    94         $(LD) -o $@ -T $(HELLO_PATH)/hello.ld $(HELLO_OBJS)
    95         $(DU) -D $@ > $@.txt
     93## boot compilation
     94boot.bin: $(BOOT_OBJS) $(BOOT_PATH)/boot.ld
     95        (cd $(BUILD_DIR_NAME); $(LD) -o ../$@ -T ../$(BOOT_PATH)/boot.ld $(BOOT_OBJS) )
     96        (cd $(BUILD_DIR_NAME); $(DU) -D ../$@ > $@.txt)
    9697
    97 hello_stdio.o: $(LIBS_PATH)/stdio.c $(LIBS_PATH)/stdio.h giet_config.h
    98         $(CC) $(CFLAGS) $(HELLO_INCLUDE) -c -o $@ $<
     98reset.o: $(BOOT_PATH)/reset.S giet_config.h
     99        $(CC) $(CFLAGS) $(BOOT_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
     100        $(DU) -D $(BUILD_DIR_NAME)/$@ > $(BUILD_DIR_NAME)/$@.txt
    99101
    100 hello_main.o: $(HELLO_PATH)/main.c giet_config.h
    101         $(CC) $(CFLAGS) $(HELLO_INCLUDE) -c -o $@ $<
     102boot_handler.o: $(BOOT_PATH)/boot_handler.c $(BOOT_PATH)/boot_handler.h giet_config.h
     103        $(CC) $(CFLAGS) $(BOOT_INCLUDE) -c -o $(BUILD_DIR_NAME)/$@ $<
    102104
    103 ## application "fifo" compilation
    104 
    105 fifo.bin: $(FIFO_OBJS) $(FIFO_PATH)/fifo.ld
    106         $(LD) -o $@ -T $(FIFO_PATH)/fifo.ld $(FIFO_OBJS)
    107         $(DU) -D $@ > $@.txt
    108 
    109 fifo_stdio.o: $(LIBS_PATH)/stdio.c $(LIBS_PATH)/stdio.h giet_config.h
    110         $(CC) $(CFLAGS) $(FIFO_INCLUDE) -c -o $@ $<
    111 
    112 fifo_mwmr.o: $(LIBS_PATH)/mwmr.c $(LIBS_PATH)/mwmr.h giet_config.h
    113         $(CC) $(CFLAGS) $(FIFO_INCLUDE) -c -o $@ $<
    114 
    115 fifo_main.o: $(FIFO_PATH)/main.c giet_config.h
    116         $(CC) $(CFLAGS) $(FIFO_INCLUDE) -c -o $@ $<
    117 
    118 ## application "router" compilation
    119 
    120 router.bin: $(ROUTER_OBJS) $(ROUTER_PATH)/router.ld
    121         $(LD) -o $@ -T $(ROUTER_PATH)/router.ld $(ROUTER_OBJS)
    122         $(DU) -D $@ > $@.txt
    123 
    124 router_stdio.o: $(LIBS_PATH)/stdio.c $(LIBS_PATH)/stdio.h giet_config.h
    125         $(CC) $(CFLAGS) $(ROUTER_INCLUDE) -c -o $@ $<
    126 
    127 router_mwmr.o: $(LIBS_PATH)/mwmr.c $(LIBS_PATH)/mwmr.h giet_config.h
    128         $(CC) $(CFLAGS) $(ROUTER_INCLUDE) -c -o $@ $<
    129 
    130 router_main.o: $(ROUTER_PATH)/main.c giet_config.h
    131         $(CC) $(CFLAGS) $(ROUTER_INCLUDE) -c -o $@ $<
    132 
    133 ## application "pgcd" compilation
    134 
    135 pgcd.bin: $(PGCD_OBJS) $(PGCD_PATH)/pgcd.ld
    136         $(LD) -o $@ -T $(PGCD_PATH)/pgcd.ld $(PGCD_OBJS)
    137         $(DU) -D $@ > $@.txt
    138 
    139 pgcd_stdio.o: $(LIBS_PATH)/stdio.c $(LIBS_PATH)/stdio.h giet_config.h
    140         $(CC) $(CFLAGS) $(PGCD_INCLUDE) -c -o $@ $<
    141 
    142 pgcd_main.o: $(PGCD_PATH)/main.c giet_config.h
    143         $(CC) $(CFLAGS) $(PGCD_INCLUDE) -c -o $@ $<
     105## applications and libs compilation
     106apps:
     107        @echo "---------------------------------------------BUILDING APPS------------------------------------------------------"
     108        make -C apps
    144109
    145110### special rules
    146 
    147111clean:
    148         rm -f *.o *.bin *.txt core *~
     112        rm -f *.o *.bin *.txt core *~  2>$(TRASH)
     113        make clean -C xml/ 2>$(TRASH)
     114        make clean -C mover/ 2>$(TRASH)
     115        make clean -C apps 2>$(TRASH)
     116        rm -r $(BUILD_DIR_NAME) 2>$(TRASH)
  • soft/giet_vm/giet_config.h

    r158 r160  
    1515#define BOOT_DEBUG_PT           0       /* display the page tables after mapping */
    1616#define BOOT_DEBUG_CTX          0       /* display the task contexts after mapping */
     17#define INIT_DEBUG_CTX          1       /* display the task contexts after mapping */
    1718
    1819#define GIET_DEBUG_SWITCH       0       /* Trace context switchs */
     20
     21
     22#define CONFIG_SRL_VERBOSITY TRACE
    1923
    2024/* hardware parameters */
     
    2226#define NB_CLUSTERS             1       /* number of clusters */
    2327#define CLUSTER_SPAN            0       /* address increment between clusters */
    24 #define NB_PROCS                4       /* number of processors per cluster */
    25 #define NB_TIMERS               4       /* number of timers per cluster */
    26 #define NB_DMAS                 4       /* number of DMA channels per cluster */
    27 #define NB_TTYS                 7       /* total number of TTY terminals */
     28#define NB_PROCS                    4   /* number of processors per cluster */
     29#define NB_TIMERS                   4   /* number of timers per cluster */
     30#define NB_DMAS                     4   /* number of DMA channels per cluster */
     31#define NB_TTYS                     9   /* total number of TTY terminals */
    2832
    2933/* software parameters */
    3034
    31 #define GIET_NB_TASKS_MAX       4       /* max number of tasks per processor */
    32 #define GIET_NB_VSPACE_MAX      3       /* max number of virtual spaces */
     35#define GIET_NB_TASKS_MAX       6       /* max number of tasks per processor */
     36#define GIET_NB_VSPACE_MAX      4       /* max number of virtual spaces */
    3337#define GIET_NB_PT2_MAX         16      /* max number of level 2 page tables per vspace */
    3438#define GIET_TICK_VALUE         20000   /* context switch period (number of cycles) */
  • soft/giet_vm/libs/barrier.c

    r159 r160  
    55// Copyright (c) UPMC-LIP6
    66///////////////////////////////////////////////////////////////////////////////////
    7 // The barrier.c and barrier.h files are part of the GIET nano-kernel.
     7// These barrier.c and barrier.h files are part of the GIET nano-kernel.
    88// This user-level library provides a synchronisation service between several
    99// tasks sharing the same address space in a parallel multi-tasks application.
    10 //
    11 // The barrier_init(), and the barrier_wait() functions do not require a syscall.
    12 // The barrier itself must have been allocated in a non cacheable segment,
    13 // if the platform does not provide hardwate cache coherence.
    14 //
    15 // ALL barriers must be defined in the mapping_info data structure,
    16 // to be initialised by the GIET in the boot phase.
    17 // The vobj_get_vbase() system call (defined in stdio.c and stdio.h files)
    18 // can be used to get the virtual base address of the barrier from it's name.
     10// Neither the barrier_init(), nor the barrier_wait() function require a syscall.
     11// The barrier itself must have been allocated in a shared data segment.
    1912///////////////////////////////////////////////////////////////////////////////////
    20 
    21 #include <barrier.h>
    2213
    2314///////////////////////////////////////////////////////////////////////////////////
  • soft/giet_vm/libs/stdio.c

    r158 r160  
    3434#define SYSCALL_IOC_READ        0x16
    3535#define SYSCALL_IOC_COMPLETED   0x17
    36 #define SYSCALL_MWMR_BASE       0x1A
     36#define SYSCALL_VOBJ_GET_VBASE  0x1A
    3737
    3838//////////////////////////////////////////////////////////////////////////////////
     
    720720//////////////////////////////////////////////////////////////////////////////////
    721721//      mwmr_base()
     722//      TODO!
    722723// This function returns in argument buffer the virtual base address
    723724// of a MWMR communication channel, identified by the two arguments
     
    726727// must be declared in the mapping_info data structure to be initialised
    727728// in the boot phase.
    728 // - Returns 0 if success, > 0 if error ( channel not defined )
    729 //////////////////////////////////////////////////////////////////////////////////
    730 unsigned int mwmr_base( char*           vspace_name,
    731                         char*           mwmr_name,
    732                         void*           buffer )
    733 {
    734     return sys_call(SYSCALL_MWMR_BASE,
     729// - Returns the address if success,  0 if error ( channel not defined )
     730//////////////////////////////////////////////////////////////////////////////////
     731unsigned int vobj_get_vbase( char* vspace_name, char* vobj_name,
     732                        unsigned int vobj_type, unsigned int* vobj_buffer)
     733{
     734    return sys_call(SYSCALL_VOBJ_GET_VBASE,
    735735                    (unsigned int)vspace_name,
    736                     (unsigned int)mwmr_name,
    737                     (unsigned int)buffer,
    738                     0);
     736                    (unsigned int)vobj_name,
     737                    (unsigned int)vobj_type,
     738                    (unsigned int)vobj_buffer);
    739739}
    740740////////////////////////////////////////////////////////////////////////////////////
  • soft/giet_vm/libs/stdio.h

    r158 r160  
    88#ifndef _STDIO_H
    99#define _STDIO_H
     10
     11#include <mapping_info.h>
    1012
    1113/* MIPS32 related functions */
     
    5759unsigned int rand();
    5860unsigned int ctx_switch();
    59 unsigned int mwmr_base(char* vspace_name, char* mwmr_name, void* buffer);
     61unsigned int vobj_get_vbase( char* vspace_name, char* vobj_name,
     62                        unsigned int vobj_type, unsigned int* vobj_buffer);
    6063
    6164/*
  • soft/giet_vm/map.xml

    r158 r160  
    55                clusters = "1"
    66                psegs    = "9"
    7                 ttys     = "7"
    8                 vspaces  = "3"
    9                 globals  = "13"
    10                 syspath  = "soft/sys.bin" >
     7                ttys     = "9"
     8                vspaces  = "4"
     9                globals  = "13" >
    1110
    1211        <clusterset>
     
    5554
    5655        <globalset>
    57                 <vseg   name      = "seg_boot_code"
     56                <vseg   name      = "seg_boot_code_data"
    5857                        vbase     = "0xbfc00000"
    59                         length    = "0x00008000"
    6058                        mode      = "CX__"
    6159                        psegname  = "PSEG_ROM"
    62                         ident     = "1" />
     60                        ident     = "1" >
     61                                        <vobj   name    = "boot_code_data"
     62                                                        type    = "ELF"
     63                                                        length  = "0x00008000"
     64                                                        binpath = "boot.bin"
     65                                                        />
     66                                </vseg>
    6367
    6468                <vseg   name      = "seg_boot_stack"
    6569                        vbase     = "0xbfc08000"
    66                         length    = "0x00004000"
    6770                        mode      = "C_W_"
    6871                        psegname  = "PSEG_ROM"
    69                         ident     = "1" />
     72                        ident     = "1" >
     73                                        <vobj   name    = "boot_stack"
     74                                                        type    = "BUFFER"
     75                                                        length  = "0x00004000" />
     76                                </vseg>
    7077
    7178                <vseg   name      = "seg_boot_mapping"
    7279                        vbase     = "0xbfc0c000"
    73                         length    = "0x00004000"
    7480                        mode      = "C_W_"
    7581                        psegname  = "PSEG_ROM"
    76                         ident     = "1" />
     82                        ident     = "1" >
     83                                        <vobj   name    = "boot_mapping"
     84                                                        type    = "ELF"
     85                                                        length  = "0x00004000"
     86                                                        binpath = "map.bin"
     87                                                        />
     88                                </vseg>
    7789
    7890                <vseg   name      = "seg_kernel_code"
    7991                        vbase     = "0x80000000"
    80                         length    = "0x00010000"
    8192                        mode      = "CX__"
    8293                        psegname  = "PSEG_RAK"
    83                         ident     = "1" />
     94                        ident     = "1" >
     95                                        <vobj   name    = "kernel_code"
     96                                                        type    = "ELF"
     97                                                        length  = "0x00010000"
     98                                                        binpath = "sys.bin"
     99                                                        />
     100                                </vseg>
    84101
    85102                <vseg   name      = "seg_kernel_data"
    86103                        vbase     = "0x80010000"
    87                         length    = "0x00010000"
    88104                        mode      = "C_W_"
    89105                        psegname  = "PSEG_RAK"
    90                         ident     = "1" />
     106                        ident     = "1" >
     107                                        <vobj   name    = "kernel_data"
     108                                                        type    = "ELF"
     109                                                        length  = "0x00010000"
     110                                                        binpath = "sys.bin"
     111                                                        />
     112                                </vseg>
    91113
    92114                <vseg   name      = "seg_kernel_uncdata"
    93115                        vbase     = "0x80020000"
    94                         length    = "0x00010000"
    95116                        mode      = "__W_"
    96117                        psegname  = "PSEG_RAK"
    97                         ident     = "1" />
    98 
    99                 <vseg   name      = "seg_kernel_pt"
     118                        ident     = "1" >
     119                                        <vobj   name    = "kernel_uncdata"
     120                                                        type    = "ELF"
     121                                                        length  = "0x00010000"
     122                                                        binpath = "sys.bin"
     123                                                        />
     124                                </vseg>
     125
     126                <vseg   name      = "seg_kernel_init"
    100127                        vbase     = "0x80030000"
    101                         length    = "0x00040000"
    102                         mode      = "C_W_"
     128                        mode      = "CX__"
    103129                        psegname  = "PSEG_RAK"
    104                         ident     = "1" />
     130                        ident     = "1" >
     131                                        <vobj   name    = "kernel_init"
     132                                                        type    = "ELF"
     133                                                        length  = "0x00010000"
     134                                                        binpath = "sys.bin"
     135                                                        />
     136                                </vseg>
     137
    105138
    106139                <vseg   name      = "seg_tty"
    107140                        vbase     = "0x90000000"
    108                         length    = "0x00000200"
    109141                        mode      = "__W_"
    110142                        psegname  = "PSEG_TTY"
    111                         ident     = "1" />
     143                        ident     = "1" >
     144                                        <vobj   name    = "tty"
     145                                                        type    = "PERI"
     146                                                        length  = "0x00000100" />
     147                                </vseg>
    112148
    113149                <vseg   name      = "seg_timer"
    114150                        vbase     = "0x91000000"
    115                         length    = "0x00000080"
    116151                        mode      = "__W_"
    117152                        psegname  = "PSEG_TIM"
    118                         ident     = "1" />
     153                        ident     = "1" >
     154                                        <vobj   name    = "timer"
     155                                                        type    = "PERI"
     156                                                        length  = "0x00000080" />
     157                                </vseg>
    119158
    120159                <vseg   name      = "seg_ioc"
    121160                        vbase     = "0x92000000"
    122                         length    = "0x00000020"
    123161                        mode      = "__W_"
    124162                        psegname  = "PSEG_IOC"
    125                         ident     = "1" />
     163                        ident     = "1" >
     164                                        <vobj   name    = "ioc"
     165                                                        type    = "PERI"
     166                                                        length  = "0x00000020" />
     167                                </vseg>
    126168
    127169                <vseg   name      = "seg_dma"
    128170                        vbase     = "0x93000000"
    129                         length    = "0x00000100"
    130171                        mode      = "__W_"
    131172                        psegname  = "PSEG_DMA"
    132                         ident     = "1" />
     173                        ident     = "1" >
     174                                        <vobj   name    = "dma"
     175                                                        type    = "PERI"
     176                                                        length  = "0x00000100" />
     177                                </vseg>
    133178
    134179                <vseg   name      = "seg_fb"
    135180                        vbase     = "0x96000000"
    136                         length    = "0x00004000"
    137181                        mode      = "__W_"
    138182                        psegname  = "PSEG_FBF"
    139                         ident     = "1" />
     183                        ident     = "1" >
     184                                        <vobj   name    = "fb"
     185                                                        type    = "PERI"
     186                                                        length  = "0x00004000" />
     187                                </vseg>
    140188
    141189                <vseg   name      = "seg_icu"
    142190                        vbase     = "0x9F000000"
    143                         length    = "0x00000100"
    144191                        mode      = "__W_"
    145192                        psegname  = "PSEG_ICU"
    146                         ident     = "1" />
     193                        ident     = "1" >
     194                                        <vobj   name    = "icu"
     195                                                        type    = "PERI"
     196                                                        length  = "0x00000100" />
     197                                </vseg>
    147198          </globalset>
    148199
    149200          <vspaceset>
    150201                <vspace name    = "router"
    151                         binpath = "soft/router.bin"
    152                         vsegs   = "8"
    153                         tasks   = "4"
    154                         mwmrs   = "2"
     202                        funcs   = "data"
    155203                        ttys    = "4" >
    156204
    157                         <vseg   name      = "seg_data"
     205                        <vseg   name      = "seg_data_router"
    158206                                vbase     = "0x00800000"
    159                                 length    = "0x00010000"
    160207                                mode      = "__WU"
    161208                                psegname  = "PSEG_RAU"
    162                                 ident     = "1" />
    163                         <vseg   name      = "seg_code"
     209                                ident     = "0" >
     210                                                        <vobj   name    = "data"
     211                                                                        type    = "ELF"
     212                                                                        length  = "0x00010000"
     213                                    binpath = "router.bin"
     214                                                                        />
     215                                                </vseg>
     216
     217                        <vseg   name      = "seg_code_router"
    164218                                vbase     = "0x00400000"
    165                                 length    = "0x00010000"
    166219                                mode      = "CX_U"
    167220                                psegname  = "PSEG_RAU"
    168                                 ident     = "1" />
     221                                ident     = "0" >
     222                                                        <vobj   name    = "code"
     223                                                                        type    = "ELF"
     224                                                                        length  = "0x00010000"
     225                                    binpath = "router.bin"
     226                                                                        />
     227                                                </vseg>
     228
     229                        <vseg   name      = "seg_ptab"
     230                                vbase     = "0x00300000"
     231                                mode      = "C___"
     232                                psegname  = "PSEG_RAU"
     233                                ident     = "0" >
     234                            <vobj   name        = "ptab"
     235                                    type        = "PTAB"
     236                                    length  = "0x00010000"
     237                                    align   = "13"
     238                                    />
     239                        </vseg>
     240
    169241                        <vseg   name      = "seg_stack_producer"
    170                                 vbase     = "0x00000000"
    171                                 length    = "0x00010000"
    172                                 mode      = "C_WU"
    173                                 psegname  = "PSEG_RAU" />
     242                                                vbase     = "0x00010000"
     243                                mode      = "C_WU"
     244                                psegname  = "PSEG_RAU" >
     245                                                        <vobj   name    = "stack_producer"
     246                                                                        type    = "BUFFER"
     247                                                                        length  = "0x00010000" />
     248                                                </vseg>
     249
    174250                        <vseg   name      = "seg_stack_consumer"
    175                                 vbase     = "0x00010000"
    176                                 length    = "0x00010000"
    177                                 mode      = "C_WU"
    178                                 psegname  = "PSEG_RAU" />
     251                                                vbase     = "0x00020000"
     252                                mode      = "C_WU"
     253                                psegname  = "PSEG_RAU" >
     254                                                        <vobj   name    = "stack_consumer"
     255                                                                        type    = "BUFFER"
     256                                                                        length  = "0x00010000" />
     257                                                </vseg>
     258
    179259                        <vseg   name      = "seg_stack_router_A"
    180                                 vbase     = "0x00020000"
    181                                 length    = "0x00010000"
    182                                 mode      = "C_WU"
    183                                 psegname  = "PSEG_RAU" />
     260                                                vbase     = "0x00030000"
     261                                mode      = "C_WU"
     262                                psegname  = "PSEG_RAU" >
     263                                                        <vobj   name    = "stack_router_A"
     264                                                                        type    = "BUFFER"
     265                                                                        length  = "0x00010000" />
     266                                                </vseg>
     267
    184268                        <vseg   name      = "seg_stack_router_B"
    185                                 vbase     = "0x00030000"
    186                                 length    = "0x00010000"
    187                                 mode      = "C_WU"
    188                                 psegname  = "PSEG_RAU" />
     269                                                vbase     = "0x00040000"
     270                                mode      = "C_WU"
     271                                psegname  = "PSEG_RAU" >
     272                                                        <vobj   name    = "stack_router_B"
     273                                                                        type    = "BUFFER"
     274                                                                        length  = "0x00010000" />
     275                                                </vseg>
     276
    189277                        <vseg   name      = "seg_mwmr_in"
    190                                 vbase     = "0x00040000"
    191                                 length    = "0x00001000"
     278                                vbase     = "0x00050000"
    192279                                mode      = "__WU"
    193280                                psegname  = "PSEG_RAU"
    194                                 mwmr      = "1" />
     281                                mwmr      = "1" >
     282                                                        <vobj   name    = "mwmr_in"
     283                                                                        type    = "MWMR"
     284                                                                        length  = "0x00000020"/>
     285                                                </vseg>
     286
    195287                        <vseg   name      = "seg_mwmr_out"
    196                                 vbase     = "0x00050000"
    197                                 length    = "0x00001000"
     288                                vbase     = "0x00060000"
    198289                                mode      = "__WU"
    199290                                psegname  = "PSEG_RAU"
    200                                 mwmr      = "1" />
     291                                mwmr      = "1" >
     292                                                        <vobj   name    = "mwmr_out"
     293                                                                        type    = "MWMR"
     294                                                                        length  = "0x00000020"/>
     295                                                </vseg>
    201296
    202297                        <task   name      = "producer"
    203298                                clusterid = "0"
    204299                                proclocid = "0"
    205                                 stackname = "seg_stack_producer"
     300                                stackname = "stack_producer"
    206301                                startid   = "0"
    207302                                ttylocid  = "0" />
     
    209304                                clusterid = "0"
    210305                                proclocid = "1"
    211                                 stackname = "seg_stack_consumer"
     306                                stackname = "stack_consumer"
    212307                                startid   = "1"
    213308                                ttylocid  = "1" />
     
    215310                                clusterid = "0"
    216311                                proclocid = "2"
    217                                 stackname = "seg_stack_router_A"
     312                                stackname = "stack_router_A"
    218313                                startid   = "2"
    219314                                ttylocid  = "2" />
     
    221316                                clusterid = "0"
    222317                                proclocid = "3"
    223                                 stackname = "seg_stack_router_B"
     318                                stackname = "stack_router_B"
    224319                                startid   = "2"
    225320                                ttylocid  = "3" />
     
    227322
    228323                <vspace name    = "hello"
    229                         binpath = "soft/hello.bin"
    230                         vsegs   = "3"
    231                         tasks   = "1"
    232                         mwmrs   = "0"
     324                        funcs   = "data"
    233325                        ttys    = "1" >
    234326
    235                         <vseg   name      = "seg_data"
    236                                 vbase     = "0x00810000"
    237                                 length    = "0x00010000"
    238                                 mode      = "C_WU"
    239                                 psegname  = "PSEG_RAU"
    240                                 ident     = "1" />
     327                        <vseg   name      = "seg_data_hello"
     328                                vbase     = "0x00800000"
     329                                mode      = "C_WU"
     330                                psegname  = "PSEG_RAU"
     331                                ident     = "0" >
     332                                                        <vobj   name    = "data"
     333                                                                        type    = "ELF"
     334                                                                        length    = "0x00010000"
     335                                    binpath = "hello.bin"/>
     336                                                </vseg>
     337
     338                        <vseg   name      = "seg_code_hello"
     339                                vbase     = "0x00400000"
     340                                mode      = "CX_U"
     341                                psegname  = "PSEG_RAU"
     342                                ident     = "0" >
     343                                                        <vobj   name    = "code"
     344                                                                        type    = "ELF"
     345                                                                        length    = "0x00010000"
     346                                    binpath = "hello.bin"/>
     347                                                </vseg>
     348
     349                        <vseg   name      = "seg_ptab"
     350                                vbase     = "0x00300000"
     351                                mode      = "C___"
     352                                psegname  = "PSEG_RAU"
     353                                ident     = "0" >
     354                            <vobj   name        = "ptab"
     355                                    type        = "PTAB"
     356                                    length  = "0x00010000"
     357                                    align   = "13"
     358                                    />
     359                        </vseg>
    241360
    242361                        <vseg   name      = "seg_stack"
    243362                                vbase     = "0x00000000"
    244                                 length    = "0x00010000"
    245                                 mode      = "C_WU"
    246                                 psegname  = "PSEG_RAU" />
    247 
    248                         <vseg   name      = "seg_code"
    249                                 vbase     = "0x00410000"
    250                                 length    = "0x00010000"
    251                                 mode      = "CX_U"
    252                                 psegname  = "PSEG_RAU"
    253                                 ident     = "1" />
     363                                mode      = "C_WU"
     364                                psegname  = "PSEG_RAU" >
     365                                                        <vobj   name    = "stack"
     366                                                                        type    = "BUFFER"
     367                                                                        length  = "0x00010000" />
     368                                                </vseg>
     369
    254370
    255371                        <task   name      = "main_hello"
    256372                                clusterid = "0"
    257373                                proclocid = "2"
    258                                 stackname = "seg_stack"
     374                                stackname = "stack"
    259375                                startid   = "0"
    260376                                ttylocid  = "0" />
     
    262378
    263379                <vspace name    = "pgcd"
    264                         binpath = "soft/pgcd.bin"
    265                         vsegs   = "3"
    266                         tasks   = "1"
    267                         mwmrs   = "0"
     380                        funcs   = "data"
    268381                        ttys    = "1" >
    269382
    270                         <vseg   name      = "seg_data"
    271                                 vbase     = "0x00820000"
    272                                 length    = "0x00010000"
    273                                 mode      = "C_WU"
    274                                 psegname  = "PSEG_RAU"
    275                                 ident     = "1" />
     383                        <vseg   name      = "seg_data_pgcd"
     384                                vbase     = "0x00800000"
     385                                mode      = "C_WU"
     386                                psegname  = "PSEG_RAU"
     387                                ident     = "0" >
     388                                                        <vobj   name    = "data"
     389                                                                        type    = "ELF"
     390                                                                        length  = "0x00010000"
     391                                    binpath = "pgcd.bin" />
     392                                                </vseg>
     393
     394                        <vseg   name      = "seg_ptab"
     395                                vbase     = "0x00300000"
     396                                mode      = "C___"
     397                                psegname  = "PSEG_RAU"
     398                                ident     = "0" >
     399                            <vobj   name        = "ptab"
     400                                    type        = "PTAB"
     401                                    length  = "0x00010000"
     402                                    align   = "13"
     403                                    />
     404                        </vseg>
     405
     406                        <vseg   name      = "seg_code_pgcd"
     407                                vbase     = "0x00400000"
     408                                mode      = "CX_U"
     409                                psegname  = "PSEG_RAU"
     410                                ident     = "0" >
     411                                                        <vobj   name    = "code"
     412                                                                        type    = "ELF"
     413                                                                        length  = "0x00010000"
     414                                    binpath = "pgcd.bin" />
     415                                                </vseg>
    276416
    277417                        <vseg   name      = "seg_stack"
    278418                                vbase     = "0x00000000"
    279                                 length    = "0x00010000"
    280                                 mode      = "C_WU"
    281                                 psegname  = "PSEG_RAU" />
    282 
    283                         <vseg   name      = "seg_code"
    284                                 vbase     = "0x00420000"
    285                                 length    = "0x00010000"
     419                                mode      = "C_WU"
     420                                psegname  = "PSEG_RAU" >
     421                                                        <vobj   name    = "stack"
     422                                                                        type    = "BUFFER"
     423                                                                        length  = "0x00010000" />
     424                                                </vseg>
     425
     426
     427                        <task   name      = "main_pgcd"
     428                                clusterid = "0"
     429                                proclocid = "3"
     430                                stackname = "stack"
     431                                startid   = "0"
     432                                ttylocid  = "0" />
     433                </vspace>
     434
     435                <vspace name    = "numsplit"
     436                        funcs   = "data"
     437                        ttys    = "2" >
     438
     439                        <vseg   name      = "seg_data_numsplit"
     440                                vbase     = "0x00800000"
     441                                mode      = "__WU"
     442                                psegname  = "PSEG_RAU"
     443                                ident     = "0" >
     444                                                        <vobj   name    = "data"
     445                                                                        type    = "ELF"
     446                                                                        length  = "0x00010000"
     447                                    binpath = "numsplit.bin"
     448                                                                        />
     449                                                </vseg>
     450
     451                        <vseg   name      = "seg_code_numsplit"
     452                                vbase     = "0x00400000"
    286453                                mode      = "CX_U"
    287454                                psegname  = "PSEG_RAU"
    288                                 ident     = "1" />
    289 
    290                         <task   name      = "main_pgcd"
    291                                 clusterid = "0"
    292                                 proclocid = "3"
    293                                 stackname = "seg_stack"
    294                                 startid   = "0"
     455                                ident     = "0" >
     456                                                        <vobj   name    = "code"
     457                                                                        type    = "ELF"
     458                                                                        length  = "0x00010000"
     459                                    binpath = "numsplit.bin"
     460                                                                        />
     461                                                </vseg>
     462
     463                        <vseg   name      = "seg_ptab"
     464                                vbase     = "0x00300000"
     465                                mode      = "C___"
     466                                psegname  = "PSEG_RAU"
     467                                ident     = "0" >
     468                            <vobj   name        = "ptab"
     469                                    type        = "PTAB"
     470                                    length  = "0x00010000"
     471                                    align   = "13"
     472                                    />
     473                        </vseg>
     474
     475                        <vseg   name      = "seg_stack_producer"
     476                                                vbase     = "0x00010000"
     477                                mode      = "C_WU"
     478                                psegname  = "PSEG_RAU" >
     479                                                        <vobj   name    = "stack_producer"
     480                                                                        type    = "BUFFER"
     481                                                                        length  = "0x00010000" />
     482                                                </vseg>
     483
     484                        <vseg   name      = "seg_stack_consumer"
     485                                                vbase     = "0x00020000"
     486                                mode      = "C_WU"
     487                                psegname  = "PSEG_RAU" >
     488                                                        <vobj   name    = "stack_consumer"
     489                                                                        type    = "BUFFER"
     490                                                                        length  = "0x00010000" />
     491                                                </vseg>
     492
     493                        <vseg   name      = "seg_mwmr"
     494                                vbase     = "0x00050000"
     495                                mode      = "__WU"
     496                                psegname  = "PSEG_RAU"
     497                                mwmr      = "1" >
     498                                                        <vobj   name    = "mwmr"
     499                                                                        type    = "MWMR"
     500                                                                        length  = "0x00000080"/>
     501                                                </vseg>
     502
     503                        <task   name      = "producer"
     504                                clusterid = "0"
     505                                proclocid = "0"
     506                                stackname = "stack_producer"
     507                                startid   = "0"
     508                                ttylocid  = "1" />
     509
     510                        <task   name      = "consumer"
     511                                clusterid = "0"
     512                                proclocid = "1"
     513                                stackname = "stack_consumer"
     514                                startid   = "1"
    295515                                ttylocid  = "0" />
    296516                </vspace>
  • soft/giet_vm/sys/common.c

    r158 r160  
    99///////////////////////////////////////////////////////////////////////////////////
    1010
    11 #include <mapping_info.h>
    1211#include <common.h>
    1312#include <drivers.h>
     
    216215}
    217216/////////////////////////////////////////////////////////////////////////////
    218 mapping_task_t* _get_task_base( mapping_header_t* header )
    219 {
    220     return   (mapping_task_t*)    ((char*)header +
     217mapping_vobj_t* _get_vobj_base( mapping_header_t* header )
     218{
     219    return   (mapping_vobj_t*)   ((char*)header +
    221220                                  MAPPING_HEADER_SIZE +
    222221                                  MAPPING_CLUSTER_SIZE*header->clusters +
    223222                                  MAPPING_PSEG_SIZE*header->psegs +
    224223                                  MAPPING_VSPACE_SIZE*header->vspaces +
     224                                  MAPPING_VSEG_SIZE*header->vsegs );
     225}
     226/////////////////////////////////////////////////////////////////////////////
     227mapping_task_t* _get_task_base( mapping_header_t* header )
     228{
     229    return   (mapping_task_t*)    ((char*)header +
     230                                  MAPPING_HEADER_SIZE +
     231                                  MAPPING_CLUSTER_SIZE*header->clusters +
     232                                  MAPPING_PSEG_SIZE*header->psegs +
     233                                  MAPPING_VSPACE_SIZE*header->vspaces +
     234                                  MAPPING_VOBJ_SIZE*header->vobjs +
    225235                                  MAPPING_VSEG_SIZE*header->vsegs);
    226236}
    227237
     238
  • soft/giet_vm/sys/common.h

    r158 r160  
    2424extern _ld_symbol_t seg_fb_base;
    2525extern _ld_symbol_t seg_ioc_base;
    26 extern _ld_symbol_t seg_boot_mapping_base;
     26extern _ld_symbol_t seg_mapping_base;
    2727extern _ld_symbol_t seg_kernel_pt_base;
    2828
     
    4949mapping_vspace_t*   _get_vspace_base( mapping_header_t* header );
    5050mapping_vseg_t*     _get_vseg_base( mapping_header_t* header );
     51mapping_vobj_t*     _get_vobj_base( mapping_header_t* header );
    5152mapping_task_t*     _get_task_base( mapping_header_t* header );
    5253
  • soft/giet_vm/sys/ctx_handler.c

    r158 r160  
    3131
    3232#include <giet_config.h>
    33 #include <ctx_handler.h>
    34 #include <sys_handler.h>
    3533#include <drivers.h>
    3634#include <common.h>
     35#include <ctx_handler.h>
     36#include <mapping_info.h>
     37#include <sys_handler.h>
    3738
    3839extern void _task_switch(unsigned int *, unsigned int *);
     
    7172    // return if only one task  */
    7273    if ( tasks <= 1) return;
    73 
     74 
    7475    // compute the task context base address for the current task
    7576    curr_task_id = _scheduler[proc_id].current;
    7677    curr_context = &(_scheduler[proc_id].context[curr_task_id][0]);
    77 
     78   
    7879    // select the next task using a round-robin scheduling policy
    7980    next_task_id = (curr_task_id + 1) % tasks;
  • soft/giet_vm/sys/drivers.c

    r158 r160  
    55// Copyright (c) UPMC-LIP6
    66///////////////////////////////////////////////////////////////////////////////////
    7 // The vers.c and drivers.h files are part ot the GIET nano kernel.
     7// The drivers.c and drivers.h files are part ot the GIET nano kernel.
    88// They contains the drivers for the peripherals available in the SoCLib library:
    99// - vci_multi_tty
     
    204204
    205205    proc_id = _procid();
     206   
    206207    task_id = _scheduler[proc_id].current;
    207208    tty_id  = _scheduler[proc_id].context[task_id][CTX_TTY_ID];
  • soft/giet_vm/sys/irq_handler.c

    r158 r160  
    4545    int interrupt_index;
    4646    _isr_func_t isr;
     47
     48    // interrupt vector initialisation
     49
    4750
    4851    /* retrieves the highest priority active interrupt index */
  • soft/giet_vm/sys/sys.ld

    r158 r160  
    22* Definition of the base address for all virtual segments
    33*****************************************************************************/
    4 
    5 /* The vsegs used in the boot phase must respect identity mapping:
    6    physical address = virtual address */
    7 
    8 seg_boot_code_base      = 0xBFC00000;   /* boot code */
    9 seg_boot_stack_base     = 0xBFC08000;   /* boot temporary stack */
    10 seg_boot_mapping_base   = 0xBFC0C000;   /* boot mapping_info */
    114
    125/* The vsegs used by the system are replicated in all virtual spaces
     
    169seg_kernel_data_base    = 0x80010000;   /* system cacheable data */
    1710seg_kernel_uncdata_base = 0x80020000;   /* system uncacheable data */
    18 seg_kernel_pt_base      = 0x80030000;   /* system page table */
     11seg_kernel_init_base    = 0x80030000;   /* system page table */
    1912
    20 /* The peripherals base addresses are referenced by the software drivers and
     13
     14/* The peripherals base addresses are referenced by the software drivers and    \
    2115   must be defined, even if the peripherals are not used in the architecture */
    2216
     
    2923seg_icu_base            = 0x9F000000;   /* ICU device */
    3024
     25/*****************************************/
     26seg_mapping_base        = 0xBFC0C000;   /* boot mapping_info */
     27
    3128/*
    3229 * Grouping sections into segments for system code and data
     
    3532SECTIONS
    3633{
    37     . = seg_boot_code_base;
    38     seg_boot_code :
    39     {
    40         *(.boot)
    41     }
    4234    . = seg_kernel_code_base;
    4335    seg_kernel_code :
     
    6961        *(.unckdata)
    7062    }
    71     . = seg_kernel_pt_base;
    72     seg_kernel_pt :
     63
     64    . = seg_kernel_init_base;
     65    seg_kernel_init :
    7366    {
    74         *(.ptab)
     67        *(.kinitentry)
     68        *(.kinit)
    7569    }
    7670}
  • soft/giet_vm/sys/sys_handler.c

    r158 r160  
    1212
    1313#include <sys_handler.h>
    14 #include <boot_handler.h>
     14//#include <boot_handler.h>
    1515#include <drivers.h>
    1616#include <ctx_handler.h>
     
    4949    &_sys_ukn,          /* 0x18 */
    5050    &_sys_ukn,          /* 0x19 */
    51     &_mwmr_base,        /* 0x1A */
     51    &_vobj_get_vbase,   /* 0x1A */
    5252    &_sys_ukn,          /* 0x1B */
    5353    &_sys_ukn,          /* 0x1C */
     
    117117                            unsigned int*       buffer)
    118118{
    119     mapping_header_t*   header  = (mapping_header_t*)&seg_boot_mapping_base;
     119    mapping_header_t*   header  = (mapping_header_t*)&seg_mapping_base;
    120120    mapping_cluster_t*  cluster = _get_cluster_base( header );
    121121
     
    131131}
    132132/////////////////////////////////////////////////////////////////////////////
    133 // _mwmr_base()
    134 // returns in buffer argument the base address of the MWMR channel
    135 // identified by the (vspace_name / channel_name) couple.
     133// _vobj_get_base()
     134// returns 0: success, else: failed.
     135// give access to the base address of a vobj identified by the (vspace_name / channel_name ) couple.
     136// The "type" argument is here for checking purpose.
    136137/////////////////////////////////////////////////////////////////////////////
    137 unsigned int _mwmr_base( char* vspace_name,
    138                          char* channel_name,
    139                          unsigned int* buffer )
     138unsigned int _vobj_get_vbase( char* vspace_name, char* vobj_name,
     139                        unsigned vobj_type, unsigned int* vobj_buffer)
    140140{
    141     mapping_header_t* header = (mapping_header_t*)&seg_boot_mapping_base;
     141    mapping_header_t* header = (mapping_header_t*)&seg_mapping_base;
    142142    mapping_vspace_t* vspace = _get_vspace_base( header );
    143     mapping_vseg_t*   vseg   = _get_vseg_base( header );
     143    mapping_vobj_t*    vobj  = _get_vobj_base( header );
    144144
    145145    unsigned int    vspace_id;
    146     unsigned int    vseg_id;
     146    unsigned int    vobj_id;
     147       
    147148
    148149    // scan vspaces
     
    151152        if ( _strncmp( vspace[vspace_id].name, vspace_name, 31) == 0 )
    152153        {
    153             // scan vsegs
    154             for ( vseg_id = vspace[vspace_id].vseg_offset ;
    155                   vseg_id < (vspace[vspace_id].vseg_offset + vspace[vspace_id].vsegs) ;
    156                   vseg_id++ )
     154            // scan vobjs
     155            for(vobj_id= vspace[vspace_id].vobj_offset; vobj_id < (vspace[vspace_id].vobj_offset + vspace[vspace_id].vobjs); vobj_id++)
    157156            {
    158                 if ( _strncmp( vseg[vseg_id].name, channel_name, 31) == 0 )
     157
     158                if ( _strncmp( vobj[vobj_id].name, vobj_name, 31) == 0 )
    159159                {
    160                     *buffer = vseg[vseg_id].vbase;
     160                    if(vobj[vobj_id].type != vobj_type)
     161                        return -1;//wrong type
     162
     163                    *vobj_buffer = (unsigned int)vobj[vobj_id].vaddr;
    161164                    return 0;
    162165                }
     
    165168    }
    166169    // not found !!!
    167     return 1;
     170    return -2;
    168171}
    169172
  • soft/giet_vm/sys/sys_handler.h

    r158 r160  
    3030                               unsigned int* buffer );
    3131
    32 unsigned int    _mwmr_base( char* vspace_name,
    33                             char* channel_name,
    34                             unsigned int* buffer);
    35 
     32unsigned int _vobj_get_vbase( char* vspace_name, char* vobj_name,
     33                        unsigned vobj_type, unsigned int* vobj_buffer);
    3634#endif
  • soft/giet_vm/xml/Makefile

    r158 r160  
    88        gcc -Wall -I. -I/usr/include/libxml2 xml_parser.c -o xml2bin -lxml2
    99
     10test:
     11        ./xml2bin map.xml test.bin
     12        ./bin2xml test.bin test.xml
     13
     14up_test:
     15        ./xml2bin ../map.xml ../test.bin
     16        ./bin2xml ../test.bin ../test.xml
     17
     18
    1019clean:
    1120        rm xml2bin bin2xml
  • soft/giet_vm/xml/mapping_info.h

    r158 r160  
    1818// - mapping_vspace_t   vspace[vspaces]     (MAPPING_VSPACE_SIZE * vspaces)
    1919// - mapping_vseg_t     vseg[vsegs]         (MAPPING_VSEG_SIZE * vsegs)
     20// - mapping_vseg_t     vobj[vsegs]         (MAPPING_VOBJ_SIZE * vsegs)
    2021// - mapping_task_t     task[tasks]         (MAPPING_TASK_SIZE * tasks)
    21 // - mapping_mwmr_t     mwmr[mwmrs]         (MAPPING_MWMR_SIZE * mwmrs)
    2222//
    2323// The number of clusters and the number of vspaces are defined in the header.
     
    4343#define MAPPING_VSPACE_SIZE     sizeof(mapping_vspace_t)
    4444#define MAPPING_VSEG_SIZE           sizeof(mapping_vseg_t)
     45#define MAPPING_VOBJ_SIZE           sizeof(mapping_vobj_t)
    4546#define MAPPING_PSEG_SIZE           sizeof(mapping_pseg_t)
    4647#define MAPPING_TASK_SIZE           sizeof(mapping_task_t)
     
    5455#define OUT_MAPPING_SIGNATURE   0xBABEF00D
    5556
     57enum
     58{
     59    ELF = 0,    //loadable code object
     60    PTAB,       //page table
     61    PERI,       //hardware component
     62    MWMR,       //MWMR channel
     63    LOCK,       //Lock
     64    BUFFER,     //Any "no intialiasation needed" objects (stacks...)
     65    BARRIER     //Barrier
     66};
     67
     68
    5669///////////////////////////////
    5770typedef struct mapping_header_s
     
    6376        unsigned int    globals;                // number of vsegs mapped in all vspaces
    6477        unsigned int    vspaces;                // number of virtual spaces
    65         unsigned int    vsegs;                  // total number of virtual segments (for all vspaces
     78        unsigned int    vsegs;                  // total number of virtual segments (for all vspaces)
     79        unsigned int    vobjs;                  // total number of virtual memory objects (for all vspaces)
    6680        unsigned int    tasks;                  // total number of tasks (for all vspaces)
    6781    char            name[32];       // mapping name
    68     char            syspath[64];    // path for the system binary code ("sys.bin")
    6982} mapping_header_t;
    7083
     
    90103{
    91104    char            name[32];       // virtual space name
    92     char            binpath[64];    // pathname to the binary code ("app.bin")
     105    unsigned int    funcs_offset;   // offset of the vobj containing the function entry table (relative to vobj_offset)
    93106        unsigned int    vsegs;              // number of private virtual segments
     107        unsigned int    vobjs;              // number of vobjs channels
    94108        unsigned int    tasks;              // number of tasks
    95         unsigned int    mwmrs;              // number of mwmr channels
    96109        unsigned int    ttys;               // number of required TTY terminals
    97110    unsigned int    vseg_offset;    // index of first vseg in vspace
     111    unsigned int    vobj_offset;    // index of first vobjs in vspace
    98112    unsigned int    task_offset;    // index of first task in vspace
    99     unsigned int    mwmr_offset;    // index of first mwmr in vspace
    100113} mapping_vspace_t;
    101114
     
    110123        unsigned char   mode;           // C-X-W-U flags
    111124    unsigned char   ident;          // identity mapping if non zero
    112     unsigned char   mwmr;           // mwmr channel if non zero
     125        unsigned int    vobjs;              // number of vobjs channels
     126    unsigned int    vobj_offset;    // index of first vobjs in vspace
    113127    unsigned char   reserved;       // unused
    114128} mapping_vseg_t;
     
    120134        unsigned int    clusterid;          // physical cluster index
    121135        unsigned int    proclocid;      // processor local index (inside cluster)
    122     unsigned int    vseglocid;      // stack vseg index in vspace
     136    unsigned int    vobjlocid;      // stack vobj index in vspace
    123137    unsigned int    startid;        // index in start_vector (in seg_data)
    124138    unsigned int    ttylocid;       // tty index (inside the vspace)
    125139} mapping_task_t;
     140
     141/////////////////////////////
     142typedef struct mapping_vobj_s
     143{
     144    char            name[32];       // vobj name (unique in a vspace)
     145    char            binpath[64];    // path for the binary code ("*.bin")
     146        unsigned int    type;           // type of vobj
     147        unsigned int    length;         // size (bytes)
     148        unsigned int    align;          // required alignement (logarithm of 2)
     149        unsigned int    vaddr;          // virtual addresse of the vobj location (bytes)
     150        unsigned int    paddr;          // physical addresse of the vobj location (bytes)
     151} mapping_vobj_t;
    126152
    127153#endif
  • soft/giet_vm/xml/xml_driver.c

    r158 r160  
    2020void buildXml( mapping_header_t* header, FILE* fpout)
    2121{
     22
     23    const char*
     24    vobj_type[] =
     25    {
     26        "ELF",
     27        "PTAB",   //page table
     28        "PERI",   //hardware component
     29        "MWMR",   //MWMR channel
     30        "LOCK",   //Lock
     31        "BUFFER", //Any "no intialiasation needed" objects (stacks...)
     32        "BARRIER" //Barrier
     33    };
    2234    const char* mode_str[] = { "____",
    2335                               "___U",
     
    4153    unsigned int                pseg_id;
    4254    unsigned int                vseg_id;
     55    unsigned int                vobj_id;
    4356    unsigned int                task_id;
    4457
     
    4760    mapping_vspace_t*   vspace;
    4861    mapping_vseg_t*     vseg;
     62    mapping_vobj_t*     vobj;
    4963    mapping_task_t*     task;
    5064
     
    7185                                  MAPPING_VSPACE_SIZE*header->vspaces );
    7286
     87    // computes the base adresss for vobjs array,
     88    vobj    = (mapping_vobj_t*)   ((char*)header +
     89                                  MAPPING_HEADER_SIZE +
     90                                  MAPPING_CLUSTER_SIZE*header->clusters +
     91                                  MAPPING_PSEG_SIZE*header->psegs +
     92                                  MAPPING_VSPACE_SIZE*header->vspaces +
     93                                  MAPPING_VSEG_SIZE*header->vsegs );
     94
    7395    // computes the base address for tasks array
    7496    task    = (mapping_task_t*)   ((char*)header +
     
    7799                                  MAPPING_PSEG_SIZE*header->psegs +
    78100                                  MAPPING_VSPACE_SIZE*header->vspaces +
     101                                  MAPPING_VOBJ_SIZE*header->vobjs +
    79102                                  MAPPING_VSEG_SIZE*header->vsegs );
    80103
     
    89112    fprintf( fpout, "              ttys      = \"%d\"\n", header->ttys);
    90113    fprintf( fpout, "              vspaces   = \"%d\"\n", header->vspaces);
    91     fprintf( fpout, "              globals   = \"%d\"\n", header->globals);
    92     fprintf( fpout, "              syspath   = \"%s\" >\n", header->syspath);
     114    fprintf( fpout, "              globals   = \"%d\" />\n\n", header->globals);
    93115
    94116    ///////////////////// clusters ///////////////////////////////////////////////
     
    124146        fprintf( fpout, "        <vseg    name     = \"%s\"\n",      vseg[vseg_id].name);
    125147        fprintf( fpout, "                 vbase    = \"0x%x\"\n",    vseg[vseg_id].vbase);
    126         fprintf( fpout, "                 length   = \"0x%x\"\n",    vseg[vseg_id].length);
    127148        fprintf( fpout, "                 mode     = \"%s\"\n", mode_str[vseg[vseg_id].mode]);
    128149        fprintf( fpout, "                 psegname = \"%s\"\n",      pseg[pseg_id].name);
    129         fprintf( fpout, "                 ident    = \"%d\" />\n\n", vseg[vseg_id].ident);
     150        fprintf( fpout, "                 ident    = \"%d\" >\n", vseg[vseg_id].ident);
     151            for ( vobj_id = vseg[vseg_id].vobj_offset ;
     152                  vobj_id < (vseg[vseg_id].vobj_offset + vseg[vseg_id].vobjs) ; vobj_id++ )
     153            {
     154                fprintf( fpout, "                 <vobj name     = \"%s\"\n",     vobj[vobj_id].name);
     155                fprintf( fpout, "                       type     = \"%s\" \n", vobj_type[vobj[vobj_id].type]);
     156                if(vobj[vobj_id].length)
     157                    fprintf( fpout, "                       length   = \"0x%x\" \n",   vobj[vobj_id].length);
     158                if(vobj[vobj_id].align)
     159                    fprintf( fpout, "                       align    = \"%d\" \n",   vobj[vobj_id].align);
     160                if(vobj[vobj_id].binpath[0]!='\0')
     161                    fprintf( fpout, "                       binpath  = \"%s\" \n",   vobj[vobj_id].binpath);
     162                fprintf( fpout, "                       />\n");
     163            }
     164            fprintf( fpout, "        </vseg>\n\n");
    130165    }
    131166    fprintf( fpout, "    </globalset>\n" );
     
    136171    for ( vspace_id = 0 ; vspace_id < header->vspaces ; vspace_id++ )
    137172    {
     173        unsigned int func_id = vspace[vspace_id].vobj_offset + vspace[vspace_id].funcs_offset;
    138174        fprintf( fpout, "        <vspace  name    = \"%s\"\n",     vspace[vspace_id].name);
    139         fprintf( fpout, "                 binpath = \"%s\"\n",     vspace[vspace_id].binpath);
    140         fprintf( fpout, "                 vsegs   = \"%d\"\n",     vspace[vspace_id].vsegs);
    141         fprintf( fpout, "                 tasks   = \"%d\"\n",     vspace[vspace_id].tasks);
    142         fprintf( fpout, "                 mwmrs   = \"%d\"\n",     vspace[vspace_id].mwmrs);
     175        fprintf( fpout, "                 funcs   = \"%s\"\n",     vobj[func_id].name);
    143176        fprintf( fpout, "                 ttys    = \"%d\" >\n\n", vspace[vspace_id].ttys);
    144177
     
    150183            fprintf( fpout, "                 <vseg name      = \"%s\"\n",      vseg[vseg_id].name);
    151184            fprintf( fpout, "                       vbase     = \"0x%x\"\n",    vseg[vseg_id].vbase);
    152             fprintf( fpout, "                       length    = \"0x%x\"\n",    vseg[vseg_id].length);
    153185            fprintf( fpout, "                       mode      = \"%s\"\n", mode_str[vseg[vseg_id].mode]);
    154186            fprintf( fpout, "                       psegname  = \"%s\"\n",      pseg[pseg_id].name);
    155             fprintf( fpout, "                       mwmr      = \"%d\"\n",      vseg[vseg_id].mwmr);
    156             fprintf( fpout, "                       ident     = \"%d\" />\n\n", vseg[vseg_id].ident);
     187            fprintf( fpout, "                       ident     = \"%d\" >\n", vseg[vseg_id].ident);
     188
     189            for ( vobj_id = vseg[vseg_id].vobj_offset ;
     190                  vobj_id < (vseg[vseg_id].vobj_offset + vseg[vseg_id].vobjs) ; vobj_id++ )
     191            {
     192                fprintf( fpout, "\t                 <vobj name     = \"%s\"\n",     vobj[vobj_id].name);
     193                fprintf( fpout, "\t                       type     = \"%s\" \n", vobj_type[vobj[vobj_id].type]);
     194                if(vobj[vobj_id].length)
     195                    fprintf( fpout, "\t                       length   = \"0x%x\" \n",   vobj[vobj_id].length);
     196                if(vobj[vobj_id].align)
     197                    fprintf( fpout, "\t                       align    = \"%d\" \n",   vobj[vobj_id].align);
     198                if(vobj[vobj_id].binpath[0]!='\0')
     199                    fprintf( fpout, "\t                       binpath  = \"%s\" \n",   vobj[vobj_id].binpath);
     200                fprintf( fpout, "\t                       />\n");
     201            }
     202            fprintf( fpout, "\t\t        </vseg>\n\n");
    157203        }
    158204        for ( task_id = vspace[vspace_id].task_offset ;
    159205              task_id < (vspace[vspace_id].task_offset + vspace[vspace_id].tasks) ; task_id++ )
    160206        {
    161             unsigned int vseg_id = task[task_id].vseglocid + vspace[vspace_id].vseg_offset;
     207            unsigned int vobj_id = task[task_id].vobjlocid + vspace[vspace_id].vobj_offset;
    162208
    163209            fprintf( fpout, "                 <task name      = \"%s\"\n",      task[task_id].name);
    164210            fprintf( fpout, "                       clusterid = \"%d\"\n",      task[task_id].clusterid);
    165211            fprintf( fpout, "                       proclocid = \"%d\"\n",      task[task_id].proclocid);
    166             fprintf( fpout, "                       stackname = \"%s\"\n",      vseg[vseg_id].name);
     212            fprintf( fpout, "                       stackname = \"%s\"\n",      vobj[vobj_id].name);
    167213            fprintf( fpout, "                       startid   = \"%d\"\n",      task[task_id].startid);
    168214            fprintf( fpout, "                       ttylocid  = \"%d\" />\n\n", task[task_id].ttylocid);
  • soft/giet_vm/xml/xml_parser.c

    r158 r160  
    1818#include  <mapping_info.h>
    1919
    20 #define MAX_CLUSTERS            1024
     20#define MAX_CLUSTERS    1024
    2121#define MAX_PSEGS               4096
    2222#define MAX_VSPACES             1024
     
    2424#define MAX_MWMRS               4096
    2525#define MAX_VSEGS               4096
     26#define MAX_VOBJS               8192
    2627
    2728#define XML_PARSER_DEBUG        0
     
    3637mapping_vspace_t*       vspace[MAX_VSPACES];            // vspace array
    3738mapping_vseg_t*         vseg[MAX_VSEGS];                // vseg array
     39mapping_vobj_t*         vobj[MAX_VOBJS];                // vobj array
    3840mapping_task_t*         task[MAX_TASKS];                // task array
    3941
     
    4648unsigned int            task_index     = 0;
    4749unsigned int            task_loc_index = 0;
    48 unsigned int            mwmr_index     = 0;
    49 unsigned int            mwmr_loc_index = 0;
     50unsigned int            vobj_index     = 0;
     51unsigned int            vobj_loc_index = 0;
     52unsigned int            vobj_loc_vspace_index = 0;
     53           
     54char one_elf_found = 0;//bool: wether a first vobj of type elf was found
    5055
    5156//////////////////////////////////////////////////
     
    132137
    133138//////////////////////////////////////////
    134 int getVsegLocId( unsigned int  vspace_id,
     139int getVobjLocId( unsigned int  vspace_id,
    135140                  char*         str )
    136141{
    137     unsigned int vseg_id;
    138     unsigned int vseg_min = vspace[vspace_id]->vseg_offset;
    139     unsigned int vseg_max = vseg_min + vspace[vspace_id]->vsegs;
    140 
    141     for ( vseg_id = vseg_min ; vseg_id < vseg_max ; vseg_id++ )
    142     {
    143         if ( strcmp(vseg[vseg_id]->name, str) == 0 ) return (vseg_id - vseg_min);
     142    unsigned int vobj_id;
     143    unsigned int vobj_min = vspace[vspace_id]->vobj_offset;
     144    unsigned int vobj_max = vobj_min + vobj_loc_vspace_index;
     145
     146    for ( vobj_id = vobj_min ; vobj_id < vobj_max ; vobj_id++ )
     147    {
     148        if ( strcmp(vobj[vobj_id]->name, str) == 0 )
     149        {
     150             return (vobj_id - vobj_min);
     151        }
    144152    }
    145153    return -1;
     
    218226    if ( ok )
    219227    {
    220         int index = getVsegLocId( vspace_index, str );
     228        int index = getVobjLocId( vspace_index, str );
    221229        if ( index >= 0 )
    222230        {
     
    225233printf("      vsegid    = %d\n", index);
    226234#endif
    227             task[task_index]->vseglocid = index;
     235            task[task_index]->vobjlocid = index;
    228236        }
    229237        else             
     
    283291} // end taskNode()
    284292
    285 ///////////////////////////////////////////////////////////////
    286 void  vsegNode ( xmlTextReaderPtr reader )
     293void  vobjNode ( xmlTextReaderPtr reader )
    287294{
    288295    unsigned int        ok;
     
    292299    if ( xmlTextReaderNodeType(reader) == XML_READER_TYPE_END_ELEMENT ) return;
    293300
     301    if ( vobj_index >= MAX_VOBJS )
     302    {
     303        printf("[XML ERROR] The number of vobjs is larger than %d\n", MAX_VSEGS);
     304        exit(1);
     305    }
     306
     307    if(one_elf_found != 0)
     308    {
     309        printf("[XML ERROR] a vobj of the type ELF must be defined alone in a vseg (%d,%d)\n",
     310                vspace_index, vobj_loc_vspace_index);
     311        exit(1);
     312
     313    }
     314
     315#if XML_PARSER_DEBUG
     316printf("    vobj %d\n", vobj_loc_index);
     317#endif
     318
     319    vobj[vobj_index] = (mapping_vobj_t*)malloc(sizeof(mapping_vobj_t));
     320
     321    ///////// get name attribute
     322    str = getStringValue(reader, "name", &ok);
     323    if ( ok )
     324    {
     325#if XML_PARSER_DEBUG
     326printf("      name = %s\n", str);
     327#endif
     328        strncpy( vobj[vobj_index]->name, str, 31);
     329    }
     330    else
     331    {
     332        printf("[XML ERROR] illegal or missing <name> attribute for vobj (%d,%d)\n",
     333                vseg_index, vobj_loc_index);
     334        exit(1);
     335    }
     336
     337
     338    // get type attribute
     339    str = getStringValue(reader, "type", &ok);
     340#if XML_PARSER_DEBUG
     341printf("      type = %s\n", str);
     342#endif
     343    if (ok && (strcmp(str, "ELF") == 0)){
     344        vobj[vobj_index]->type = ELF;
     345        one_elf_found = 1;
     346        if(vobj_loc_index != 0) //check that this vobj is the first
     347        {
     348            printf("[XML ERROR] a vobj of the type ELF must be defined alone in a vobj (%d,%d)\n",
     349                    vspace_index, vobj_loc_vspace_index);
     350            exit(1);
     351
     352        }
     353    }
     354    else if (ok && (strcmp(str, "PTAB") == 0)) vobj[vobj_index]->type = PTAB;
     355    else if (ok && (strcmp(str, "PERI") == 0)) vobj[vobj_index]->type = PERI;
     356    else if (ok && (strcmp(str, "MWMR") == 0)) vobj[vobj_index]->type = MWMR;
     357    else if (ok && (strcmp(str, "LOCK") == 0)) vobj[vobj_index]->type = LOCK;
     358    else if (ok && (strcmp(str, "BUFFER") == 0)) vobj[vobj_index]->type = BUFFER;
     359    else if (ok && (strcmp(str, "BARRIER") == 0)) vobj[vobj_index]->type = BARRIER;
     360    else
     361    {
     362        printf("[XML ERROR] illegal or missing <type> attribute for vobj (%d,%d)\n",
     363                vspace_index, vobj_loc_vspace_index);
     364        exit(1);
     365    }
     366
     367
     368    ////////// get length attribute (0 if missing)
     369    value = getIntValue(reader,"length", &ok);
     370    if ( ok )
     371    {
     372#if XML_PARSER_DEBUG
     373printf("      length = %d\n", value);
     374#endif
     375        vobj[vobj_index]->length = value;
     376    } 
     377    else
     378    {
     379        vobj[vobj_index]->length = 0;
     380    }
     381
     382    ////////// get align attribute (0 if missing)
     383    value = getIntValue(reader,"align", &ok);
     384    if ( ok )
     385    {
     386#if XML_PARSER_DEBUG
     387printf("      align = %d\n", value);
     388#endif
     389        vobj[vobj_index]->align = value;
     390    } 
     391    else
     392    {
     393        vobj[vobj_index]->align = 0;
     394    }
     395
     396    ////////// get binpath attribute ('\0' if missing)
     397    str = getStringValue(reader, "binpath", &ok);
     398    if ( ok )
     399    {
     400#if XML_PARSER_DEBUG
     401printf("      binpath = %s\n", str);
     402#endif
     403        strncpy(vobj[vobj_index]->binpath, str, 63);
     404    } 
     405    else
     406    {
     407        vobj[vobj_index]->binpath[0] = '\0';
     408    }
     409   
     410    vobj_index++;
     411    vobj_loc_index++;
     412    vobj_loc_vspace_index++;
     413}
     414
     415
     416///////////////////////////////////////////////////////////////
     417void  vsegNode ( xmlTextReaderPtr reader )
     418{
     419    unsigned int        ok;
     420    unsigned int        value;
     421    char*               str;
     422        vobj_loc_index = 0;
     423        one_elf_found = 0;
     424
     425    if ( xmlTextReaderNodeType(reader) == XML_READER_TYPE_END_ELEMENT ) return;
     426
    294427    if ( vseg_index >= MAX_VSEGS )
    295428    {
     
    303436
    304437    vseg[vseg_index] = (mapping_vseg_t*)malloc(sizeof(mapping_vseg_t));
     438   
     439    ////////// set vobj_offset attributes
     440    vseg[vseg_index]->vobj_offset = vobj_index;
     441#if XML_PARSER_DEBUG
     442printf("- vobj_offset = %d\n", vobj_index);
     443#endif
    305444
    306445    ///////// get name attribute
     
    336475    }
    337476
    338     ////////// get length attribute
    339     value = getIntValue(reader,"length", &ok);
    340     if ( ok )
    341     {
    342 #if XML_PARSER_DEBUG
    343 printf("      length = 0x%x\n", value);
    344 #endif
    345         vseg[vseg_index]->length = value;
    346     } 
    347     else
    348     {
    349         printf("[XML ERROR] illegal or missing <length> attribute for vseg (%d,%d)\n",
    350                 vspace_index, vseg_loc_index);
    351         exit(1);
    352     }
    353477
    354478    ////////// get ident attribute (0 if missing)
     
    366490    }
    367491
    368     ////////// get mwmr attribute (0 if missing)
    369     value = getIntValue(reader,"mwmr", &ok);
    370     if ( ok )
    371     {
    372 #if XML_PARSER_DEBUG
    373 printf("      mwmr  = %d\n", value);
    374 #endif
    375         vseg[vseg_index]->mwmr = value;
    376         if ( value )
    377         {
    378             mwmr_index++;
    379             mwmr_loc_index++;
    380         }
    381     } 
    382     else
    383     {
    384         vseg[vseg_index]->mwmr = 0;
    385     }
    386492
    387493    ////////// get psegname attribute
     
    440546    }
    441547   
    442     vseg_index++;
    443     vseg_loc_index++;
     548   
     549    ////////// set the length attribute to 0
     550    //the final value will be set by the VLoader
     551    vseg[vseg_index]->length = value;
     552
     553    ////////// get vobjs
     554    int status = xmlTextReaderRead ( reader );
     555    while ( status == 1 )
     556    {
     557        const char* tag = (const char*)xmlTextReaderConstName(reader);
     558
     559        if      ( strcmp(tag,"vobj") == 0    ) vobjNode(reader);
     560        else if ( strcmp(tag,"#text"  ) == 0 ) { }
     561        else if ( strcmp(tag,"vseg") == 0  )
     562        {
     563            //  checking source file consistency?
     564            vseg[vseg_index]->vobjs = vobj_loc_index;
     565            vseg_index++;
     566            vseg_loc_index++;
     567            return;
     568        }
     569        else
     570        {
     571            printf("[XML ERROR] Unknown tag %s",tag);
     572            exit(1);
     573        }
     574        status = xmlTextReaderRead ( reader );
     575    }
     576   
     577
    444578} // end vsegNode()
    445579
     
    450584    unsigned int        ok;
    451585    unsigned int        value;
     586    vobj_loc_vspace_index = 0;
     587        vseg_loc_index = 0;
     588        task_loc_index = 0;
    452589
    453590    if ( xmlTextReaderNodeType(reader) == XML_READER_TYPE_END_ELEMENT ) return;
     
    467604    vspace[vspace_index] = (mapping_vspace_t*)malloc(sizeof(mapping_vspace_t));
    468605
    469     ////////// set vseg_offset and task_offset attributes
     606    ////////// set vseg_offsetand task_offset attributes
    470607    vspace[vspace_index]->vseg_offset = vseg_index;
     608    vspace[vspace_index]->vobj_offset = vobj_index;
    471609    vspace[vspace_index]->task_offset = task_index;
    472610   
    473611#if XML_PARSER_DEBUG
    474612printf("- vseg_offset = %d\n", vseg_index);
     613printf("- vobj_offset = %d\n", vobj_index);
    475614printf("- task_offset = %d\n", task_index);
    476615#endif
     
    492631    }
    493632
    494     /////////// get binpath attribute
    495     str = getStringValue(reader, "binpath", &ok);
    496     if ( ok )
    497     {
    498 #if XML_PARSER_DEBUG
    499 printf("    binpath = %s\n", str);
    500 #endif
    501         strncpy(vspace[vspace_index]->binpath, str, 63);
    502     }
    503     else
    504     {
    505         printf("[XML ERROR] illegal or missing <binpath> attribute for vspace %d",
     633    ////////// get funcs_entry attribute
     634    str = getStringValue(reader, "funcs", &ok);
     635    if ( ok )
     636    {
     637#if XML_PARSER_DEBUG
     638printf("    name = %s\n", str);
     639#endif
     640        //used after parsing all the vobjs
     641    }
     642    else
     643    {
     644        printf("[XML ERROR] illegal or missing <name> attribute for vspace %d",
    506645                 vspace_index);
    507646        exit(1);
    508     }
    509 
    510     ////////// get vsegs attribute
    511     value = getIntValue(reader,"vsegs",&ok);
    512     if ( ok )
    513     {
    514 #if XML_PARSER_DEBUG
    515 printf("    vsegs = %d\n", value);
    516 #endif
    517         vspace[vspace_index]->vsegs = value;
    518     }
    519     else
    520     {
    521         printf("[XML ERROR] illegal or missing <vsegs> attribute for vspace %d",
    522                  vspace_index);
    523         exit(1);
    524     }
    525 
    526     // get tasks attribute
    527     value = getIntValue(reader,"tasks", &ok);
    528     if ( ok )
    529     {
    530 #if XML_PARSER_DEBUG
    531 printf("    tasks = %d\n", value);
    532 #endif
    533         vspace[vspace_index]->tasks = value;
    534     }
    535     else
    536     {
    537         printf("[XML ERROR] illegal or missing <tasks> attribute for vspace %d",
    538                   vspace_index);
    539         exit(1);
    540     }
    541 
    542     // get mwmrs attribute
    543     value = getIntValue(reader,"mwmrs", &ok);
    544     if ( ok )
    545     {
    546 #if XML_PARSER_DEBUG
    547 printf("    mwmrs = %d\n", value);
    548 #endif
    549         vspace[vspace_index]->mwmrs = value;
    550     }
    551     else
    552     {
    553         vspace[vspace_index]->mwmrs = 0;
    554647    }
    555648
     
    580673        else if ( strcmp(tag,"vspace") == 0  )
    581674        {
    582             // checking source file consistency
    583             if ( vseg_loc_index != vspace[vspace_index]->vsegs )
     675            vspace[vspace_index]->vobjs = vobj_loc_vspace_index;
     676            vspace[vspace_index]->tasks = task_loc_index ;
     677            vspace[vspace_index]->vsegs = vseg_loc_index ;
     678            int index =  getVobjLocId( vspace_index, str );
     679            if(index == -1)
    584680            {
    585                 printf("[XML ERROR] Wrong number of vsegs in vspace %d\n", vspace_index);
    586                 exit(1);
     681                printf("Error funcs entry vobj not found %s\n",str);
     682                exit(-1);
    587683            }
    588             else if ( task_loc_index != vspace[vspace_index]->tasks )
    589             {
    590                 printf("[XML ERROR] Wrong number of tasks in vspace %d\n", vspace_index);
    591                 exit(1);
    592             }
    593             else if ( mwmr_loc_index != vspace[vspace_index]->mwmrs )
    594             {
    595                 printf("[XML ERROR] Wrong number of mwmrs in vspace %d\n", vspace_index);
    596                 exit(1);
    597             }
    598             else
    599             {
    600                 vseg_loc_index = 0;
    601                 task_loc_index = 0;
    602                 mwmr_loc_index = 0;
    603                 vspace_index++;
    604                 return;
    605             }
     684            vspace[vspace_index]->funcs_offset = index;
     685
     686            vspace_index++;
     687            return;
    606688        }
    607689        else
     
    898980            {
    899981                header->vsegs = vseg_index;
     982                header->vobjs = vobj_index;
    900983                header->tasks = task_index;
    901984                return;
     
    10331116    {
    10341117        printf("[XML ERROR] illegal or missing <globals> attribute in mapping_info_header\n");
    1035         exit(1);
    1036     }
    1037 
    1038     // get syspath attribute
    1039     name = getStringValue(reader, "syspath", &ok);
    1040     if ( ok )
    1041     {
    1042 #if XML_PARSER_DEBUG
    1043 printf("- syspath = %s\n\n", name);
    1044 #endif
    1045         strncpy( header->syspath, name, 63);
    1046     }     
    1047     else
    1048     {
    1049         printf("[XML ERROR] illegal or missing <syspath> attribute in header\n");
    10501118        exit(1);
    10511119    }
     
    10861154    unsigned int    vspace_id;
    10871155    unsigned int    vseg_id;
     1156    unsigned int    vobj_id;
    10881157    unsigned int    task_id;
    10891158
     
    11421211#if XML_PARSER_DEBUG
    11431212printf("write vspace %d\n", vspace_id);
     1213printf("vspace->vobj_offset: %d\n", vspace[vspace_id]->vobj_offset);
     1214printf("vspace->vobjs: %d\n", vspace[vspace_id]->vobjs);
     1215printf("header->vobjs: %d\n", header->vobjs);
    11441216#endif
    11451217
     
    11631235        {
    11641236            perror("write vseg");
     1237            exit(1);
     1238        }
     1239    }
     1240   
     1241    // write vobjs
     1242    for ( vobj_id = 0 ; vobj_id < header->vobjs ; vobj_id++ )
     1243    {
     1244        length = write(fdout, (char*)vobj[vobj_id], sizeof(mapping_vobj_t));
     1245   
     1246#if XML_PARSER_DEBUG
     1247printf("write vobj %d\n", vobj_id);
     1248printf("write vobj name %s\n", vobj[vobj_id]->name);
     1249printf("write vobj length %x\n", vobj[vobj_id]->length);
     1250printf("write vobj type %d\n", vobj[vobj_id]->type);
     1251#endif
     1252
     1253        if ( length != sizeof(mapping_vobj_t) )
     1254        {
     1255            perror("write vobj");
    11651256            exit(1);
    11661257        }
Note: See TracChangeset for help on using the changeset viewer.