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

#/***********************************************************************/
#/*									*/
#/* Driver Name:							*/
#/*		 ------------------------------------------------	*/
#/*									*/
#/* 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						*/
#/*D150757  04/08/96  K. Huynh	  Remove swappable segment.		*/
#/*									*/
#/*									*/
#/***********************************************************************/

#
#
#	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  = ..\..\diskh
DHLIB  = ..\..\devhelp
ADDLIB = ..\..\addcalls
RMLIB  = ..\..\..\resource\rmcalls
RSM_H  = ..\..\..\resource\rsm_h
APMLIB	  = ..\..\..\thinkpad\dockii\apmcalls
DOCKLIB   = ..\..\..\thinkpad\dockii\doccalls

#
# 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);$(RMLIB);$(ADDLIB)] || [set PATH=$(TOOLSPATH)]
!endif


#
# Compiler/tools Macros
#

AS=masm
CC=cl
IMPLIB=implib
IPF=ipfc
LIBUTIL=lib
LINK=link
MAPSYM=mapsym
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$(MAKEDIR) -I$(APMLIB) -I$(DOCKLIB)
CFLAGS = /c /Zp /G2s /Answ /Ox $(ENV)
LFLAGS = /map /nod /exepack /packd /a:16 /far
RFLAGS = -r

LIBS  =  $(APMLIB)\apmcalls.lib $(DHLIB)\dhcalls.lib $(ADDLIB)\addcalls.lib $(LIB)\libh.lib $(RMLIB)\rmcalls.lib $(DOCKLIB)\doccalls.lib
DEF02 =  ibm1flpy.def

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

#
# OBJ files
#
#
OBJ1 =	FLP1SEGS.OBJ FLP1ISM.OBJ FLP1OSM1.OBJ FLP1OSM2.OBJ FLP1OSM3.OBJ
OBJ2 =	FLP1DATA.OBJ FLP1APM.OBJ FLP1APME.OBJ FLP1INI2.OBJ
OBJ3 =	FLP1INIT.OBJ CMDPARSE.OBJ FLP1PRTF.OBJ

#
#	LIST Files
#
LIST=	FLP1SEGS.OBJ FLP1ISM.LST FLP1OSM1.LST FLP1OSM2.LST FLP1OSM3.LST \
	FLP1DATA.LST FLP1APM.LST FLP1APME.LST FLP1INI2.LST FLP1INIT.LST \
	CMDPARSE.LST FLP1PRTF.LST


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

#****************************************************************************
#   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:   ibm1flpy.add

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


#*****************************************************************************
#   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.
#

ibm1flpy.add:  $(OBJS) $(LIBS) makefile
	Rem Create DEF file <<$(DEF02)
LIBRARY IBM1FLPY

DESCRIPTION "$(FILEVER)  Adapter Driver for ISA Diskette Controllers"

PROTMODE

SEGMENTS
 DDHeader	CLASS 'DATA'
 LIBDATA	CLASS 'DATA'
 _DATA		CLASS 'DATA'
 CONST		CLASS 'CONST'
 _BSS		CLASS 'BSS'
 'Code'         CLASS 'CODE' IOPL
 LIBCODE	CLASS 'CODE' IOPL
 _TEXT		CLASS 'CODE' IOPL
 'RMCode'       CLASS 'CODE' IOPL

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


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