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: