2013-11-27 21:17:00 +01:00
|
|
|
|
2013-05-20 07:17:58 +02:00
|
|
|
CC := gcc
|
2010-11-01 09:35:04 +01:00
|
|
|
CXX := g++
|
2019-11-11 09:52:15 +01:00
|
|
|
AR := ar
|
2013-05-20 07:15:55 +02:00
|
|
|
LD := $(CXX)
|
|
|
|
|
|
2014-07-24 19:57:40 +02:00
|
|
|
MSG_PREFIX ?=
|
2024-04-11 16:28:36 +02:00
|
|
|
ABCSRC ?= .
|
|
|
|
|
VPATH = $(ABCSRC)
|
2014-07-24 19:57:40 +02:00
|
|
|
|
2025-11-04 01:52:02 +01:00
|
|
|
# whether to print build options, tools, and echo commands while building
|
|
|
|
|
ifdef ABC_MAKE_VERBOSE
|
|
|
|
|
VERBOSE=
|
|
|
|
|
abc_info = $(info $(1))
|
|
|
|
|
else
|
|
|
|
|
VERBOSE=@
|
|
|
|
|
abc_info =
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
$(call abc_info,$(MSG_PREFIX)Using CC=$(CC))
|
|
|
|
|
$(call abc_info,$(MSG_PREFIX)Using CXX=$(CXX))
|
|
|
|
|
$(call abc_info,$(MSG_PREFIX)Using AR=$(AR))
|
|
|
|
|
$(call abc_info,$(MSG_PREFIX)Using LD=$(LD))
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
PROG := abc
|
2018-02-06 04:00:46 +01:00
|
|
|
OS := $(shell uname -s)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2008-07-02 17:01:00 +02:00
|
|
|
MODULES := \
|
2014-10-29 05:13:59 +01:00
|
|
|
$(wildcard src/ext*) \
|
2016-04-12 06:46:14 +02:00
|
|
|
src/base/abc src/base/abci src/base/cmd src/base/io src/base/main src/base/exor \
|
2018-10-01 05:51:37 +02:00
|
|
|
src/base/ver src/base/wlc src/base/wln src/base/acb src/base/bac src/base/cba src/base/pla src/base/test \
|
2024-01-16 17:42:43 +01:00
|
|
|
src/map/mapper src/map/mio src/map/super src/map/if src/map/if/acd \
|
2013-07-12 22:02:32 +02:00
|
|
|
src/map/amap src/map/cov src/map/scl src/map/mpm \
|
2012-01-21 13:30:10 +01:00
|
|
|
src/misc/extra src/misc/mvc src/misc/st src/misc/util src/misc/nm \
|
|
|
|
|
src/misc/vec src/misc/hash src/misc/tim src/misc/bzlib src/misc/zlib \
|
2026-01-04 22:37:18 +01:00
|
|
|
src/misc/mem src/misc/bar src/misc/bbl src/misc/parse src/misc/btor \
|
2016-05-12 00:41:31 +02:00
|
|
|
src/opt/cut src/opt/fxu src/opt/fxch src/opt/rwr src/opt/mfs src/opt/sim \
|
2025-03-01 16:44:55 +01:00
|
|
|
src/opt/ret src/opt/fret src/opt/res src/opt/lpk src/opt/nwk src/opt/rwt src/opt/rar \
|
2025-12-25 04:06:29 +01:00
|
|
|
src/opt/cgt src/opt/csw src/opt/dar src/opt/dau src/opt/dsc src/opt/sfm src/opt/sbd src/opt/eslim src/opt/ufar src/opt/untk src/opt/util \
|
2025-03-07 09:25:11 +01:00
|
|
|
src/sat/bsat src/sat/xsat src/sat/satoko src/sat/csat src/sat/msat src/sat/psat src/sat/cnf src/sat/bmc src/sat/glucose src/sat/glucose2 src/sat/kissat src/sat/cadical \
|
2013-06-22 20:54:58 +02:00
|
|
|
src/bool/bdc src/bool/deco src/bool/dec src/bool/kit src/bool/lucky \
|
|
|
|
|
src/bool/rsb src/bool/rpo \
|
2015-08-25 05:55:07 +02:00
|
|
|
src/proof/pdr src/proof/abs src/proof/live src/proof/ssc src/proof/int \
|
2016-05-08 04:47:02 +02:00
|
|
|
src/proof/cec src/proof/acec src/proof/dch src/proof/fraig src/proof/fra src/proof/ssw \
|
2012-01-21 13:30:10 +01:00
|
|
|
src/aig/aig src/aig/saig src/aig/gia src/aig/ioa src/aig/ivy src/aig/hop \
|
2015-11-05 10:24:26 +01:00
|
|
|
src/aig/miniaig
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2010-11-01 09:35:04 +01:00
|
|
|
all: $(PROG)
|
2005-09-10 17:01:00 +02:00
|
|
|
default: $(PROG)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2015-11-12 20:43:59 +01:00
|
|
|
ARCHFLAGS_EXE ?= ./arch_flags
|
|
|
|
|
|
|
|
|
|
$(ARCHFLAGS_EXE) : arch_flags.c
|
2024-04-11 16:28:36 +02:00
|
|
|
$(CC) $< -o $(ARCHFLAGS_EXE)
|
2011-11-24 23:25:47 +01:00
|
|
|
|
2017-10-20 23:41:30 +02:00
|
|
|
INCLUDES += -I$(ABCSRC)/src
|
2015-10-22 07:56:15 +02:00
|
|
|
|
2018-03-30 10:03:04 +02:00
|
|
|
# Use C99 stdint.h header for platform-dependent types
|
|
|
|
|
ifdef ABC_USE_STDINT_H
|
|
|
|
|
ARCHFLAGS ?= -DABC_USE_STDINT_H=1
|
|
|
|
|
else
|
|
|
|
|
ARCHFLAGS ?= $(shell $(CC) $(ABCSRC)/arch_flags.c -o $(ARCHFLAGS_EXE) && $(ARCHFLAGS_EXE))
|
|
|
|
|
endif
|
|
|
|
|
|
2015-02-05 23:47:07 +01:00
|
|
|
ARCHFLAGS := $(ARCHFLAGS)
|
|
|
|
|
|
2024-01-16 18:13:30 +01:00
|
|
|
OPTFLAGS ?= -g -O
|
2005-09-02 17:01:00 +02:00
|
|
|
|
2024-01-16 18:13:30 +01:00
|
|
|
CFLAGS += -Wall -Wno-unused-function -Wno-write-strings -Wno-sign-compare $(ARCHFLAGS)
|
2015-01-27 19:09:57 +01:00
|
|
|
ifneq ($(findstring arm,$(shell uname -m)),)
|
|
|
|
|
CFLAGS += -DABC_MEMALIGN=4
|
|
|
|
|
endif
|
2013-05-20 07:15:55 +02:00
|
|
|
|
2022-01-21 21:51:36 +01:00
|
|
|
# compile ABC using the C++ compiler and put everything in the namespace $(ABC_NAMESPACE)
|
2015-10-17 01:27:59 +02:00
|
|
|
ifdef ABC_USE_NAMESPACE
|
2022-01-21 21:51:36 +01:00
|
|
|
CFLAGS += -DABC_NAMESPACE=$(ABC_USE_NAMESPACE) -fpermissive -x c++
|
2015-10-17 01:27:59 +02:00
|
|
|
CC := $(CXX)
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Compiling in namespace $(ABC_USE_NAMESPACE))
|
2015-10-17 01:27:59 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
# compile CUDD with ABC
|
2015-10-17 01:44:59 +02:00
|
|
|
ifndef ABC_USE_NO_CUDD
|
2015-10-17 01:27:59 +02:00
|
|
|
CFLAGS += -DABC_USE_CUDD=1
|
|
|
|
|
MODULES += src/bdd/cudd src/bdd/extrab src/bdd/dsd src/bdd/epd src/bdd/mtr src/bdd/reo src/bdd/cas src/bdd/bbr src/bdd/llb
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Compiling with CUDD)
|
2015-10-17 01:27:59 +02:00
|
|
|
endif
|
|
|
|
|
|
2015-11-05 10:23:35 +01:00
|
|
|
ABC_READLINE_INCLUDES ?=
|
|
|
|
|
ABC_READLINE_LIBRARIES ?= -lreadline
|
|
|
|
|
|
|
|
|
|
# whether to use libreadline
|
|
|
|
|
ifndef ABC_USE_NO_READLINE
|
|
|
|
|
CFLAGS += -DABC_USE_READLINE $(ABC_READLINE_INCLUDES)
|
|
|
|
|
LIBS += $(ABC_READLINE_LIBRARIES)
|
2018-02-06 04:00:46 +01:00
|
|
|
ifeq ($(OS), FreeBSD)
|
|
|
|
|
CFLAGS += -I/usr/local/include
|
|
|
|
|
LDFLAGS += -L/usr/local/lib
|
|
|
|
|
endif
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Using libreadline)
|
2015-11-05 10:23:35 +01:00
|
|
|
endif
|
|
|
|
|
|
2015-10-17 01:27:59 +02:00
|
|
|
# whether to compile with thread support
|
2016-04-12 20:16:22 +02:00
|
|
|
ifndef ABC_USE_NO_PTHREADS
|
2015-10-17 01:27:59 +02:00
|
|
|
CFLAGS += -DABC_USE_PTHREADS
|
|
|
|
|
LIBS += -lpthread
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Using pthreads)
|
2015-10-17 01:27:59 +02:00
|
|
|
endif
|
|
|
|
|
|
2015-10-17 01:44:59 +02:00
|
|
|
# whether to compile into position independent code
|
|
|
|
|
ifdef ABC_USE_PIC
|
2015-10-22 07:56:15 +02:00
|
|
|
CFLAGS += -fPIC
|
2015-10-17 01:44:59 +02:00
|
|
|
LIBS += -fPIC
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Compiling position independent code)
|
2015-10-17 01:44:59 +02:00
|
|
|
endif
|
|
|
|
|
|
2013-05-20 07:15:55 +02:00
|
|
|
# Set -Wno-unused-bug-set-variable for GCC 4.6.0 and greater only
|
|
|
|
|
ifneq ($(or $(findstring gcc,$(CC)),$(findstring g++,$(CC))),)
|
|
|
|
|
empty:=
|
|
|
|
|
space:=$(empty) $(empty)
|
2013-05-04 20:10:25 +02:00
|
|
|
|
2013-05-20 07:15:55 +02:00
|
|
|
GCC_VERSION=$(shell $(CC) -dumpversion)
|
|
|
|
|
GCC_MAJOR=$(word 1,$(subst .,$(space),$(GCC_VERSION)))
|
|
|
|
|
GCC_MINOR=$(word 2,$(subst .,$(space),$(GCC_VERSION)))
|
|
|
|
|
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Found GCC_VERSION $(GCC_VERSION))
|
2013-05-20 07:15:55 +02:00
|
|
|
ifeq ($(findstring $(GCC_MAJOR),0 1 2 3),)
|
2018-06-08 21:03:39 +02:00
|
|
|
ifeq ($(GCC_MAJOR),4)
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Found GCC_MAJOR==4)
|
2013-05-20 07:15:55 +02:00
|
|
|
ifeq ($(findstring $(GCC_MINOR),0 1 2 3 4 5),)
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Found GCC_MINOR>=6)
|
2013-05-04 20:10:25 +02:00
|
|
|
CFLAGS += -Wno-unused-but-set-variable
|
2013-05-20 07:15:55 +02:00
|
|
|
endif
|
2018-06-08 21:03:39 +02:00
|
|
|
else
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Found GCC_MAJOR>=5)
|
2018-06-08 21:03:39 +02:00
|
|
|
CFLAGS += -Wno-unused-but-set-variable
|
|
|
|
|
endif
|
2013-05-20 07:15:55 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
endif
|
2013-05-04 20:10:25 +02:00
|
|
|
|
2013-08-15 09:58:23 +02:00
|
|
|
# LIBS := -ldl -lrt
|
2018-02-06 04:00:46 +01:00
|
|
|
LIBS += -lm
|
2024-03-03 17:02:41 +01:00
|
|
|
ifneq ($(OS), $(filter $(OS), FreeBSD OpenBSD NetBSD))
|
2018-02-06 04:00:46 +01:00
|
|
|
LIBS += -ldl
|
|
|
|
|
endif
|
|
|
|
|
|
2024-03-03 17:02:41 +01:00
|
|
|
ifneq ($(OS), $(filter $(OS), FreeBSD OpenBSD NetBSD Darwin))
|
2013-08-15 09:58:23 +02:00
|
|
|
LIBS += -lrt
|
|
|
|
|
endif
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2017-09-15 19:59:39 +02:00
|
|
|
ifdef ABC_USE_LIBSTDCXX
|
|
|
|
|
LIBS += -lstdc++
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Using explicit -lstdc++)
|
2017-09-15 19:59:39 +02:00
|
|
|
endif
|
2013-05-04 20:10:25 +02:00
|
|
|
|
2025-11-04 01:52:02 +01:00
|
|
|
$(call abc_info,$(MSG_PREFIX)Using CFLAGS=$(CFLAGS))
|
2024-08-06 19:08:22 +02:00
|
|
|
CXXFLAGS += $(CFLAGS) -std=c++17 -fno-exceptions
|
2010-11-01 09:35:04 +01:00
|
|
|
|
2015-10-17 01:27:59 +02:00
|
|
|
SRC :=
|
2012-01-22 03:38:09 +01:00
|
|
|
GARBAGE := core core.* *.stackdump ./tags $(PROG) arch_flags
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2015-10-22 07:56:15 +02:00
|
|
|
.PHONY: all default tags clean docs cmake_info
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2017-10-20 23:41:30 +02:00
|
|
|
include $(patsubst %, $(ABCSRC)/%/module.make, $(MODULES))
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
OBJ := \
|
|
|
|
|
$(patsubst %.cc, %.o, $(filter %.cc, $(SRC))) \
|
2014-10-22 05:13:25 +02:00
|
|
|
$(patsubst %.cpp, %.o, $(filter %.cpp, $(SRC))) \
|
2005-07-29 17:01:00 +02:00
|
|
|
$(patsubst %.c, %.o, $(filter %.c, $(SRC))) \
|
2015-10-17 01:27:59 +02:00
|
|
|
$(patsubst %.y, %.o, $(filter %.y, $(SRC)))
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2016-12-23 03:15:29 +01:00
|
|
|
LIBOBJ := $(filter-out src/base/main/main.o,$(OBJ))
|
|
|
|
|
|
2005-07-29 17:01:00 +02:00
|
|
|
DEP := $(OBJ:.o=.d)
|
|
|
|
|
|
|
|
|
|
# implicit rules
|
|
|
|
|
|
2012-02-17 05:57:03 +01:00
|
|
|
%.o: %.c
|
2024-04-11 16:28:36 +02:00
|
|
|
@mkdir -p $(dir $@)
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Compiling:" $(LOCAL_PATH)/$<
|
2015-10-22 07:56:15 +02:00
|
|
|
$(VERBOSE)$(CC) -c $(OPTFLAGS) $(INCLUDES) $(CFLAGS) $< -o $@
|
2012-02-17 05:57:03 +01:00
|
|
|
|
|
|
|
|
%.o: %.cc
|
2024-04-11 16:28:36 +02:00
|
|
|
@mkdir -p $(dir $@)
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Compiling:" $(LOCAL_PATH)/$<
|
2015-10-22 07:56:15 +02:00
|
|
|
$(VERBOSE)$(CXX) -c $(OPTFLAGS) $(INCLUDES) $(CXXFLAGS) $< -o $@
|
2012-02-17 05:57:03 +01:00
|
|
|
|
2014-10-22 04:45:52 +02:00
|
|
|
%.o: %.cpp
|
2024-04-11 16:28:36 +02:00
|
|
|
@mkdir -p $(dir $@)
|
2014-10-22 04:45:52 +02:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Compiling:" $(LOCAL_PATH)/$<
|
2015-10-22 07:56:15 +02:00
|
|
|
$(VERBOSE)$(CXX) -c $(OPTFLAGS) $(INCLUDES) $(CXXFLAGS) $< -o $@
|
2014-10-22 04:45:52 +02:00
|
|
|
|
2005-07-29 17:01:00 +02:00
|
|
|
%.d: %.c
|
2024-04-11 16:28:36 +02:00
|
|
|
@mkdir -p $(dir $@)
|
2014-10-22 04:45:52 +02:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Generating dependency:" $(LOCAL_PATH)/$<
|
2020-11-19 21:27:24 +01:00
|
|
|
$(VERBOSE)$(ABCSRC)/depends.sh "$(CC)" `dirname $*.c` $(OPTFLAGS) $(INCLUDES) $(CFLAGS) $< > $@
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
%.d: %.cc
|
2024-04-11 16:28:36 +02:00
|
|
|
@mkdir -p $(dir $@)
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Generating dependency:" $(LOCAL_PATH)/$<
|
2020-11-19 21:27:24 +01:00
|
|
|
$(VERBOSE)$(ABCSRC)/depends.sh "$(CXX)" `dirname $*.cc` $(OPTFLAGS) $(INCLUDES) $(CXXFLAGS) $< > $@
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2014-10-22 04:45:52 +02:00
|
|
|
%.d: %.cpp
|
2024-04-11 16:28:36 +02:00
|
|
|
@mkdir -p $(dir $@)
|
2014-10-22 04:45:52 +02:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Generating dependency:" $(LOCAL_PATH)/$<
|
2020-11-19 21:27:24 +01:00
|
|
|
$(VERBOSE)$(ABCSRC)/depends.sh "$(CXX)" `dirname $*.cpp` $(OPTFLAGS) $(INCLUDES) $(CXXFLAGS) $< > $@
|
2014-10-22 04:45:52 +02:00
|
|
|
|
2015-10-22 07:56:15 +02:00
|
|
|
ifndef ABC_MAKE_NO_DEPS
|
2005-07-29 17:01:00 +02:00
|
|
|
-include $(DEP)
|
2015-10-22 07:56:15 +02:00
|
|
|
endif
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
# Actual targets
|
|
|
|
|
|
|
|
|
|
depend: $(DEP)
|
|
|
|
|
|
2015-10-17 01:27:59 +02:00
|
|
|
clean:
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Cleaning up..."
|
Makefile: break apart steps in `make clean`
The `make clean` target consists of a single `rm` call that passes every
generated file, object file, and dependency directory. This results in
a command line that's around 53,800 characters long.
On Linux, the maximum length of a command line is 131,072 or 262,144
characters, however on Windows the limit is 32,768.
The 53,800 character command simply fails to run on Windows, which is a
problem when the first command that gets run is `make clean`.
Break this target into steps, first removing the output files, then the
object files, then any generated garbage, and then the object depedency
directories.
This fixes `make clean` (and as a result yosys) on Windows.
Signed-off-by: Sean Cross <sean@xobs.io>
(cherry picked from commit 11c4f998b25b6c07f4081cea10e2532ebcb7f4d4)
2019-10-19 06:36:14 +02:00
|
|
|
$(VERBOSE)rm -rvf $(PROG) lib$(PROG).a
|
|
|
|
|
$(VERBOSE)rm -rvf $(OBJ)
|
|
|
|
|
$(VERBOSE)rm -rvf $(GARBAGE)
|
|
|
|
|
$(VERBOSE)rm -rvf $(OBJ:.o=.d)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
tags:
|
2012-10-29 23:35:02 +01:00
|
|
|
etags `find . -type f -regex '.*\.\(c\|h\)'`
|
2005-07-29 17:01:00 +02:00
|
|
|
|
|
|
|
|
$(PROG): $(OBJ)
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Building binary:" $(notdir $@)
|
2018-02-06 04:00:46 +01:00
|
|
|
$(VERBOSE)$(LD) -o $@ $^ $(LDFLAGS) $(LIBS)
|
2005-07-29 17:01:00 +02:00
|
|
|
|
2016-12-23 03:15:29 +01:00
|
|
|
lib$(PROG).a: $(LIBOBJ)
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Linking:" $(notdir $@)
|
2019-11-11 09:52:15 +01:00
|
|
|
$(VERBOSE)$(AR) rsv $@ $?
|
2008-01-31 05:01:00 +01:00
|
|
|
|
2016-12-23 03:15:29 +01:00
|
|
|
lib$(PROG).so: $(LIBOBJ)
|
|
|
|
|
@echo "$(MSG_PREFIX)\`\` Linking:" $(notdir $@)
|
|
|
|
|
$(VERBOSE)$(CXX) -shared -o $@ $^ $(LIBS)
|
|
|
|
|
|
2005-07-29 17:01:00 +02:00
|
|
|
docs:
|
2013-11-27 21:17:00 +01:00
|
|
|
@echo "$(MSG_PREFIX)\`\` Building documentation." $(notdir $@)
|
2015-10-17 01:44:59 +02:00
|
|
|
$(VERBOSE)doxygen doxygen.conf
|
2015-10-22 07:56:15 +02:00
|
|
|
|
|
|
|
|
cmake_info:
|
|
|
|
|
@echo SEPARATOR_CFLAGS $(CFLAGS) SEPARATOR_CFLAGS
|
2015-11-05 10:23:31 +01:00
|
|
|
@echo SEPARATOR_CXXFLAGS $(CXXFLAGS) SEPARATOR_CXXFLAGS
|
2015-10-22 07:56:15 +02:00
|
|
|
@echo SEPARATOR_LIBS $(LIBS) SEPARATOR_LIBS
|
|
|
|
|
@echo SEPARATOR_SRC $(SRC) SEPARATOR_SRC
|