1 # 2 # CDDL HEADER START 3 # 4 # The contents of this file are subject to the terms of the 5 # Common Development and Distribution License (the "License"). 6 # You may not use this file except in compliance with the License. 7 # 8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 # or http://www.opensolaris.org/os/licensing. 10 # See the License for the specific language governing permissions 11 # and limitations under the License. 12 # 13 # When distributing Covered Code, include this CDDL HEADER in each 14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 # If applicable, add the following below this CDDL HEADER, with the 16 # fields enclosed by brackets "[]" replaced with your own identifying 17 # information: Portions Copyright [yyyy] [name of copyright owner] 18 # 19 # CDDL HEADER END 20 # 21 # 22 # Copyright 2009 Sun Microsystems, Inc. All rights reserved. 23 # Use is subject to license terms. 24 # 25 26 PROG = ucodeadm 27 28 PROG_OBJS = ucodeadm.o ucode_errno.o 29 COMMON_OBJS = ucode_utils.o 30 OBJS = $(PROG_OBJS) $(COMMON_OBJS) 31 COMMON_SRCDIR = ../../common/ucode 32 ERROR_HEADER = $(COMMON_SRCDIR)/ucode_errno.h 33 SRCS = $(PROG_OBJS:%.o=%.c) $(COMMON_OBJS:%.o=$(COMMON_SRCDIR)/%.c) 34 35 include ../Makefile.cmd 36 37 POFILE = ucodeadm_all.po 38 POFILES = $(PROG_OBJS:%.o=%.po) 39 40 INTEL_UCODE_FILE = intel-ucode.txt 41 AMD_UCODE_FILE = amd-ucode.bin 42 43 ROOTUCODEPATH = $(ROOT)/platform/i86pc/ucode 44 ROOTINTELUCODE = $(INTEL_UCODE_FILE:%=$(ROOTUCODEPATH)/%) 45 ROOTAMDUCODE = $(AMD_UCODE_FILE:%=$(ROOTUCODEPATH)/%) 46 47 CPPFLAGS = -I../../common -I../../uts/common 48 CFLAGS += $(CCVERBOSE) 49 CERRWARN += -_gcc=-Wno-uninitialized 50 CERRWARN += -_gcc=-Wno-type-limits 51 LINTFLAGS += -errtags -erroff=E_NAME_DEF_NOT_USED2 52 LINTFLAGS += -erroff=E_INCONS_ARG_DECL2,E_INCONS_VAL_TYPE_DECL2 53 LDLIBS = -lgen 54 55 DIRMODE = 0755 56 FILEMODE = 0555 57 58 $(ROOTINTELUCODE) := FILEMODE = 0444 59 $(ROOTAMDUCODE) := FILEMODE = 0444 60 61 install := TARGET = install 62 clobber := TARGET = clobber 63 64 CLEANFILES += $(PROG) $(OBJS) ucode_errno.c $(POFILES) $(POFILE) 65 66 .KEEP_STATE: 67 68 all: $(PROG) 69 70 install: all $(ROOTUSRSBINPROG) $(ROOTUCODEPATH) $(ROOTINTELUCODE) $(ROOTAMDUCODE) 71 72 _msg: ucodeadm_all.po 73 74 %.o: $(COMMON_SRCDIR)/%.c 75 $(COMPILE.c) -o $@ $< 76 $(POST_PROCESS_O) 77 78 $(PROG): $(OBJS) ucode_errno.c 79 $(LINK.c) -o $(PROG) $(OBJS) $(LDLIBS) 80 $(POST_PROCESS) 81 82 $(ROOTUCODEPATH): 83 $(INS.dir) 84 85 $(ROOTUCODEPATH)/%: % 86 $(INS.file) 87 88 clean: 89 -$(RM) $(CLEANFILES) 90 91 lint: lint_SRCS 92 93 94 include ../Makefile.targ 95 96 ucode_errno.c: $(COMMON_SRCDIR)/mkerrno.sh $(ERROR_HEADER) 97 sh $(COMMON_SRCDIR)/mkerrno.sh $(ERROR_HEADER) > $@ 98 99 ucode_errno.po := XGETFLAGS += -a 100 101 $(POFILE): $(POFILES) 102 $(RM) $@ 103 $(CAT) $(POFILES) > $@ 104 105 FRC: