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

Last change on this file since 623 was 622, checked in by alain, 11 years ago

Introducing a minimal GIET:

  • no virtual memory
  • no conyext switch
  • no system calls
File size: 3.7 KB
Line 
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////////////////////////////////////////////////////////////////////////////////////////
31
32#ifndef _GIET_STDIO_H_
33#define _GIET_STDIO_H_
34
35#include "tty.h"
36#include "block_device.h"
37#include "hard_config.h"
38#include <stdarg.h>
39
40typedef unsigned int    size_t;
41
42// global variables defined in stdio.c
43
44extern  int volatile    _ioc_lock;
45extern  int volatile    _ioc_done;
46extern  int volatile    _ioc_status;
47
48extern  char volatile   _tty_get_buf[];
49extern  int volatile    _tty_get_full[];
50
51extern int volatile     _barrier_value[];
52extern int volatile     _barrier_count[];
53extern int volatile     _barrier_lock[];
54
55extern int volatile     _spin_lock[];
56
57// functions defined in stdio.c
58
59void*           _memcpy( void* dst, const void* src, size_t size );
60
61unsigned int    _procid();
62unsigned int    _proctime();
63unsigned int    _procnumber();
64
65void            _it_mask();
66void            _it_enable();
67
68void            _dcache_buf_invalidate( const void* buffer, size_t size );
69
70void            _exit();
71
72void            _itoa_dec( unsigned int val, char* buf );
73void            _itoa_hex( unsigned int val, char* buf );
74
75int             _tty_write( char* buffer, size_t length, size_t channel );
76int             _tty_read( char* buffer, size_t channel );
77void            _tty_puts( char* string );
78void            _tty_putd( unsigned int val );
79void            _tty_putx( unsigned int val );
80void            _tty_get_lock( size_t channel );
81void            _tty_release_lock( size_t channel );
82void            _tty_getc( char* buffer );
83void            _tty_getw( unsigned int* buffer );
84void            _tty_printf( char* format, ... );
85
86void            _ioc_get_lock();
87void            _ioc_write( size_t lba, void* buffer, size_t count, size_t ext );
88void            _ioc_read (size_t lba, void* buffer, size_t count, size_t ext );
89void            _ioc_completed();
90void            _ioc_isr();
91
92void            _mmc_isr();
93
94void            _fb_sync_write( size_t offset, void* buffer, size_t length, size_t ext );
95void            _fb_sync_read( size_t offset, void* buffer, size_t length, size_t ext );
96
97void            _release_lock( size_t lock_index );
98void            _get_lock( size_t lock_index );
99
100void            _barrier_init(size_t index, size_t count);
101void            _barrier_wait(size_t index);
102
103#endif
104
105// Local Variables:
106// tab-width: 4;
107// c-basic-offset: 4;
108// c-file-offsets:((innamespace . 0)(inline-open . 0));
109// indent-tabs-mode: nil;
110// End:
111//
112// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=4:softtabstop=4
113
Note: See TracBrowser for help on using the repository browser.