source: trunk/kernel/syscalls/shared_include/shared_almos.h @ 671

Last change on this file since 671 was 670, checked in by alain, 4 years ago

1) Introduce up to 4 command lines arguments in the KSH "load" command.
These arguments are transfered to the user process through the
argc/argv mechanism, using the user space "args" vseg.

2) Introduce the named and anonymous "pipes", for inter-process communication
through the pipe() and mkfifo() syscalls.

3) Introduce the "chat" application to validate the two above mechanisms.

4) Improve printk() and assert() fonctions in printk.c.

File size: 4.5 KB
Line 
1/*
2 * shared_almos.h - Shared mnemonics used by the almos-mkh specific syscalls.
3 *
4 * Author  Alain Greiner (2016,2017,2018)
5 *
6 * Copyright (c) UPMC Sorbonne Universites
7 *
8 * This file is part of ALMOS-MKH.
9 *
10 * ALMOS-MKH is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; version 2.0 of the License.
13 *
14 * ALMOS-MKH is distributed in the hope that it will be useful, but
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
17 * General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with ALMOS-MKH; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22 */
23
24#ifndef _SHARED_ALMOS_H_
25#define _SHARED_ALMOS_H_
26
27/*******************************************************************************************
28 * This enum defines the operation mnemonics for the utls() syscall (Thread Local Storage).
29 ******************************************************************************************/
30
31typedef enum
32{
33    UTLS_SET       = 1,
34    UTLS_GET       = 2,
35    UTLS_GET_ERRNO = 3,
36}
37utls_operation_t;
38
39/*******************************************************************************************
40 * This enum defines the type of structure for the display() syscall.
41 ******************************************************************************************/
42
43typedef enum
44{
45    DISPLAY_STRING            = 0,
46    DISPLAY_VMM               = 1,
47    DISPLAY_SCHED             = 2,
48    DISPLAY_CLUSTER_PROCESSES = 3,
49    DISPLAY_VFS               = 4,
50    DISPLAY_CHDEV             = 5,
51    DISPLAY_TXT_PROCESSES     = 6,
52    DISPLAY_DQDT              = 7,
53    DISPLAY_BUSYLOCKS         = 8,
54    DISPLAY_MAPPER            = 9,
55    DISPLAY_BARRIER           = 10,
56    DISPLAY_FAT               = 11,
57    DISPLAY_SOCKET            = 12,
58    DISPLAY_FD                = 13,
59    DISPLAY_WINDOWS           = 14,
60}
61display_type_t;
62
63/*******************************************************************************************
64 * This structure defines the - user accessible - information stored in a thread.
65 ******************************************************************************************/
66
67typedef struct thread_info_s
68{
69        unsigned long      false_pgfault_nr;     /*! number of local page fault               */
70    unsigned long      false_pgfault_cost;   /*! cumulated cost                           */
71    unsigned long      false_pgfault_max;    /*! max cost of a local page fault           */
72
73        unsigned long      local_pgfault_nr;     /*! number of local page fault               */
74    unsigned long      local_pgfault_cost;   /*! cumulated cost                           */
75    unsigned long      local_pgfault_max;    /*! max cost of a false page fault           */
76
77        unsigned long      global_pgfault_nr;    /*! number of global page fault              */
78    unsigned long      global_pgfault_cost;  /*! cumulated cost                           */
79    unsigned long      global_pgfault_max;   /*! max cost of a global page fault          */
80
81        unsigned long long last_cycle;           /*! last cycle counter value (date)          */
82        unsigned long long usr_cycles;           /*! user execution duration (cycles)         */
83        unsigned long long sys_cycles;           /*! system execution duration (cycles)       */
84}
85thread_info_t;
86
87/*******************************************************************************************
88 * This structure defines the - user accessible - global hardware configuration.
89 * It is used by the get_config() syscall.
90 ******************************************************************************************/
91
92typedef struct hard_config_s
93{
94    unsigned int      x_size;                /*! number of clusters in a row              */
95    unsigned int      y_size;                /*! number of clusters in a column           */
96    unsigned int      ncores;                /*! max number of cores per cluster          */
97   
98    unsigned int      txt_channels;          /*! number of TXT channels                   */
99    unsigned int      nic_channels;          /*! number of NIC channels                   */
100    unsigned int      ioc_channels;          /*! number of IOC channels                   */
101    unsigned int      fbf_channels;          /*! number of FBF channels                   */
102}
103hard_config_t;
104
105
106#endif /* _SHARED_ALMOS_H_ */
107
Note: See TracBrowser for help on using the repository browser.