# SCCSID = src/dev/dasd/ibm/ibm1flpx/makefile, flp1, basedd, initial 94/03/13

#/***********************************************************************/
#/*                                                                     */
#/* Driver Name: RESOURCE.SYS - Resource Management Driver              */
#/*              ------------------------------------------------       */
#/*                                                                     */
#/* Source File Name: MAKEFILE                                          */
#/*                                                                     */
#/* Descriptive Name: MAKEFILE for                                      */
#/*                                                                     */
#/* Function:                                                           */
#/*                                                                     */
#/*                                                                     */
#/*---------------------------------------------------------------------*/
#/*                                                                     */
#/* Copyright (C) 1992 IBM Corporation                                  */
#/*                                                                     */
#/* DISCLAIMER OF WARRANTIES.  The following [enclosed] code is         */
#/* provided to you solely for the purpose of assisting you in          */
#/* the development of your applications. The code is provided          */
#/* "AS IS", without warranty of any kind. IBM shall not be liable      */
#/* for any damages arising out of your use of this code, even if       */
#/* they have been advised of the possibility of such damages.          */
#/*                                                                     */
#/*---------------------------------------------------------------------*/
#/*                                                                     */
#/* Change Log                                                          */
#/*                                                                     */
#/* Mark    Date      Programmer  Comment                               */
#/* ----    ----      ----------  -------                               */
#/* @nnnn   mm/dd/yy  NNN                                               */
#/*                                                                     */
#/*                                                                     */
#/***********************************************************************/

#
#
#       You can optionally generate the listing files for the device driver.
#
#          make  [option]
#
#            option:     list         -> create listings
#                                     -> create
#
#            default:  create
#
# ******  NOTE  ******
#
#        If you are using a SED command with TAB characters, many editors
#        will expand tabs causing unpredictable results in other programs.
#
#        Documentation:
#
#        Using SED command with TABS. Besure to invoke set tab save option
#        on your editor. If you don't, the program 'xyz' will not work
#        correctly.
#

#****************************************************************************
#  Dot directive definition area (usually just suffixes)
#****************************************************************************

.SUFFIXES:
.SUFFIXES: .com .add .exe .obj .mbj .asm .inc .def .lnk .lrf .crf .ref
.SUFFIXES: .lst .sym .map .c .h .lib

#****************************************************************************
#  Environment Setup for the component(s).
#****************************************************************************

#
# Conditional Setup Area and User Defined Macros
#

#
# Compiler Location w/ includes, libs and tools
#

DOSINC =    ..\..\..\dos\dosinc
INIT   =    ..\..\..\dos\init
TASK   =    ..\..\..\dos\task
INC    =    ..\..\..\..\inc
H      =    ..\..\..\..\h
LIB    =    ..\..\..\..\lib
TOOLSPATH = ..\..\..\..\tools
DISKH  =    ..\..\dasd\diskh
DHLIB  =    ..\..\dasd\devhelp
ADDLIB =    ..\..\dasd\addcalls
RSM_H  =    ..\rsm_h
RMCALLS_H = ..\rmcalls

#
# Since the compiler/linker and other tools use environment
# variables ( INCLUDE, LIB, etc ) in order to get the location of files,
# the following line will check the environment for the LIFE of the
# makefile and will be specific to this set of instructions. All MAKEFILES
# are requested to use this format to insure that they are using the correct
# level of files and tools.
#

!if [set INCLUDE=$(DOSINC);$(INIT);$(TASK);$(INC)] || \
   [set LIB=$(LIB);$(DHLIB);$(ADDLIB)] || [set PATH=$(TOOLSPATH)]
!endif


#
# Compiler/tools Macros
#

AS=masm
CC=cl
IMPLIB=implib
IPF=ipfc
LIBUTIL=lib
LINK=link
MAPSYM=mapsym
TRCUST=trcust
RC=rc

#
# Compiler and Linker Options
#

AFLAGS = -MX -T -Z $(ENV)
AINC   = -I. -I$(DOSINC) -I$(INIT) -I$(TASK) -I$(INC)
CINC   = -I. -I$(H) -I$(DISKH) -I$(RSM_H) -I$(RMCALLS_H) -I$(MAKEDIR)
CFLAGS = /c /Zp /G2s /Answ /Ox $(ENV)
LFLAGS = /map /nod /exepack /packd /a:16 /far
RFLAGS = -r

LIBS  =  $(DHLIB)\dhcalls.lib $(ADDLIB)\addcalls.lib $(LIB)\libh.lib
DEF02 =  resource.def

