1 /* The kernel call implemented in this file:
4 * The parameters for this kernel call are:
5 * m1_i3: I_REQUEST (what info to get)
6 * m1_p1: I_VAL_PTR (where to put it)
7 * m1_i1: I_VAL_LEN (maximum length expected, optional)
8 * m1_p2: I_VAL_PTR2 (second, optional pointer)
9 * m1_i2: I_VAL_LEN2_E (second length or process nr)
13 #include <minix/endpoint.h>
15 #include "kernel/system.h"
20 /*===========================================================================*
22 *===========================================================================*/
23 PUBLIC
int do_getinfo(struct proc
* caller
, message
* m_ptr
)
25 /* Request system information to be copied to caller's address space. This
26 * call simply copies entire data structures to the caller.
31 int wipe_rnd_bin
= -1;
34 /* Set source address and length based on request type. */
35 switch (m_ptr
->I_REQUEST
) {
37 length
= sizeof(struct machine
);
38 src_vir
= (vir_bytes
) &machine
;
42 length
= sizeof(struct kinfo
);
43 src_vir
= (vir_bytes
) &kinfo
;
47 length
= sizeof(struct loadinfo
);
48 src_vir
= (vir_bytes
) &kloadinfo
;
52 length
= sizeof(system_hz
);
53 src_vir
= (vir_bytes
) &system_hz
;
57 length
= sizeof(struct boot_image
) * NR_BOOT_PROCS
;
58 src_vir
= (vir_bytes
) image
;
62 length
= sizeof(struct irq_hook
) * NR_IRQ_HOOKS
;
63 src_vir
= (vir_bytes
) irq_hooks
;
67 length
= sizeof(struct proc
) * (NR_PROCS
+ NR_TASKS
);
68 src_vir
= (vir_bytes
) proc
;
72 length
= sizeof(struct priv
) * (NR_SYS_PROCS
);
73 src_vir
= (vir_bytes
) priv
;
77 nr_e
= (m_ptr
->I_VAL_LEN2_E
== SELF
) ?
78 caller
->p_endpoint
: m_ptr
->I_VAL_LEN2_E
;
79 if(!isokendpt(nr_e
, &nr
)) return EINVAL
; /* validate request */
80 length
= sizeof(struct proc
);
81 src_vir
= (vir_bytes
) proc_addr(nr
);
85 nr_e
= (m_ptr
->I_VAL_LEN2_E
== SELF
) ?
86 caller
->p_endpoint
: m_ptr
->I_VAL_LEN2_E
;
87 if(!isokendpt(nr_e
, &nr
)) return EINVAL
; /* validate request */
88 length
= sizeof(struct priv
);
89 src_vir
= (vir_bytes
) priv_addr(nr_to_id(nr
));
94 /* GET_WHOAMI uses m3 and only uses the message contents for info. */
95 m_ptr
->GIWHO_EP
= caller
->p_endpoint
;
96 len
= MIN(sizeof(m_ptr
->GIWHO_NAME
), sizeof(caller
->p_name
))-1;
97 strncpy(m_ptr
->GIWHO_NAME
, caller
->p_name
, len
);
98 m_ptr
->GIWHO_NAME
[len
] = '\0';
101 case GET_MONPARAMS
: {
102 src_vir
= (vir_bytes
) params_buffer
;
103 length
= sizeof(params_buffer
);
106 case GET_RANDOMNESS
: {
107 static struct k_randomness copy
; /* copy to keep counters */
111 for (i
= 0; i
<RANDOM_SOURCES
; i
++) {
112 krandom
.bin
[i
].r_size
= 0; /* invalidate random data */
113 krandom
.bin
[i
].r_next
= 0;
115 length
= sizeof(copy
);
116 src_vir
= (vir_bytes
) ©
;
119 case GET_RANDOMNESS_BIN
: {
120 int bin
= m_ptr
->I_VAL_LEN2_E
;
122 if(bin
< 0 || bin
>= RANDOM_SOURCES
) {
123 printf("SYSTEM: GET_RANDOMNESS_BIN: %d out of range\n", bin
);
127 if(krandom
.bin
[bin
].r_size
< RANDOM_ELEMENTS
)
130 length
= sizeof(krandom
.bin
[bin
]);
131 src_vir
= (vir_bytes
) &krandom
.bin
[bin
];
137 case GET_KMESSAGES
: {
138 length
= sizeof(struct kmessages
);
139 src_vir
= (vir_bytes
) &kmess
;
143 case GET_LOCKTIMING
: {
144 length
= sizeof(timingdata
);
145 src_vir
= (vir_bytes
) timingdata
;
149 case GET_IRQACTIDS
: {
150 length
= sizeof(irq_actids
);
151 src_vir
= (vir_bytes
) irq_actids
;
157 idl
= proc_addr(IDLE
);
158 length
= sizeof(idl
->p_cycles
);
159 src_vir
= (vir_bytes
) &idl
->p_cycles
;
162 case GET_AOUTHEADER
: {
163 int hdrindex
, index
= m_ptr
->I_VAL_LEN2_E
;
164 if(index
< 0 || index
>= NR_BOOT_PROCS
) {
167 if (iskerneln(_ENDPOINT_P(image
[index
].endpoint
))) {
170 hdrindex
= 1 + index
-NR_TASKS
;
172 arch_get_aout_headers(hdrindex
, &e_hdr
);
173 length
= sizeof(e_hdr
);
174 src_vir
= (vir_bytes
) &e_hdr
;
179 printf("do_getinfo: invalid request %d\n", m_ptr
->I_REQUEST
);
183 /* Try to make the actual copy for the requested data. */
184 if (m_ptr
->I_VAL_LEN
> 0 && length
> m_ptr
->I_VAL_LEN
) return (E2BIG
);
185 r
= data_copy_vmcheck(caller
, KERNEL
, src_vir
, caller
->p_endpoint
,
186 (vir_bytes
) m_ptr
->I_VAL_PTR
, length
);
188 if(r
!= OK
) return r
;
190 if(wipe_rnd_bin
>= 0 && wipe_rnd_bin
< RANDOM_SOURCES
) {
191 krandom
.bin
[wipe_rnd_bin
].r_size
= 0;
192 krandom
.bin
[wipe_rnd_bin
].r_next
= 0;
198 #endif /* USE_GETINFO */