~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/samples/bpf/Makefile

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /samples/bpf/Makefile (Version linux-6.12-rc7) and /samples/bpf/Makefile (Version ccs-tools-1.8.12)


  1 # SPDX-License-Identifier: GPL-2.0                
  2                                                   
  3 BPF_SAMPLES_PATH ?= $(abspath $(src))             
  4 TOOLS_PATH := $(BPF_SAMPLES_PATH)/../../tools     
  5                                                   
  6 pound := \#                                       
  7                                                   
  8 # List of programs to build                       
  9 tprogs-y := test_lru_dist                         
 10 tprogs-y += sock_example                          
 11 tprogs-y += fds_example                           
 12 tprogs-y += sockex1                               
 13 tprogs-y += sockex2                               
 14 tprogs-y += sockex3                               
 15 tprogs-y += tracex1                               
 16 tprogs-y += tracex3                               
 17 tprogs-y += tracex4                               
 18 tprogs-y += tracex5                               
 19 tprogs-y += tracex6                               
 20 tprogs-y += tracex7                               
 21 tprogs-y += test_probe_write_user                 
 22 tprogs-y += trace_output                          
 23 tprogs-y += lathist                               
 24 tprogs-y += offwaketime                           
 25 tprogs-y += spintest                              
 26 tprogs-y += map_perf_test                         
 27 tprogs-y += test_overhead                         
 28 tprogs-y += test_cgrp2_array_pin                  
 29 tprogs-y += test_cgrp2_attach                     
 30 tprogs-y += test_cgrp2_sock                       
 31 tprogs-y += test_cgrp2_sock2                      
 32 tprogs-y += xdp_router_ipv4                       
 33 tprogs-y += test_current_task_under_cgroup        
 34 tprogs-y += trace_event                           
 35 tprogs-y += sampleip                              
 36 tprogs-y += tc_l2_redirect                        
 37 tprogs-y += lwt_len_hist                          
 38 tprogs-y += xdp_tx_iptunnel                       
 39 tprogs-y += test_map_in_map                       
 40 tprogs-y += per_socket_stats_example              
 41 tprogs-y += syscall_tp                            
 42 tprogs-y += cpustat                               
 43 tprogs-y += xdp_adjust_tail                       
 44 tprogs-y += xdp_fwd                               
 45 tprogs-y += task_fd_query                         
 46 tprogs-y += ibumad                                
 47 tprogs-y += hbm                                   
 48                                                   
 49 # Libbpf dependencies                             
 50 LIBBPF_SRC = $(TOOLS_PATH)/lib/bpf                
 51 LIBBPF_OUTPUT = $(abspath $(BPF_SAMPLES_PATH))    
 52 LIBBPF_DESTDIR = $(LIBBPF_OUTPUT)                 
 53 LIBBPF_INCLUDE = $(LIBBPF_DESTDIR)/include        
 54 LIBBPF = $(LIBBPF_OUTPUT)/libbpf.a                
 55                                                   
 56 CGROUP_HELPERS := ../../tools/testing/selftest    
 57 TRACE_HELPERS := ../../tools/testing/selftests    
 58 XDP_SAMPLE := xdp_sample_user.o                   
 59                                                   
 60 fds_example-objs := fds_example.o                 
 61 sockex1-objs := sockex1_user.o                    
 62 sockex2-objs := sockex2_user.o                    
 63 sockex3-objs := sockex3_user.o                    
 64 tracex1-objs := tracex1_user.o $(TRACE_HELPERS    
 65 tracex3-objs := tracex3_user.o                    
 66 tracex4-objs := tracex4_user.o                    
 67 tracex5-objs := tracex5_user.o $(TRACE_HELPERS    
 68 tracex6-objs := tracex6_user.o                    
 69 tracex7-objs := tracex7_user.o                    
 70 test_probe_write_user-objs := test_probe_write    
 71 trace_output-objs := trace_output_user.o          
 72 lathist-objs := lathist_user.o                    
 73 offwaketime-objs := offwaketime_user.o $(TRACE    
 74 spintest-objs := spintest_user.o $(TRACE_HELPE    
 75 map_perf_test-objs := map_perf_test_user.o        
 76 test_overhead-objs := test_overhead_user.o        
 77 test_cgrp2_array_pin-objs := test_cgrp2_array_    
 78 test_cgrp2_attach-objs := test_cgrp2_attach.o     
 79 test_cgrp2_sock-objs := test_cgrp2_sock.o         
 80 test_cgrp2_sock2-objs := test_cgrp2_sock2.o       
 81 test_current_task_under_cgroup-objs := $(CGROU    
 82                                        test_cu    
 83 trace_event-objs := trace_event_user.o $(TRACE    
 84 sampleip-objs := sampleip_user.o $(TRACE_HELPE    
 85 tc_l2_redirect-objs := tc_l2_redirect_user.o      
 86 lwt_len_hist-objs := lwt_len_hist_user.o          
 87 xdp_tx_iptunnel-objs := xdp_tx_iptunnel_user.o    
 88 test_map_in_map-objs := test_map_in_map_user.o    
 89 per_socket_stats_example-objs := cookie_uid_he    
 90 syscall_tp-objs := syscall_tp_user.o              
 91 cpustat-objs := cpustat_user.o                    
 92 xdp_adjust_tail-objs := xdp_adjust_tail_user.o    
 93 xdp_fwd-objs := xdp_fwd_user.o                    
 94 task_fd_query-objs := task_fd_query_user.o $(T    
 95 ibumad-objs := ibumad_user.o                      
 96 hbm-objs := hbm.o $(CGROUP_HELPERS)               
 97                                                   
 98 xdp_router_ipv4-objs := xdp_router_ipv4_user.o    
 99                                                   
100 # Tell kbuild to always build the programs        
101 always-y := $(tprogs-y)                           
102 always-y += sockex1_kern.o                        
103 always-y += sockex2_kern.o                        
104 always-y += sockex3_kern.o                        
105 always-y += tracex1.bpf.o                         
106 always-y += tracex3.bpf.o                         
107 always-y += tracex4.bpf.o                         
108 always-y += tracex5.bpf.o                         
109 always-y += tracex6.bpf.o                         
110 always-y += tracex7.bpf.o                         
111 always-y += sock_flags.bpf.o                      
112 always-y += test_probe_write_user.bpf.o           
113 always-y += trace_output.bpf.o                    
114 always-y += tcbpf1_kern.o                         
115 always-y += tc_l2_redirect_kern.o                 
116 always-y += lathist_kern.o                        
117 always-y += offwaketime.bpf.o                     
118 always-y += spintest.bpf.o                        
119 always-y += map_perf_test.bpf.o                   
120 always-y += test_overhead_tp.bpf.o                
121 always-y += test_overhead_raw_tp.bpf.o            
122 always-y += test_overhead_kprobe.bpf.o            
123 always-y += parse_varlen.o parse_simple.o pars    
124 always-y += test_cgrp2_tc.bpf.o                   
125 always-y += test_current_task_under_cgroup.bpf    
126 always-y += trace_event_kern.o                    
127 always-y += sampleip_kern.o                       
128 always-y += lwt_len_hist.bpf.o                    
129 always-y += xdp_tx_iptunnel_kern.o                
130 always-y += test_map_in_map.bpf.o                 
131 always-y += tcp_synrto_kern.o                     
132 always-y += tcp_rwnd_kern.o                       
133 always-y += tcp_bufs_kern.o                       
134 always-y += tcp_cong_kern.o                       
135 always-y += tcp_iw_kern.o                         
136 always-y += tcp_clamp_kern.o                      
137 always-y += tcp_basertt_kern.o                    
138 always-y += tcp_tos_reflect_kern.o                
139 always-y += tcp_dumpstats_kern.o                  
140 always-y += xdp2skb_meta_kern.o                   
141 always-y += syscall_tp_kern.o                     
142 always-y += cpustat_kern.o                        
143 always-y += xdp_adjust_tail_kern.o                
144 always-y += xdp_fwd_kern.o                        
145 always-y += task_fd_query_kern.o                  
146 always-y += ibumad_kern.o                         
147 always-y += hbm_out_kern.o                        
148 always-y += hbm_edt_kern.o                        
149                                                   
150 TPROGS_CFLAGS = $(TPROGS_USER_CFLAGS)             
151 TPROGS_LDFLAGS = $(TPROGS_USER_LDFLAGS)           
152                                                   
153 ifeq ($(ARCH), arm)                               
154 # Strip all except -D__LINUX_ARM_ARCH__ option    
155 # headers when arm instruction set identificat    
156 ARM_ARCH_SELECTOR := $(filter -D__LINUX_ARM_AR    
157 BPF_EXTRA_CFLAGS := $(ARM_ARCH_SELECTOR)          
158 TPROGS_CFLAGS += $(ARM_ARCH_SELECTOR)             
159 endif                                             
160                                                   
161 ifeq ($(ARCH), mips)                              
162 TPROGS_CFLAGS += -D__SANE_USERSPACE_TYPES__       
163 ifdef CONFIG_MACH_LOONGSON64                      
164 BPF_EXTRA_CFLAGS += -I$(srctree)/arch/mips/inc    
165 BPF_EXTRA_CFLAGS += -I$(srctree)/arch/mips/inc    
166 endif                                             
167 endif                                             
168                                                   
169 ifeq ($(ARCH), x86)                               
170 BPF_EXTRA_CFLAGS += -fcf-protection               
171 endif                                             
172                                                   
173 TPROGS_CFLAGS += -Wall -O2                        
174 TPROGS_CFLAGS += -Wmissing-prototypes             
175 TPROGS_CFLAGS += -Wstrict-prototypes              
176 TPROGS_CFLAGS += $(call try-run,\                 
177         printf "int main() { return 0; }" |\      
178         $(CC) -Werror -fsanitize=bounds -x c -    
179                                                   
180 TPROGS_CFLAGS += -I$(objtree)/usr/include         
181 TPROGS_CFLAGS += -I$(srctree)/tools/testing/se    
182 TPROGS_CFLAGS += -I$(LIBBPF_INCLUDE)              
183 TPROGS_CFLAGS += -I$(srctree)/tools/include       
184 TPROGS_CFLAGS += -I$(srctree)/tools/perf          
185 TPROGS_CFLAGS += -I$(srctree)/tools/lib           
186 TPROGS_CFLAGS += -DHAVE_ATTR_TEST=0               
187                                                   
188 ifdef SYSROOT                                     
189 TPROGS_CFLAGS += --sysroot=$(SYSROOT)             
190 TPROGS_LDFLAGS := -L$(SYSROOT)/usr/lib            
191 endif                                             
192                                                   
193 TPROGS_LDLIBS                   += $(LIBBPF) -    
194 TPROGLDLIBS_xdp_router_ipv4     += -lm -pthrea    
195 TPROGLDLIBS_tracex4             += -lrt           
196 TPROGLDLIBS_trace_output        += -lrt           
197 TPROGLDLIBS_map_perf_test       += -lrt           
198 TPROGLDLIBS_test_overhead       += -lrt           
199                                                   
200 # Allows pointing LLC/CLANG to a LLVM backend     
201 # make M=samples/bpf LLC=~/git/llvm-project/ll    
202 LLC ?= llc                                        
203 CLANG ?= clang                                    
204 OPT ?= opt                                        
205 LLVM_DIS ?= llvm-dis                              
206 LLVM_OBJCOPY ?= llvm-objcopy                      
207 LLVM_READELF ?= llvm-readelf                      
208 BTF_PAHOLE ?= pahole                              
209                                                   
210 # Detect that we're cross compiling and use th    
211 ifdef CROSS_COMPILE                               
212 CLANG_ARCH_ARGS = --target=$(notdir $(CROSS_CO    
213 endif                                             
214                                                   
215 # Don't evaluate probes and warnings if we nee    
216 ifneq ($(src),)                                   
217 HDR_PROBE := $(shell printf "$(pound)include <    
218         $(CC) $(TPROGS_CFLAGS) $(TPROGS_LDFLAG    
219         -o /dev/null 2>/dev/null && echo okay)    
220                                                   
221 ifeq ($(HDR_PROBE),)                              
222 $(warning WARNING: Detected possible issues wi    
223 $(warning WARNING: Please install kernel heade    
224 endif                                             
225                                                   
226 BTF_LLC_PROBE := $(shell $(LLC) -march=bpf -ma    
227 BTF_PAHOLE_PROBE := $(shell $(BTF_PAHOLE) --he    
228 BTF_OBJCOPY_PROBE := $(shell $(LLVM_OBJCOPY) -    
229 BTF_LLVM_PROBE := $(shell echo "int main() { r    
230                           $(CLANG) --target=bp    
231                           $(LLVM_READELF) -S .    
232                           /bin/rm -f ./llvm_bt    
233                                                   
234 BPF_EXTRA_CFLAGS += -fno-stack-protector          
235 ifneq ($(BTF_LLVM_PROBE),)                        
236         BPF_EXTRA_CFLAGS += -g                    
237 else                                              
238 ifneq ($(and $(BTF_LLC_PROBE),$(BTF_PAHOLE_PRO    
239         BPF_EXTRA_CFLAGS += -g                    
240         LLC_FLAGS += -mattr=dwarfris              
241         DWARF2BTF = y                             
242 endif                                             
243 endif                                             
244 endif                                             
245                                                   
246 # Trick to allow make to be run from this dire    
247 all:                                              
248         $(MAKE) -C ../../ M=$(CURDIR) BPF_SAMP    
249                                                   
250 clean:                                            
251         $(MAKE) -C ../../ M=$(CURDIR) clean       
252         @find $(CURDIR) -type f -name '*~' -de    
253         @$(RM) -r $(CURDIR)/libbpf $(CURDIR)/b    
254                                                   
255 $(LIBBPF): $(wildcard $(LIBBPF_SRC)/*.[ch] $(L    
256 # Fix up variables inherited from Kbuild that     
257         $(MAKE) -C $(LIBBPF_SRC) RM='rm -rf' E    
258                 LDFLAGS="$(TPROGS_LDFLAGS)" sr    
259                 O= OUTPUT=$(LIBBPF_OUTPUT)/ DE    
260                 $@ install_headers                
261                                                   
262 BPFTOOLDIR := $(TOOLS_PATH)/bpf/bpftool           
263 BPFTOOL_OUTPUT := $(abspath $(BPF_SAMPLES_PATH    
264 DEFAULT_BPFTOOL := $(BPFTOOL_OUTPUT)/bootstrap    
265 BPFTOOL ?= $(DEFAULT_BPFTOOL)                     
266 $(DEFAULT_BPFTOOL): $(wildcard $(BPFTOOLDIR)/*    
267         $(MAKE) -C $(BPFTOOLDIR) srctree=$(BPF    
268                 OUTPUT=$(BPFTOOL_OUTPUT)/ boot    
269                                                   
270 $(LIBBPF_OUTPUT) $(BPFTOOL_OUTPUT):               
271         $(call msg,MKDIR,$@)                      
272         $(Q)mkdir -p $@                           
273                                                   
274 $(obj)/syscall_nrs.h:   $(obj)/syscall_nrs.s F    
275         $(call filechk,offsets,__SYSCALL_NRS_H    
276                                                   
277 targets += syscall_nrs.s                          
278 clean-files += syscall_nrs.h                      
279                                                   
280 FORCE:                                            
281                                                   
282                                                   
283 # Verify LLVM compiler tools are available and    
284 .PHONY: verify_cmds verify_target_bpf $(CLANG)    
285                                                   
286 verify_cmds: $(CLANG) $(LLC)                      
287         @for TOOL in $^ ; do \                    
288                 if ! (which -- "$${TOOL}" > /d    
289                         echo "*** ERROR: Canno    
290                         exit 1; \                 
291                 else true; fi; \                  
292         done                                      
293                                                   
294 verify_target_bpf: verify_cmds                    
295         @if ! (${LLC} -march=bpf -mattr=help >    
296                 echo "*** ERROR: LLVM (${LLC})    
297                 echo "   NOTICE: LLVM version     
298                 exit 2; \                         
299         else true; fi                             
300                                                   
301 $(BPF_SAMPLES_PATH)/*.c: verify_target_bpf $(L    
302 $(src)/*.c: verify_target_bpf $(LIBBPF)           
303                                                   
304 libbpf_hdrs: $(LIBBPF)                            
305 $(obj)/$(TRACE_HELPERS) $(obj)/$(CGROUP_HELPER    
306                                                   
307 .PHONY: libbpf_hdrs                               
308                                                   
309 $(obj)/xdp_router_ipv4_user.o: $(obj)/xdp_rout    
310                                                   
311 $(obj)/tracex5.bpf.o: $(obj)/syscall_nrs.h        
312 $(obj)/hbm_out_kern.o: $(src)/hbm.h $(src)/hbm    
313 $(obj)/hbm.o: $(src)/hbm.h                        
314 $(obj)/hbm_edt_kern.o: $(src)/hbm.h $(src)/hbm    
315                                                   
316 # Override includes for xdp_sample_user.o beca    
317 # TPROGS_CFLAGS causes conflicts                  
318 XDP_SAMPLE_CFLAGS += -Wall -O2 \                  
319                      -I$(src)/../../tools/incl    
320                      -I$(src)/../../tools/incl    
321                      -I$(LIBBPF_INCLUDE) \        
322                      -I$(src)/../../tools/test    
323                                                   
324 $(obj)/$(XDP_SAMPLE): TPROGS_CFLAGS = $(XDP_SA    
325 $(obj)/$(XDP_SAMPLE): $(src)/xdp_sample_user.h    
326 # Override includes for trace_helpers.o becaus    
327 # in our include path.                            
328 $(obj)/$(TRACE_HELPERS): TPROGS_CFLAGS := $(TP    
329                                                   
330 -include $(BPF_SAMPLES_PATH)/Makefile.target      
331                                                   
332 VMLINUX_BTF_PATHS ?= $(abspath $(if $(O),$(O)/    
333                      $(abspath $(if $(KBUILD_O    
334                      $(abspath ./vmlinux)         
335 VMLINUX_BTF ?= $(abspath $(firstword $(wildcar    
336                                                   
337 $(obj)/vmlinux.h: $(VMLINUX_BTF) $(BPFTOOL)       
338 ifeq ($(VMLINUX_H),)                              
339 ifeq ($(VMLINUX_BTF),)                            
340         $(error Cannot find a vmlinux for VMLI    
341                 build the kernel or set VMLINU    
342 endif                                             
343         $(Q)$(BPFTOOL) btf dump file $(VMLINUX    
344 else                                              
345         $(Q)cp "$(VMLINUX_H)" $@                  
346 endif                                             
347                                                   
348 clean-files += vmlinux.h                          
349                                                   
350 # Get Clang's default includes on this system,    
351 # '--target=bpf'. This fixes "missing" files o    
352 # such as asm/byteorder.h, asm/socket.h, asm/s    
353 #                                                 
354 # Use '-idirafter': Don't interfere with inclu    
355 # build would have failed anyways.                
356 define get_sys_includes                           
357 $(shell $(1) -v -E - </dev/null 2>&1 \            
358         | sed -n '/<...> search starts here:/,    
359 $(shell $(1) -dM -E - </dev/null | grep '#defi    
360 endef                                             
361                                                   
362 CLANG_SYS_INCLUDES = $(call get_sys_includes,$    
363                                                   
364 $(obj)/xdp_router_ipv4.bpf.o: $(obj)/xdp_sampl    
365                                                   
366 $(obj)/%.bpf.o: $(src)/%.bpf.c $(obj)/vmlinux.    
367         @echo "  CLANG-BPF " $@                   
368         $(Q)$(CLANG) -g -O2 --target=bpf -D__T    
369                 -Wno-compare-distinct-pointer-    
370                 -I$(srctree)/samples/bpf -I$(s    
371                 -I$(LIBBPF_INCLUDE) $(CLANG_SY    
372                 -c $(filter %.bpf.c,$^) -o $@     
373                                                   
374 LINKED_SKELS := xdp_router_ipv4.skel.h            
375 clean-files += $(LINKED_SKELS)                    
376                                                   
377 xdp_router_ipv4.skel.h-deps := xdp_router_ipv4    
378                                                   
379 LINKED_BPF_SRCS := $(patsubst %.bpf.o,%.bpf.c,    
380                                                   
381 BPF_SRCS_LINKED := $(notdir $(wildcard $(src)/    
382 BPF_OBJS_LINKED := $(patsubst %.bpf.c,$(obj)/%    
383 BPF_SKELS_LINKED := $(addprefix $(obj)/,$(LINK    
384                                                   
385 $(BPF_SKELS_LINKED): $(BPF_OBJS_LINKED) $(BPFT    
386         @echo "  BPF GEN-OBJ " $(@:.skel.h=)      
387         $(Q)$(BPFTOOL) gen object $(@:.skel.h=    
388         @echo "  BPF GEN-SKEL" $(@:.skel.h=)      
389         $(Q)$(BPFTOOL) gen skeleton $(@:.skel.    
390                                                   
391 # asm/sysreg.h - inline assembly used by it is    
392 # But, there is no easy way to fix it, so just    
393 # useless for BPF samples.                        
394 # below we use long chain of commands, clang |    
395 # to generate final object file. 'clang' compi    
396 # with native target, e.g., x64, arm64, etc. '    
397 # processing (llvm12) and IR optimizations. 'l    
398 # 'opt' output to IR, and finally 'llc' genera    
399 $(obj)/%.o: $(src)/%.c                            
400         @echo "  CLANG-bpf " $@                   
401         $(Q)$(CLANG) $(NOSTDINC_FLAGS) $(LINUX    
402                 -I$(obj) -I$(srctree)/tools/te    
403                 -I$(LIBBPF_INCLUDE) \             
404                 -D__KERNEL__ -D__BPF_TRACING__    
405                 -D__TARGET_ARCH_$(SRCARCH) -Wn    
406                 -Wno-gnu-variable-sized-type-n    
407                 -Wno-address-of-packed-member     
408                 -Wno-unknown-warning-option $(    
409                 -fno-asynchronous-unwind-table    
410                 -I$(srctree)/samples/bpf/ -inc    
411                 -O2 -emit-llvm -Xclang -disabl    
412                 $(OPT) -O2 -mtriple=bpf-pc-lin    
413                 $(LLC) -march=bpf $(LLC_FLAGS)    
414 ifeq ($(DWARF2BTF),y)                             
415         $(BTF_PAHOLE) -J $@                       
416 endif                                             
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php