xref: /titanic_51/usr/src/cmd/mdb/Makefile.module (revision 799823bbed51a695d01e13511bbb1369980bb714)
17c478bd9Sstevel@tonic-gate#
27c478bd9Sstevel@tonic-gate# CDDL HEADER START
37c478bd9Sstevel@tonic-gate#
47c478bd9Sstevel@tonic-gate# The contents of this file are subject to the terms of the
5dc0093f4Seschrock# Common Development and Distribution License (the "License").
6dc0093f4Seschrock# You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate#
87c478bd9Sstevel@tonic-gate# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate# or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate# See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate# and limitations under the License.
127c478bd9Sstevel@tonic-gate#
137c478bd9Sstevel@tonic-gate# When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate# If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate# fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate# information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate#
197c478bd9Sstevel@tonic-gate# CDDL HEADER END
207c478bd9Sstevel@tonic-gate#
217c478bd9Sstevel@tonic-gate#
2224fe0b3bSjmcp# Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate# Use is subject to license terms.
247c478bd9Sstevel@tonic-gate#
252a12f85aSJeremy Jones# Copyright (c) 2013 by Delphix. All rights reserved.
26*799823bbSRobert Mustacchi# Copyright 2015, Joyent, Inc.
272a12f85aSJeremy Jones#
287c478bd9Sstevel@tonic-gate
297c478bd9Sstevel@tonic-gate.KEEP_STATE:
307c478bd9Sstevel@tonic-gate.SUFFIXES:
317c478bd9Sstevel@tonic-gate
327c478bd9Sstevel@tonic-gateinclude $(SRC)/cmd/mdb/Makefile.tools
337c478bd9Sstevel@tonic-gate
347c478bd9Sstevel@tonic-gate$(KMOD_SOURCES_DIFFERENT)KMODSRCS = $(MODSRCS)
35*799823bbSRobert Mustacchi$(KMOD_SOURCES_DIFFERENT)KMODASMSRCS = $(MODASMSRCS)
367c478bd9Sstevel@tonic-gate
37*799823bbSRobert MustacchiMODOBJS = $(MODSRCS:%.c=dmod/%.o) $(MODASMSRCS:%.s=dmod/%.o)
38*799823bbSRobert MustacchiKMODOBJS = $(KMODSRCS:%.c=kmod/%.o) $(KMODASMSRCS:%.s=kmod/%.o)
397c478bd9Sstevel@tonic-gate
407c478bd9Sstevel@tonic-gateMODNAME = $(MODULE:%.so=%)
417c478bd9Sstevel@tonic-gateKMODULE = $(MODNAME)
427c478bd9Sstevel@tonic-gate
437c478bd9Sstevel@tonic-gateMODFILE = dmod/$(MODULE)
447c478bd9Sstevel@tonic-gateKMODFILE = kmod/$(KMODULE)
457c478bd9Sstevel@tonic-gate
467c478bd9Sstevel@tonic-gate#
477c478bd9Sstevel@tonic-gate# The mess below is designed to pick the right set of objects to build and/or
487c478bd9Sstevel@tonic-gate# lint.  We have three flavors:
497c478bd9Sstevel@tonic-gate#
501a7c1b72Smws#  1. proc and raw modules.  Only $(MODOBJS) are built.
517c478bd9Sstevel@tonic-gate#  2. kvm modules for systems without kmdb.  Only $(MODOBJS) are built.
527c478bd9Sstevel@tonic-gate#  3. kvm modules for systems with kmdb.  $(MODOBJS) and $(KMODOBJS) are built.
537c478bd9Sstevel@tonic-gate#
547c478bd9Sstevel@tonic-gate# Complicating matters, we'd like to make the distinction between 2 and 3 before
557c478bd9Sstevel@tonic-gate# this Makefile is loaded.  By default, we'll assume that all kvm modules should
567c478bd9Sstevel@tonic-gate# be built for kmdb.  If, however, the user sets $(MODULE_BUILD_TYPE) to `mdb',
577c478bd9Sstevel@tonic-gate# the kmdb variant of the module won't be built.
587c478bd9Sstevel@tonic-gate#
597c478bd9Sstevel@tonic-gate
607c478bd9Sstevel@tonic-gate# Which flavors are to be built?
617c478bd9Sstevel@tonic-gateTARGETS_kvm_type_	= both	# Build both if $(MODULE_BUILD_TYPE) is unset
627c478bd9Sstevel@tonic-gateTARGETS_kvm_type_kmdb	= both
637c478bd9Sstevel@tonic-gateTARGETS_kvm_type_mdb	= mdb
647c478bd9Sstevel@tonic-gateTARGETS_kvm_type	= $(TARGETS_kvm_type_$(MODULE_BUILD_TYPE))
657c478bd9Sstevel@tonic-gate
667c478bd9Sstevel@tonic-gate# What should we build?
677c478bd9Sstevel@tonic-gateTARGETS_kvm_kmdb	= $(KMODFILE)
687c478bd9Sstevel@tonic-gateTARGETS_kvm_mdb		= $(MODFILE)
697c478bd9Sstevel@tonic-gateTARGETS_kvm_both	= $(TARGETS_kvm_mdb) $(TARGETS_kvm_kmdb)
707c478bd9Sstevel@tonic-gateTARGETS_kvm		= $(TARGETS_kvm_$(TARGETS_kvm_type))
717c478bd9Sstevel@tonic-gateTARGETS_proc		= $(MODFILE)
721a7c1b72SmwsTARGETS_raw		= $(MODFILE)
737c478bd9Sstevel@tonic-gateTARGETS			= $(TARGETS_$(MDBTGT))
747c478bd9Sstevel@tonic-gate
757c478bd9Sstevel@tonic-gate# Where should we install that which we've built?
767c478bd9Sstevel@tonic-gateROOTTGTS_kvm_type	= $(TARGETS_kvm_type)	# overridden by mdb_ks
777c478bd9Sstevel@tonic-gateROOTTGTS_kvm_kmdb	= $(ROOTKMOD)/$(KMODULE)
787c478bd9Sstevel@tonic-gateROOTTGTS_kvm_mdb	= $(ROOTMOD)/$(MODULE)
797c478bd9Sstevel@tonic-gateROOTTGTS_kvm_both	= $(ROOTTGTS_kvm_mdb) $(ROOTTGTS_kvm_kmdb)
807c478bd9Sstevel@tonic-gateROOTTGTS_kvm		= $(ROOTTGTS_kvm_$(ROOTTGTS_kvm_type))
817c478bd9Sstevel@tonic-gateROOTTGTS_proc		= $(ROOTMOD)/$(MODULE)
821a7c1b72SmwsROOTTGTS_raw		= $(ROOTMOD)/$(MODULE)
837c478bd9Sstevel@tonic-gateROOTTGTS		= $(ROOTTGTS_$(MDBTGT))
847c478bd9Sstevel@tonic-gate
857c478bd9Sstevel@tonic-gate# What should we lint?
867c478bd9Sstevel@tonic-gateKLINTOBJS		= $(KMODOBJS:%.o=%.ln)
877c478bd9Sstevel@tonic-gateLINTOBJS		= $(MODOBJS:%.o=%.ln)
887c478bd9Sstevel@tonic-gate
897c478bd9Sstevel@tonic-gateLINTFILES_kvm_type	= $(TARGETS_kvm_type)
907c478bd9Sstevel@tonic-gateLINTFILES_kvm_both	= $(KLINTOBJS) $(LINTOBJS)
917c478bd9Sstevel@tonic-gateLINTFILES_kvm_mdb	= $(LINTOBJS)
927c478bd9Sstevel@tonic-gateLINTFILES_kvm		= $(LINTFILES_kvm_$(LINTFILES_kvm_type))
937c478bd9Sstevel@tonic-gateLINTFILES_proc		= $(LINTOBJS)
941a7c1b72SmwsLINTFILES_raw		= $(LINTOBJS)
957c478bd9Sstevel@tonic-gateLINTFILES		= $(LINTFILES_$(MDBTGT))
967c478bd9Sstevel@tonic-gate
977c478bd9Sstevel@tonic-gatekvm_TGTFLAGS		= -D_KERNEL
987c478bd9Sstevel@tonic-gateproc_TGTFLAGS		= -D_USER
997c478bd9Sstevel@tonic-gate
1002a12f85aSJeremy JonesC99MODE			= $(C99_ENABLE)
1012a12f85aSJeremy Jones
1027c478bd9Sstevel@tonic-gateCFLAGS			+= $(CCVERBOSE)
1037c478bd9Sstevel@tonic-gateCFLAGS64		+= $(CCVERBOSE)
1047c478bd9Sstevel@tonic-gateCPPFLAGS		+= $($(MDBTGT)_TGTFLAGS) -I../../../common
10567e3a03eSrieLDFLAGS			+= $(ZTEXT)
10667e3a03eSrieLDFLAGS64		+= $(ZTEXT)
107*799823bbSRobert MustacchiASFLAGS			+= -P
108*799823bbSRobert MustacchiAS_CPPFLAGS		+= -D_ASM
1097c478bd9Sstevel@tonic-gate
1107c478bd9Sstevel@tonic-gate# Module type-specific compiler flags
1117c478bd9Sstevel@tonic-gate$(MODOBJS) :=			CFLAGS += $(C_BIGPICFLAGS) $(XREGSFLAG)
1127c478bd9Sstevel@tonic-gate$(MODOBJS) :=			CFLAGS64 += $(C_BIGPICFLAGS) $(XREGSFLAG)
1137c478bd9Sstevel@tonic-gate$(KMODOBJS) $(KLINTOBJS) :=	CPPFLAGS += -D_KMDB
1147c478bd9Sstevel@tonic-gate$(KMODOBJS) :=			V9CODESIZE = $(CCABS32)
1157c478bd9Sstevel@tonic-gate$(KMODOBJS) :=			DTS_ERRNO =
1167c478bd9Sstevel@tonic-gate
1177c478bd9Sstevel@tonic-gate# Modules aren't allowed to export symbols
1187c478bd9Sstevel@tonic-gateMAPFILE		= $(SRC)/cmd/mdb/common/modules/conf/mapfile
1197c478bd9Sstevel@tonic-gate
12067e3a03eSrie# Modules typically make external references.  To provide for -zdefs use
12167e3a03eSrie# and clean ldd(1) processing, explicitly define all external references.
12267e3a03eSrieMAPFILE-EXT	= $(SRC)/cmd/mdb/common/modules/conf/mapfile-extern
12367e3a03eSrie
1247c478bd9Sstevel@tonic-gate#
1257c478bd9Sstevel@tonic-gate# kmdb is a kernel module, so we'll use the kernel's build flags.
1267c478bd9Sstevel@tonic-gate$(KMODOBJS) := CFLAGS += $(STAND_FLAGS_32)
1277c478bd9Sstevel@tonic-gate$(KMODOBJS) := CFLAGS64 += $(STAND_FLAGS_64)
1287c478bd9Sstevel@tonic-gate
1297c478bd9Sstevel@tonic-gate#
1307c478bd9Sstevel@tonic-gate# Override this to pull source files from another directory
1317c478bd9Sstevel@tonic-gate#
1327c478bd9Sstevel@tonic-gateMODSRCS_DIR = ../../../common/modules/genunix
1337c478bd9Sstevel@tonic-gate
1347c478bd9Sstevel@tonic-gateall: $$(TARGETS)
1357c478bd9Sstevel@tonic-gate
1367c478bd9Sstevel@tonic-gateinstall: all $$(ROOTTGTS)
1377c478bd9Sstevel@tonic-gate
1387c478bd9Sstevel@tonic-gatedmods: install
1397c478bd9Sstevel@tonic-gate
1407c478bd9Sstevel@tonic-gateclean.lint:
141b6805bf7SGordon Ross	$(RM) $(LINTFILES) $(MODSRCS:.c=.ln)
1427c478bd9Sstevel@tonic-gate
1437c478bd9Sstevel@tonic-gateclean:
1441a7c1b72Smws	$(RM) $(MODOBJS) $(KMODOBJS) $(CLEANFILES)
1457c478bd9Sstevel@tonic-gate
1467c478bd9Sstevel@tonic-gateclobber: clean clean.lint
1471a7c1b72Smws	$(RM) $(MODFILE) $(KMODFILE) $(CLOBBERFILES)
1487c478bd9Sstevel@tonic-gate
1497c478bd9Sstevel@tonic-gatelint: $$(LINTFILES)
1507c478bd9Sstevel@tonic-gate
1517c478bd9Sstevel@tonic-gate.NO_PARALLEL:
1527c478bd9Sstevel@tonic-gate.PARALLEL: $(MODOBJS) $(KMODOBJS) mdb_tgt kmdb_tgt dmod kmod \
1537c478bd9Sstevel@tonic-gate	$(TARGETS) $(LINTFILES)
1547c478bd9Sstevel@tonic-gate
15567e3a03eSrie$(MODFILE): dmod .WAIT $(MODOBJS) $$(MAPFILE-EXT)
15667e3a03eSrie	$(LINK.c) $(ZDEFS) $(ZIGNORE) $(MAPFILE-EXT:%=-M%) $(GSHARED) \
15767e3a03eSrie	    $(MODOBJS) -o $@ $(LDLIBS) -lc
1587c478bd9Sstevel@tonic-gate	$(CTFMERGE) -L VERSION -o $@ $(MODOBJS)
1597c478bd9Sstevel@tonic-gate	$(POST_PROCESS_SO)
1607c478bd9Sstevel@tonic-gate
1617c478bd9Sstevel@tonic-gate#
1627c478bd9Sstevel@tonic-gate# kmdb dmods must *not* stray from the module API.  To ensure that they don't,
1637c478bd9Sstevel@tonic-gate# we try to link them, at build time, against an object that exports the symbols
1647c478bd9Sstevel@tonic-gate# that they can legally use.  The link test object is, however, only built when
1657c478bd9Sstevel@tonic-gate# kmdb itself is built.  Requiring module developers to build kmdb first would
1667c478bd9Sstevel@tonic-gate# be painful, so by default, module-level builds don't do the link test (the
1677c478bd9Sstevel@tonic-gate# $(POUND_SIGN) assignment below takes care of that).  Builds of the entire
1687c478bd9Sstevel@tonic-gate# tree can, however, guarantee the construction of kmdb first, and as such can
1697c478bd9Sstevel@tonic-gate# override the setting of $(KMDB_LINKTEST_ENABLE).  This override causes the
1707c478bd9Sstevel@tonic-gate# link test to be run.
1717c478bd9Sstevel@tonic-gate#
1727c478bd9Sstevel@tonic-gate# Developers wanting to force a link test for a single module can use the
1737c478bd9Sstevel@tonic-gate# `linktest' target from within a module directory.
1747c478bd9Sstevel@tonic-gate#
1757c478bd9Sstevel@tonic-gateLINKTESTOBJ = $(KMDBDIR)/kmdb_modlinktest.o
1767c478bd9Sstevel@tonic-gate
1777c478bd9Sstevel@tonic-gateKMDB_LINKTEST = \
178dc0093f4Seschrock	$(LD) $(ZDEFS) -dy -r -o $@.linktest $(KMODOBJS) \
179dc0093f4Seschrock	$(STANDOBJS) $(LINKTESTOBJ) && \
1807c478bd9Sstevel@tonic-gate	$(RM) $@.linktest
1817c478bd9Sstevel@tonic-gate
1827c478bd9Sstevel@tonic-gateKMDB_LINKTEST_ENABLE=$(POUND_SIGN)
1837c478bd9Sstevel@tonic-gate$(KMDB_LINKTEST_ENABLE)KMDB_LINKTEST_CMD = $(KMDB_LINKTEST)
1847c478bd9Sstevel@tonic-gate
1857c478bd9Sstevel@tonic-gate#
1867c478bd9Sstevel@tonic-gate# Ensure that dmods don't use floating point
1877c478bd9Sstevel@tonic-gate#
1887c478bd9Sstevel@tonic-gateKMDB_FPTEST_CMD = $(KMDB_FPTEST)
1897c478bd9Sstevel@tonic-gate
1907c478bd9Sstevel@tonic-gate$(KMODFILE): kmod .WAIT $(KMODOBJS) $(MAPFILE)
191dc0093f4Seschrock	$(LD) -dy -r $(MAPFILE:%=-M%) -Nmisc/kmdbmod -o $@ $(KMODOBJS) \
192dc0093f4Seschrock	$(STANDOBJS)
1937c478bd9Sstevel@tonic-gate	$(KMDB_LINKTEST_CMD)
1947c478bd9Sstevel@tonic-gate	$(KMDB_FPTEST_CMD)
1955ae68c69Sjohnlev	$(CTFMERGE) -f -L VERSION -o $@ $(KMODOBJS)
1966ddb3373SRichard Lowe	$(POST_PROCESS)
1977c478bd9Sstevel@tonic-gate	$(SETDYNFLAG) -f DF_1_NOKSYMS $@
1987c478bd9Sstevel@tonic-gate
1997c478bd9Sstevel@tonic-gatelinktest: linktest_check .WAIT kmod .WAIT $(KMODOBJS)
2007c478bd9Sstevel@tonic-gate	$(KMDB_LINKTEST)
2017c478bd9Sstevel@tonic-gate
2027c478bd9Sstevel@tonic-gatelinktest_check:
203dc0093f4Seschrock	@if [ "$(MDBTGT)" != "kvm" ] ; then \
2047c478bd9Sstevel@tonic-gate		echo "ERROR: linktest is not supported non-kvm/disasm dmods" \
2057c478bd9Sstevel@tonic-gate		    >&2 ; \
2067c478bd9Sstevel@tonic-gate		exit 1 ; \
2077c478bd9Sstevel@tonic-gate	fi
2087c478bd9Sstevel@tonic-gate
2097c478bd9Sstevel@tonic-gate#
2107c478bd9Sstevel@tonic-gate# Dynamic rules for object construction
2117c478bd9Sstevel@tonic-gate#
2127c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: %.c
2137c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
2147c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
2157c478bd9Sstevel@tonic-gate
216*799823bbSRobert Mustacchidmod/%.o kmod%.o: %.s
217*799823bbSRobert Mustacchi	$(COMPILE.s) -o $@ $<
218*799823bbSRobert Mustacchi	$(CTFCONVERT_O)
219*799823bbSRobert Mustacchi
2207c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: ../%.c
2217c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
2227c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
2237c478bd9Sstevel@tonic-gate
224*799823bbSRobert Mustacchidmod/%.o kmod%.o: ../%.s
225*799823bbSRobert Mustacchi	$(COMPILE.s) -o $@ $<
226*799823bbSRobert Mustacchi	$(CTFCONVERT_O)
227*799823bbSRobert Mustacchi
2287c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: ../../../common/modules/$(MODNAME)/%.c
2297c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
2307c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
2317c478bd9Sstevel@tonic-gate
232*799823bbSRobert Mustacchidmod/%.o kmod%.o: ../../../common/modules/$(MODNAME)/%.s
233*799823bbSRobert Mustacchi	$(COMPILE.s) -o $@ $<
234*799823bbSRobert Mustacchi	$(CTFCONVERT_O)
235*799823bbSRobert Mustacchi
2367c478bd9Sstevel@tonic-gatedmod/%.o kmod/%.o: $$(MODSRCS_DIR)/%.c
2377c478bd9Sstevel@tonic-gate	$(COMPILE.c) -o $@ $<
2387c478bd9Sstevel@tonic-gate	$(CTFCONVERT_O)
2397c478bd9Sstevel@tonic-gate
240*799823bbSRobert Mustacchidmod/%.o kmod%.o: $$(MODSRCS_DIR)/%.s
241*799823bbSRobert Mustacchi	$(COMPILE.s) -o $@ $<
242*799823bbSRobert Mustacchi	$(CTFCONVERT_O)
243*799823bbSRobert Mustacchi
2447c478bd9Sstevel@tonic-gate#
2457c478bd9Sstevel@tonic-gate# Lint
2467c478bd9Sstevel@tonic-gate#
2477c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: %.c
2487c478bd9Sstevel@tonic-gate	$(LINT.c) -dirout=$(@D) -c $<
2497c478bd9Sstevel@tonic-gate
250*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: %.s
251*799823bbSRobert Mustacchi	$(LINT.s) -dirout=$(@D) -c $<
252*799823bbSRobert Mustacchi
2537c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: ../%.c
2547c478bd9Sstevel@tonic-gate	$(LINT.c) -dirout=$(@D) -c $<
2557c478bd9Sstevel@tonic-gate
256*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: ../%.s
257*799823bbSRobert Mustacchi	$(LINT.s) -dirout=$(@D) -c $<
258*799823bbSRobert Mustacchi
2597c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.c
2607c478bd9Sstevel@tonic-gate	$(LINT.c) -dirout=$(@D) -c $<
2617c478bd9Sstevel@tonic-gate
262*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: ../../../common/modules/$(MODNAME)/%.s
263*799823bbSRobert Mustacchi	$(LINT.s) -dirout=$(@D) -c $<
264*799823bbSRobert Mustacchi
2657c478bd9Sstevel@tonic-gatedmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.c
2667c478bd9Sstevel@tonic-gate	$(LINT.c) -dirout=$(@D) -c $<
2677c478bd9Sstevel@tonic-gate
268*799823bbSRobert Mustacchidmod/%.ln kmod/%.ln: $$(MODSRCS_DIR)/%.s
269*799823bbSRobert Mustacchi	$(LINT.s) -dirout=$(@D) -c $<
270*799823bbSRobert Mustacchi
2717c478bd9Sstevel@tonic-gate#
2727c478bd9Sstevel@tonic-gate# Installation targets
2737c478bd9Sstevel@tonic-gate#
2747c478bd9Sstevel@tonic-gate
2757c478bd9Sstevel@tonic-gate$(ROOT)/usr/lib/mdb/$(MDBTGT): $(ROOT)/usr/lib/mdb
2767c478bd9Sstevel@tonic-gate	$(INS.dir)
2777c478bd9Sstevel@tonic-gate
2787c478bd9Sstevel@tonic-gate$(ROOT)/usr/lib/mdb:
2797c478bd9Sstevel@tonic-gate	$(INS.dir)
2807c478bd9Sstevel@tonic-gate
2817c478bd9Sstevel@tonic-gate$(ROOT)/kernel/kmdb:
2827c478bd9Sstevel@tonic-gate	$(INS.dir)
2837c478bd9Sstevel@tonic-gate
2847c478bd9Sstevel@tonic-gate$(ROOTMOD)/$(MODULE): $(ROOTMOD)
2857c478bd9Sstevel@tonic-gate
2867c478bd9Sstevel@tonic-gate$(ROOTKMOD)/$(KMODULE): $(ROOTKMOD)
2877c478bd9Sstevel@tonic-gate
2887c478bd9Sstevel@tonic-gatekmod dmod:
2897c478bd9Sstevel@tonic-gate	-@mkdir -p $@
290