source: soft/giet_vm/giet_common/utils.h @ 347

Last change on this file since 347 was 345, checked in by cfuguet, 11 years ago

giet_vm optimizations:

  • Several modifications in GIET_VM in order to support compilation with GCC optimizations (-O2) activated.
  • Adding missing volatile in some global variables.
  • Using ioread and iowrite utility functions in peripheral drivers which prevent GCC to remove writes or reads in hardware memory mapped registers.
  • Code refactoring of stdio printf functions. Now, shr_printf and tty_printf function reuse the same function body. The only difference is that shr_printf wraps printf function call with TTY get lock and release lock.
  • Property svn:executable set to *
File size: 8.3 KB
Line 
1///////////////////////////////////////////////////////////////////////////////////
2// File     : utils.h
3// Date     : 18/10/2013
4// Author   : alain greiner
5// Copyright (c) UPMC-LIP6
6///////////////////////////////////////////////////////////////////////////////////
7// The utils.c and utils.h files are part of the GIET-VM nano-kernel.
8// They define more or less the GIET-VM HAL (Hardware Abstraction Layer),
9// and contains various utility functions, that can be used by both the
10// boot code and the kernel code.
11///////////////////////////////////////////////////////////////////////////////////
12
13#ifndef GIET_UTILS_H
14#define GIET_UTILS_H
15
16#include <mapping_info.h>
17#include <giet_config.h>
18
19//////////////////////////////////////////////////////////////////////////////////
20// NULL pointer definition
21//////////////////////////////////////////////////////////////////////////////////
22
23#define NULL (void *)0
24
25///////////////////////////////////////////////////////////////////////////////////
26// For retrieving base addresses defined in seg.ld file.
27///////////////////////////////////////////////////////////////////////////////////
28
29typedef struct _ld_symbol_s _ld_symbol_t;
30
31// boot segments vbase addresses & sizes
32extern _ld_symbol_t boot_code_vbase;
33extern _ld_symbol_t boot_code_size;
34
35extern _ld_symbol_t boot_data_vbase;
36extern _ld_symbol_t boot_data_size;
37
38extern _ld_symbol_t boot_stack_vbase;
39extern _ld_symbol_t boot_stack_size;
40
41extern _ld_symbol_t boot_mapping_vbase;
42extern _ld_symbol_t boot_mapping_size;
43
44extern _ld_symbol_t boot_buffer_vbase;
45extern _ld_symbol_t boot_buffer_size;
46
47// kernel segments vbase addresses & sizes
48extern _ld_symbol_t kernel_code_vbase;
49extern _ld_symbol_t kernel_code_size;
50
51extern _ld_symbol_t kernel_data_vbase;
52extern _ld_symbol_t kernel_data_size;
53
54extern _ld_symbol_t kernel_uncdata_vbase;
55extern _ld_symbol_t kernel_uncdata_size;
56
57extern _ld_symbol_t kernel_init_vbase;
58extern _ld_symbol_t kernel_init_size;
59
60///////////////////////////////////////////////////////////////////////////////////
61//     Memory handling functions
62///////////////////////////////////////////////////////////////////////////////////
63
64extern void* memcpy( void* _dst, 
65                     const void* _src, 
66                     unsigned int size );
67
68extern void* memset( void* dst, 
69                     int s, 
70                     unsigned int count );
71
72///////////////////////////////////////////////////////////////////////////////////
73//     Break function
74///////////////////////////////////////////////////////////////////////////////////
75
76extern void _break( char* str);
77
78///////////////////////////////////////////////////////////////////////////////////
79//     Suicide function
80///////////////////////////////////////////////////////////////////////////////////
81
82extern void _exit(void);
83
84///////////////////////////////////////////////////////////////////////////////////
85//     Eret function
86///////////////////////////////////////////////////////////////////////////////////
87
88extern void _eret(void);
89
90///////////////////////////////////////////////////////////////////////////////////
91//     CP0 and CP2 registers access functions
92///////////////////////////////////////////////////////////////////////////////////
93
94extern unsigned int _get_sched(void);
95extern unsigned int _get_mmu_ptpr(void);
96extern unsigned int _get_mmu_mode(void);
97extern unsigned int _get_epc(void);
98extern unsigned int _get_bvar(void);
99extern unsigned int _get_cr(void);
100extern unsigned int _get_sr(void);
101extern unsigned int _get_procid(void);
102extern unsigned int _get_proctime(void);
103extern unsigned int _get_current_task_id(void);
104
105extern void         _it_disable( unsigned int* save_sr_ptr );
106extern void         _it_enable(void);
107extern void         _it_restore( unsigned int* save_sr_ptr );
108
109extern void         _set_mmu_ptpr(unsigned int value);
110extern void         _set_mmu_mode(unsigned int value);
111extern void         _set_sched(unsigned int value);
112extern void         _set_sr(unsigned int value);
113
114///////////////////////////////////////////////////////////////////////////////////
115//     Physical addressing related functions
116///////////////////////////////////////////////////////////////////////////////////
117
118extern unsigned int _physical_read(  unsigned long long paddr );
119
120extern void         _physical_write( unsigned long long paddr,
121                                     unsigned int       value );
122
123extern void         _physical_memcpy( unsigned long long dst_paddr,
124                                      unsigned long long src_paddr,
125                                      unsigned int       size );
126
127extern unsigned int _io_extended_read(  unsigned int* vaddr );
128
129extern void         _io_extended_write( unsigned int* vaddr,
130                                        unsigned int  value );
131
132///////////////////////////////////////////////////////////////////////////////////
133//     Locks access functions
134///////////////////////////////////////////////////////////////////////////////////
135
136extern void         _get_lock(unsigned int * lock);
137extern void         _release_lock(unsigned int * lock);
138
139///////////////////////////////////////////////////////////////////////////////////
140//     TTY0 access functions
141///////////////////////////////////////////////////////////////////////////////////
142
143extern void         _puts( char*        string );
144
145extern void         _putx( unsigned int val );
146
147extern void         _putd( unsigned int val ); 
148
149extern void         _putl( unsigned long long val );
150
151extern void         _printf(char* format, ...); 
152
153extern void         _getc( char*        byte );       
154
155///////////////////////////////////////////////////////////////////////////////////
156//     string compare functions
157///////////////////////////////////////////////////////////////////////////////////
158
159extern unsigned int _strncmp(const char*  s1, 
160                             const char*  s2, 
161                             unsigned int n);
162
163extern char*        _strcpy( char*        dest,
164                             char*        source );
165
166///////////////////////////////////////////////////////////////////////////////////
167//     cache invalidate function
168///////////////////////////////////////////////////////////////////////////////////
169
170extern void  _dcache_buf_invalidate( void * buffer, 
171                                     unsigned int size );
172
173///////////////////////////////////////////////////////////////////////////////////
174//     Schedulers access functions
175///////////////////////////////////////////////////////////////////////////////////
176
177extern unsigned int _get_task_slot( unsigned int gpid,
178                                    unsigned int ltid,
179                                    unsigned int slot );
180
181extern void         _set_task_slot( unsigned int gpid,
182                                    unsigned int ltid,
183                                    unsigned int slot,
184                                    unsigned int value );
185
186extern unsigned int _get_context_slot( unsigned int slot );
187
188extern void         _set_context_slot( unsigned int slot,
189                                       unsigned int value );
190
191extern unsigned int _heap_info( unsigned int* vaddr,
192                                unsigned int* size );
193
194///////////////////////////////////////////////////////////////////////////////////
195//     Mapping access functions
196///////////////////////////////////////////////////////////////////////////////////
197
198extern mapping_cluster_t *  _get_cluster_base(mapping_header_t* header);
199extern mapping_pseg_t *     _get_pseg_base(mapping_header_t* header);
200extern mapping_vspace_t *   _get_vspace_base(mapping_header_t* header);
201extern mapping_vseg_t *     _get_vseg_base(mapping_header_t* header);
202extern mapping_vobj_t *     _get_vobj_base(mapping_header_t* header);
203extern mapping_task_t *     _get_task_base(mapping_header_t* header);
204extern mapping_proc_t *     _get_proc_base(mapping_header_t* header);
205extern mapping_irq_t *      _get_irq_base(mapping_header_t* header);
206extern mapping_coproc_t *   _get_coproc_base(mapping_header_t* header);
207extern mapping_cp_port_t *  _get_cp_port_base(mapping_header_t* header);
208extern mapping_periph_t *   _get_periph_base(mapping_header_t* header);
209
210#endif
211
212// Local Variables:
213// tab-width: 4
214// c-basic-offset: 4
215// c-file-offsets:((innamespace . 0)(inline-open . 0))
216// indent-tabs-mode: nil
217// End:
218// vim: filetype=c:expandtab:shiftwidth=4:tabstop=4:softtabstop=4
219
Note: See TracBrowser for help on using the repository browser.