source: trunk/softs/giet_tsar/stdio.h @ 670

Last change on this file since 670 was 629, checked in by alain, 11 years ago
  • Updatre the gier_tsar to support the vci_iopic component in the tsar_generic_leti plat-form.
  • Modify the soft_transpose_giet application to make optional the graphic display on frame buffer and to introduce a systematic auto-check
File size: 4.9 KB
RevLine 
[622]1////////////////////////////////////////////////////////////////////////////////////////
2// File : stdio.h
3// Written by Alain Greiner
4// Date : 17/01/2014
5//
6// This file define varions functions that can be used by applications to access
7// peripherals, or other ressources such as processor registers, spin_locks
8// or synchronisation barriers.
9// It is dedicated for the TSAR multi-processors multi_clusters architecture.
10// There is NO separation between application code and system code.
11// This basic GIET does not use the virtual memory, and does nort support multi-tasking.
12//
13//The supported peripherals are:
14//- the SoClib multi_tty
15//- The SoCLib frame_buffer
16//- The SoCLib block_device
17//
18//The following parameters must be defined in the hard_config.h file.
19//- X_SIZE          : number of clusters in a row
20//- Y_SIZE          : number of clusters in a column
21//- X_WIDTH         : number of bits for X field in proc_id
22//- Y_WIDTH         : number of bits for Y field in proc_id
23//- NB_PROCS_MAX    : max number of processor per cluster
24//- NB_TTY_CHANNELS : max number of TTY channels
25//
26//The follobing base addresses must be defined in the ldscript
27//- seg_tty_base
28//- seg_fbf_base
29//- seg_ioc_base
30////////////////////////////////////////////////////////////////////////////////////////
[158]31
[622]32#ifndef _GIET_STDIO_H_
33#define _GIET_STDIO_H_
[158]34
[622]35#include "tty.h"
36#include "block_device.h"
37#include "hard_config.h"
38#include <stdarg.h>
[158]39
[622]40typedef unsigned int    size_t;
[158]41
[622]42// global variables defined in stdio.c
[158]43
[622]44extern  int volatile    _ioc_lock;
45extern  int volatile    _ioc_done;
46extern  int volatile    _ioc_status;
[158]47
[622]48extern  char volatile   _tty_get_buf[];
49extern  int volatile    _tty_get_full[];
[158]50
[622]51extern int volatile     _barrier_value[];
52extern int volatile     _barrier_count[];
53extern int volatile     _barrier_lock[];
[158]54
[622]55extern int volatile     _spin_lock[];
[158]56
[622]57// functions defined in stdio.c
[158]58
[622]59void*           _memcpy( void* dst, const void* src, size_t size );
[158]60
[629]61void            _extended_memcpy( unsigned int dst_cluster,
62                                  unsigned int dst_address,
63                                  unsigned int src_cluster,
64                                  unsigned int src_address,
65                                  unsigned int length );
[622]66unsigned int    _procid();
67unsigned int    _proctime();
68unsigned int    _procnumber();
[158]69
[626]70unsigned int    _rand();
71
[622]72void            _it_mask();
73void            _it_enable();
[158]74
[622]75void            _dcache_buf_invalidate( const void* buffer, size_t size );
[158]76
[622]77void            _exit();
[158]78
[622]79void            _itoa_dec( unsigned int val, char* buf );
80void            _itoa_hex( unsigned int val, char* buf );
81
82int             _tty_write( char* buffer, size_t length, size_t channel );
83int             _tty_read( char* buffer, size_t channel );
84void            _tty_puts( char* string );
85void            _tty_putd( unsigned int val );
86void            _tty_putx( unsigned int val );
87void            _tty_get_lock( size_t channel );
88void            _tty_release_lock( size_t channel );
89void            _tty_getc( char* buffer );
90void            _tty_getw( unsigned int* buffer );
91void            _tty_printf( char* format, ... );
[629]92void            _tty_isr();
[622]93
94void            _ioc_get_lock();
95void            _ioc_write( size_t lba, void* buffer, size_t count, size_t ext );
96void            _ioc_read (size_t lba, void* buffer, size_t count, size_t ext );
97void            _ioc_completed();
98void            _ioc_isr();
99
100void            _mmc_isr();
101
[629]102void            _fb_sync_write( unsigned int offset, 
103                                unsigned int buffer,
104                                unsigned int length,
105                                unsigned int ext );
106void            _fb_sync_read(  unsigned int offset, 
107                                unsigned int buffer,
108                                unsigned int length,
109                                unsigned int ext );
[622]110
111void            _release_lock( size_t lock_index );
112void            _get_lock( size_t lock_index );
113
114void            _barrier_init(size_t index, size_t count);
115void            _barrier_wait(size_t index);
116
[629]117unsigned char   _byte_extended_read(  unsigned int   cluster, 
118                                      unsigned int   address );
119unsigned int    _word_extended_read(  unsigned int   cluster, 
120                                      unsigned int   address );
121void            _word_extended_write( unsigned int   cluster, 
122                                      unsigned int   address, 
123                                      unsigned int   word );
124void            _byte_extended_write( unsigned int   cluster, 
125                                      unsigned int   address, 
126                                      unsigned char  byte );
[158]127#endif
128
129// Local Variables:
130// tab-width: 4;
131// c-basic-offset: 4;
132// c-file-offsets:((innamespace . 0)(inline-open . 0));
133// indent-tabs-mode: nil;
134// End:
135//
136// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=4:softtabstop=4
137
Note: See TracBrowser for help on using the repository browser.