usr/src/cmd/fm/topo/plugins/Makefile.plugin
author rie
Tue, 13 Sep 2005 10:26:14 -0700
changeset 524 259d2acc2f55
parent 240 add91ef1762e
permissions -rw-r--r--
5072038 binaries shouldn't be stripped
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     1
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     2
# CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     3
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     4
# The contents of this file are subject to the terms of the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     5
# Common Development and Distribution License, Version 1.0 only
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     6
# (the "License").  You may not use this file except in compliance
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
# with the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
# or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
# See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
# and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
# When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
# If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
# fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
# information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
# CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    21
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    22
#
240
add91ef1762e 6240456 Need topo enumeration for PCI Express
timh
parents: 0
diff changeset
    23
# Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    24
# Use is subject to license terms.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    25
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    26
#ident	"%Z%%M%	%I%	%E% SMI"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    27
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    28
.KEEP_STATE:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    29
.SUFFIXES:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    30
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
include ../../../../../Makefile.cmd
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
# Set PROG and OBJS based on the values of MODULE and SRCS.  We expect that
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
# these macros to be defined by the Makefile that is including this file.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
PROG = $(MODULE:%=%.so)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    38
TOPO = $(MODULE:%=%.topo)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
YOBJS = $(YSRCS:%.y=%.o)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
OBJS = $(YOBJS) $(SRCS:%.c=%.o)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
# Set ROOTPROG and ROOTTOPO based on the values of MODULE, CLASS, and PLATFORMS
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
# We expect these macros to be defined by the Makefile that is including us.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
#
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
common_TOPODIR = $(ROOT)/usr/lib/fm/topo
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
arch_TOPODIR = $(ROOT)/usr/lib/fm/topo/$(ARCH)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
ROOT_TOPO_DIR = $($(CLASS)_TOPODIR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
ROOTPROG = $(ROOT_TOPO_DIR)/$(PROG)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
ROOTTOPO = $(ROOT_TOPO_DIR)/$(TOPO)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
LINTFLAGS += -mu
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
LINTFILES = $(SRCS:%.c=%.ln)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
LINTLDLIBS += -L$(ROOTLIB)/fm -ltopo
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
CFLAGS += $(CTF_FLAGS) $(CCVERBOSE) -xstrconst -K pic -G $(XREGSFLAG)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
CPPFLAGS += -D_POSIX_PTHREAD_SEMANTICS -D_REENTRANT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
LDFLAGS += -z text -z combreloc -z defs -z ignore -R/usr/lib/fm
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
LDLIBS += -L$(ROOTLIB)/fm -ltopo -lc
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
all: $(PROG)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
.NO_PARALLEL:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
.PARALLEL: $(OBJS) $(LINTFILES)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
$(PROG): $(OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
	$(LINK.c) $(OBJS) -o $@ $(LDLIBS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
	$(CTFMERGE) -L VERSION -o $@ $(OBJS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
	$(POST_PROCESS_SO)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
%.o: %.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
	$(COMPILE.c) $<
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
	$(CTFCONVERT_O)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
clean:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
	$(RM) $(OBJS) $(LINTFILES)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
clobber: clean
240
add91ef1762e 6240456 Need topo enumeration for PCI Express
timh
parents: 0
diff changeset
    79
	$(RM) $(PROG) $(ROOTTOPO) $(ROOTPROG) 
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
%.ln: %.c
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
	$(LINT.c) -c $<
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
lint: $(LINTFILES)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
	$(LINT) $(LINTFLAGS) $(LINTFILES) $(LDLIBS)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
install_h:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
$(ROOTPROG): $$(@D) $(PROG)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
	$(RM) $@; $(INS) -s -m 0555 -f $(@D) $(PROG)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
$(ROOTTOPO): $$(@D) $(TOPO)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
	$(RM) $@; $(INS) -s -m 0444 -f $(@D) $(TOPO)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    95
install: $(ROOTTOPO) $(ROOTPROG) 
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    96
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    97
include ../../../Makefile.rootdirs