#****************************************************************************
# Set up Macros that will contain all the different dependencies for the
# executables and dlls etc. that are generated.
#****************************************************************************

#
# OBJ files
#
#
OBJ1 =  rsmsegs.obj rsmapir3.obj rsmapir0.obj rsmalloc.obj
OBJ2 =  rsmhlpr.obj rsmnode.obj rsmrsrc.obj rsmldev.obj
OBJ3 =  rsmsrch.obj rsmtrace.obj rsmentry.obj rsmdata.obj rsminit.obj

#
#       LIST Files
#
LIST=   rsmsegs.lst rsmapir3.lst rsmapir0.lst rsmalloc.lst            \
        rsmhlpr.lst rsmnode.lst rsmrsrc.lst rsmldev.lst               \
        rsmsrch.obj rsmtrace.lst rsmentry.lst rsmdata.lst rsminit.lst


OBJS = $(OBJ1) $(OBJ2) $(OBJ3) $(OBJ4)

#****************************************************************************
#   Setup the inference rules for compiling and assembling source code to
#   obejct code.
#****************************************************************************


.asm.obj:
        $(AS) $(AFLAGS) $(AINC) $*.asm;

.asm.mbj:
        $(AS) $(AFLAGS) -DMMIOPH $(AINC) $*.asm $*.mbj;

.asm.lst:
        $(AS) -l -n $(AFLAGS) $(AINC) $*.asm;

.c.obj:
        $(CC) $(CFLAGS) $(CINC) $*.c

.c.dbj:
        $(CC) $(DFLAGS) $(CINC) -Fo$*.dbj $*.c
        copy $*.cod $*.lst
        del $*.cod

.c.lst:
        $(CC) $(CFLAGS) /Fc $(CINC) $*.c
        copy $*.cod $*.lst
        del $*.cod

#****************************************************************************
#   Target Information
#****************************************************************************
#
# This is a very important step. The following small amount of code MUST
# NOT be removed from the program. The following directive will do
# dependency checking every time this component is built UNLESS the
# following is performed:
#                    A specific tag is used -- ie. all
#
# This allows the developer as well as the B & I group to perform incremental
# build with a degree of accuracy that has not been used before.
# There are some instances where certain types of INCLUDE files must be
# created first. This type of format will allow the developer to require
# that file to be created first. In order to achive that, all that has to
# be done is to make the DEPEND.MAK tag have your required target. Below is
# an example:
#
#    depend.mak:   { your file(s) } dephold
#
# Please DON'T remove the following line
#

!include      "$(H)\version.mak"

#
# Should be the default tag for all general processing
#

all:   resource.sys

list: $(LIST)

clean:
        if exist *.lnk  del *.lnk
        if exist *.def  del *.def
        if exist *.obj  del *.obj
        if exist *.map  del *.map
        if exist *.lst  del *.lst
        if exist *.sym  del *.sym
        if exist *.add  del *.add
        if exist *.sys  del *.sys
        if exist *.mak  del *.mak


#*****************************************************************************
#   Specific Description Block Information
#*****************************************************************************

# This section would only be for specific direction as to how to create
# unique elements that are necessary to the build process. This could
# be compiling or assembling, creation of DEF files and other unique
# files.
# If all compiler and assembly rules are the same, use an inference rule to
# perform the compilation.
#

resource.sys:  $(OBJS) $(LIBS) makefile
        Rem Create DEF file <<$(DEF02)
LIBRARY RESOURCE

DESCRIPTION "$(FILEVER)  Resource Management Driver"

PROTMODE

SEGMENTS
 DDHeader       CLASS 'DDHEADER'
 CONST          CLASS 'CONST'
 _BSS           CLASS 'BSS'
 LIBDATA        CLASS 'DATA'
 _DATA          CLASS 'DATA'
 'Code'         CLASS 'CODE'     IOPL
 LIBCODE        CLASS 'CODE'     IOPL
 _TEXT          CLASS 'CODE'     IOPL
 SwapCode       CLASS 'CODE'     IOPL
 SwapData       CLASS 'DATASWAP' IOPL

<<keep
        $(LINK) $(LFLAGS) @<<$(@B).lnk
$(OBJ1) +
$(OBJ2) +
$(OBJ3) +
$(OBJ4)
$*.sys
$*.map
$(LIBS)
$(DEF02)
<<keep
             $(TRCUST) $*.tsf
             $(MAPSYM) $*.map


#****************************************************************************
