-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmake.common
3872 lines (3167 loc) · 113 KB
/
make.common
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
#***********************************************************************
#
# Copyright (c) 2006 Broadcom Corporation
# All Rights Reserved
#
#***********************************************************************/
#
# This makefile is included by most of the lower level makefiles
# to suck in the common defines.
#
default_auto_fail:
@echo ""
@echo "Error - $@ target invoked. This is likely because make.common" >&2
@echo " was included before the default target in a parent Makefile." >&2
@echo ""
exit 1
# GNUMAKEFLAGS := --output-sync=recurse
###########################################
# Define build environment (profile and
# toolchain)
#
###########################################
TARGETS_DIR := $(BUILD_DIR)/targets
INC_KERNEL_BASE := $(BUILD_DIR)/kernel
#
# If we don't define a PROFILE, try to figure out what the last profile
# was and use that.
#
ifneq ($(MAKECMDGOALS), menuconfig)
ifneq ($(MAKECMDGOALS), distclean)
ifneq ($(MAKECMDGOALS), cleanall)
ifneq ($(MAKECMDGOALS), binaryonly_dist_clean)
ifeq ($(HOST_PERLARCH),)
HOST_PERLARCH_COOKIE := $(BUILD_DIR)/.host_perlarch
HOST_PERLARCH := $(strip $(shell cat $(HOST_PERLARCH_COOKIE) 2>/dev/null))
endif #HOST_PERLARCH is not set
ifeq ($(LAST_PROFILE),)
LAST_PROFILE_COOKIE := $(BUILD_DIR)/.last_profile
LAST_PROFILE := $(strip $(shell cat $(LAST_PROFILE_COOKIE) 2>/dev/null))
endif #LAST_PROFILE is not set
export HOST_PERLARCH HOST_PERLARCH_COOKIE LAST_PROFILE_COOKIE LAST_PROFILE
ifeq ($(strip $(PROFILE)),)
PROFILE=$(LAST_PROFILE)
export PROFILE
endif #PROFILE
endif #binaryonly_dist_clean
endif #cleanall
endif #distclean
endif #menuconfig
ifneq ($(strip $(PROFILE)),)
PROFILE_DIR := $(TARGETS_DIR)/$(PROFILE)
PROFILE_FILE := $(PROFILE_DIR)/$(PROFILE)
ifeq ($(strip $(LAST_PROFILE)),)
ifeq ($(strip $(wildcard $(PROFILE_FILE))),)
$(info ./release/maketargets $(PROFILE))
JUNK := $(shell ./release/maketargets $(PROFILE))
endif
endif
ifneq ($(MAKECMDGOALS), menuconfig)
include $(PROFILE_FILE)
# include version make file
#
# version.make has the 4.0.0 version number,
# each directory must set depth appropriately
#
VERSION_MAKE_FILE ?= version.make
include $(BUILD_DIR)/$(VERSION_MAKE_FILE)
ifeq ($(strip $(BRCM_RELEASETAG)),)
BRCM_RELEASETAG=$(BRCM_VERSION).$(BRCM_RELEASE)L.$(BRCM_EXTRAVERSION)
endif
# When building multi-architecture, CURRENT_ARCH will override PROFILE_ARCH
ifneq ($(strip $(CURRENT_ARCH)),)
ORIG_PROFILE_ARCH := $(PROFILE_ARCH)
PROFILE_ARCH := $(CURRENT_ARCH)
TOOLCHAIN_PREFIX :=
ifneq ($(strip $(CURRENT_ARCH)),$(strip $(ORIG_PROFILE_ARCH)))
BCM_INSTALL_SUFFIX := $(CURRENT_ARCH)
BCM_INSTALL_SUFFIX_DIR := /$(BCM_INSTALL_SUFFIX)
# BCM_LIB_INSTALL_SUFFIX assumes there is only arm and aarch64
# If userspace is by default 32bit, then 64bit libs are installed in lib64
# If userspace is by default 64bit, then 32bit libs are installed in lib32
ifeq ($(strip $(CURRENT_ARCH)),arm)
BCM_LIB_INSTALL_SUFFIX := 32
else
BCM_LIB_INSTALL_SUFFIX := 64
endif
TOOLCHAIN_TOP :=
else
# CURRENT_ARCH == ORIG_PROFILE_ARCH
BCM_INSTALL_SUFFIX :=
BCM_INSTALL_SUFFIX_DIR :=
TOOLCHAIN_TOP :=
endif
endif #CURRENT_ARCH
ifndef TOOLCHAIN_BASE
ifeq ($(strip $(DESKTOP_LINUX)),)
TOOLCHAIN_BASE := /opt/toolchains/
endif # DESKTOP_LINUX eq empty
endif
# Define variables for Alternate toolchain if configured
ifeq ($(strip $(BRCM_USE_ALT_TOOLCHAIN)),y)
TOOLCHAIN_BASE := $(ALT_TOOLCHAIN_BASE)
ALT_TOOLCHAIN_BASE = $(subst $\",,$(BRCM_ALT_TOOLCHAIN_BASE))
ALT_ARM_TOOLCHAIN_TOPDIR := $(subst $\",,$(BRCM_ALT_ARM_TOOLCHAIN_TOPDIR))
ALT_ARM_TOOLCHAIN_PREFIX := $(subst $\",,$(BRCM_ALT_ARM_TOOLCHAIN_PREFIX))
ALT_ARM_TOOLCHAIN_SYSROOT_DIR := $(subst $\",,$(BRCM_ALT_ARM_TOOLCHAIN_SYSROOT_DIR))
ALT_ARM_TOOLCHAIN_VER := $(subst $\",,$(BRCM_ALT_ARM_TOOLCHAIN_VER))
ALT_ARM_TOOLCHAIN_TOP := $(ALT_TOOLCHAIN_BASE)/$(ALT_ARM_TOOLCHAIN_TOPDIR)
ifeq ($(strip $(RDK_BUILD)),y)
ALT_ARM_TOOLCHAIN_LIBDIR := usr/lib
ALT_ARM_TOOLCHAIN_INCDIR := usr/include
else
ALT_ARM_TOOLCHAIN_LIBDIR := $(ALT_ARM_TOOLCHAIN_PREFIX)/$(ALT_ARM_TOOLCHAIN_SYSROOT_DIR)/lib
ALT_ARM_TOOLCHAIN_INCDIR := $(ALT_ARM_TOOLCHAIN_PREFIX)/$(ALT_ARM_TOOLCHAIN_SYSROOT_DIR)/usr/include
endif
ALT_AARCH64_TOOLCHAIN_TOPDIR := $(subst $\",,$(BRCM_ALT_AARCH64_TOOLCHAIN_TOPDIR))
export ALT_AARCH64_TOOLCHAIN_PREFIX := $(subst $\",,$(BRCM_ALT_AARCH64_TOOLCHAIN_PREFIX))
ALT_AARCH64_TOOLCHAIN_SYSROOT_DIR := $(subst $\",,$(BRCM_ALT_ARM_TOOLCHAIN_SYSROOT_DIR))
ALT_AARCH64_TOOLCHAIN_VER := $(subst $\",,$(BRCM_ALT_AARCH64_TOOLCHAIN_VER))
export ALT_AARCH64_TOOLCHAIN_TOP := $(ALT_TOOLCHAIN_BASE)/$(ALT_AARCH64_TOOLCHAIN_TOPDIR)
ALT_AARCH64_TOOLCHAIN_LIBDIR := $(ALT_AARCH64_TOOLCHAIN_PREFIX)/$(ALT_AARCH64_TOOLCHAIN_SYSROOT_DIR)/lib
ALT_AARCH64_TOOLCHAIN_INCDIR := $(ALT_AARCH64_TOOLCHAIN_PREFIX)/$(ALT_AARCH64_TOOLCHAIN_SYSROOT_DIR)/usr/include
endif
#
# Get Kernel and Toolchain versions based
# on profile
#
# --- KERNEL VERSION SPECIFIC INFORMATION:
# for ARM, Linux 4.19
ifeq ($(strip $(BRCM_USE_ALT_TOOLCHAIN)),y)
DEFAULT_TOOLCHAIN_LINUX_4_19_0_ARM := $(ALT_ARM_TOOLCHAIN_TOP)
TOOLCHAIN_PREFIX_LINUX_4_19_0_ARM := $(ALT_ARM_TOOLCHAIN_PREFIX)
DEFAULT_TOOLCHAIN_VER_LINUX_4_19_0_ARM := $(ALT_ARM_TOOLCHAIN_VER)
TOOLCHAIN_LIBDIR_LINUX_4_19_0_ARM := $(ALT_ARM_TOOLCHAIN_LIBDIR)
TOOLCHAIN_INCDIR_LINUX_4_19_0_ARM := $(ALT_ARM_TOOLCHAIN_INCDIR)
else
DEFAULT_TOOLCHAIN_LINUX_4_19_0_ARM := $(TOOLCHAIN_BASE)/crosstools-arm-gcc-9.2-linux-4.19-glibc-2.30-binutils-2.32
DEFAULT_TOOLCHAIN_VER_LINUX_4_19_0_ARM := 9.2.0
TOOLCHAIN_PREFIX_LINUX_4_19_0_ARM := arm-buildroot-linux-gnueabi
TOOLCHAIN_LIBDIR_LINUX_4_19_0_ARM := $(TOOLCHAIN_PREFIX_LINUX_4_19_0_ARM)/sysroot/lib
TOOLCHAIN_INCDIR_LINUX_4_19_0_ARM := $(TOOLCHAIN_PREFIX_LINUX_4_19_0_ARM)/sysroot/usr/include
endif
# for AARCH64, Linux 4.19
ifeq ($(strip $(RDK_BUILD)),y)
#RDK build, using BRCM toolchain for kernel space in specified location
DEFAULT_TOOLCHAIN_LINUX_4_19_0_AARCH64 := $(TOOLCHAIN_BASE_AARCH64)/crosstools-aarch64-gcc-9.2-linux-4.19-glibc-2.30-binutils-2.32
DEFAULT_TOOLCHAIN_VER_LINUX_4_19_0_AARCH64 := 9.2.0
TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64 := aarch64-buildroot-linux-gnu
TOOLCHAIN_LIBDIR_LINUX_4_19_0_AARCH64 := $(TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64)/sysroot/lib
TOOLCHAIN_INCDIR_LINUX_4_19_0_AARCH64 := $(TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64)/sysroot/usr/include
else ifeq ($(strip $(BRCM_USE_ALT_TOOLCHAIN)),y)
DEFAULT_TOOLCHAIN_LINUX_4_19_0_AARCH64 := $(ALT_AARCH64_TOOLCHAIN_TOP)
TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64 := $(ALT_AARCH64_TOOLCHAIN_PREFIX)
DEFAULT_TOOLCHAIN_VER_LINUX_4_19_0_AARCH64 := $(ALT_AARCH64_TOOLCHAIN_VER)
TOOLCHAIN_LIBDIR_LINUX_4_19_0_AARCH64 := $(ALT_AARCH64_TOOLCHAIN_LIBDIR)
TOOLCHAIN_INCDIR_LINUX_4_19_0_AARCH64 := $(ALT_AARCH64_TOOLCHAIN_INCDIR)
else
DEFAULT_TOOLCHAIN_LINUX_4_19_0_AARCH64 := $(TOOLCHAIN_BASE)/crosstools-aarch64-gcc-9.2-linux-4.19-glibc-2.30-binutils-2.32
DEFAULT_TOOLCHAIN_VER_LINUX_4_19_0_AARCH64 := 9.2.0
TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64 := aarch64-buildroot-linux-gnu
TOOLCHAIN_LIBDIR_LINUX_4_19_0_AARCH64 := $(TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64)/sysroot/lib
TOOLCHAIN_INCDIR_LINUX_4_19_0_AARCH64 := $(TOOLCHAIN_PREFIX_LINUX_4_19_0_AARCH64)/sysroot/usr/include
endif
LINUX_ZIP_FILE_LINUX_4_19_0 := src-linux-4.19.tar.bz2
LINUX_SUB_DIR_LINUX_4_19_0 := linux-4.19
LINUX_VER_STR_LINUX_4_19_0 := 4.19.151
ifeq ($(strip $(PROFILE_ARCH)),mips)
ARCHCAP := MIPS
ARCH := mips
ARCH_ENDIAN := big
export BRCM_ENDIAN_FLAGS := -b
else
ARCH_ENDIAN := little
export BRCM_ENDIAN_FLAGS := -l
ifeq ($(strip $(PROFILE_ARCH)),arm)
ARCHCAP := ARM
ARCH := arm
endif
ifeq ($(strip $(PROFILE_ARCH)),mipsel)
ARCHCAP := MIPSEL
ARCH := mips
endif
ifeq ($(strip $(PROFILE_ARCH)),aarch64)
ARCHCAP := AARCH64
ARCH := arm64
endif
ifeq ($(strip $(PROFILE_ARCH)),i386)
ARCHCAP := I386
ARCH := i386
endif
ifeq ($(strip $(DESKTOP_LINUX)),y)
ifeq ($(shell uname -m),x86_64)
ARCHCAP := X86_64
# uncomment the next line to have 64-bit compiling environment if the build machine is a 64-bit system
# ARCH := x86
endif
ifeq ($(shell uname -m),i686)
ARCHCAP := I686
ARCH := i686
endif
endif
endif
# set up kernel build tool arch, if KERNEL_ARCH not specified, kernel use the same as user profile arch
ifeq ($(strip $(KERNEL_ARCH)),)
KERNEL_ARCH := $(PROFILE_ARCH)
endif
ifeq ($(strip $(KERNEL_ARCH)),mips)
KARCHCAP := MIPS
KARCH := mips
else
ifeq ($(strip $(KERNEL_ARCH)),arm)
KARCHCAP := ARM
KARCH := arm
endif
ifeq ($(strip $(KERNEL_ARCH)),mipsel)
KARCHCAP := MIPSEL
KARCH := mips
endif
ifeq ($(strip $(KERNEL_ARCH)),aarch64)
KARCHCAP := AARCH64
KARCH := arm64
endif
ifeq ($(strip $(KERNEL_ARCH)),i386)
KARCHCAP := I386
KARCH := i386
endif
ifeq ($(strip $(DESKTOP_LINUX)),y)
ifeq ($(shell uname -m),x86_64)
KARCHCAP := X86_64
KARCH := x86_64
endif
ifeq ($(shell uname -m),i686)
KARCHCAP := I686
KARCH := i686
endif
endif
endif
# ---
ifeq ($(PROFILE_KERNEL_VER),)
$(error KERNEL VERSION not specified in profile $(PROFILE_FILE))
endif
ifndef TOOLCHAIN_TOP
TOOLCHAIN_TOP := ${DEFAULT_TOOLCHAIN_${PROFILE_KERNEL_VER}_${ARCHCAP}}
endif
ifndef KTOOLCHAIN_TOP
KTOOLCHAIN_TOP := ${DEFAULT_TOOLCHAIN_${PROFILE_KERNEL_VER}_${KARCHCAP}}
endif
ifeq ($(strip $(RDK_BUILD)),)
# Older toolchains have a toplevel usr under which lie all the bins, includes and libs, if it exists then use it
TOOLCHAIN_USR_DIR := $(shell if test -d $(TOOLCHAIN_TOP)/usr ; then echo "usr"; else echo ""; fi; )
endif
TOOLCHAIN_VER := ${DEFAULT_TOOLCHAIN_VER_${PROFILE_KERNEL_VER}_${ARCHCAP}}
TOOLCHAIN_LIBDIR := ${TOOLCHAIN_LIBDIR_${PROFILE_KERNEL_VER}_${ARCHCAP}}
TOOLCHAIN_INCDIR := ${TOOLCHAIN_INCDIR_${PROFILE_KERNEL_VER}_${ARCHCAP}}
ifeq ($(TOOLCHAIN_PREFIX),)
TOOLCHAIN_PREFIX := ${TOOLCHAIN_PREFIX_${PROFILE_KERNEL_VER}_${ARCHCAP}}
endif
export TOOLCHAIN_PREFIX
ifeq ($(strip $(BRCM_USE_ALT_TOOLCHAIN)),y)
ifeq ($(strip $(RDK_BUILD)),y)
TOOLCHAIN_SYSROOT := $(TOOLCHAIN_TOP)
else
TOOLCHAIN_SYSROOT := $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/$(TOOLCHAIN_PREFIX)/${ALT_${ARCHCAP}_TOOLCHAIN_SYSROOT_DIR}
endif
else
TOOLCHAIN_SYSROOT := $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/$(TOOLCHAIN_PREFIX)/sysroot
endif
LINUX_VER_STR := ${LINUX_VER_STR_${PROFILE_KERNEL_VER}}
KTOOLCHAIN_VER := ${DEFAULT_TOOLCHAIN_VER_${PROFILE_KERNEL_VER}_${KARCHCAP}}
KTOOLCHAIN_PREFIX:= ${TOOLCHAIN_PREFIX_${PROFILE_KERNEL_VER}_${KARCHCAP}}
pbuildvar:
@echo "-----toolchain variables----"
@echo BRCM_USE_ALT_TOOLCHAIN: ${BRCM_USE_ALT_TOOLCHAIN}
@echo ALT_TOOLCHAIN_BASE: ${ALT_TOOLCHAIN_BASE}
@echo TOOLCHAIN_BASE: ${TOOLCHAIN_BASE}
@echo TOOLCHAIN_BASE_AARCH64: ${TOOLCHAIN_BASE_AARCH64}
@echo RDK_BUILD: ${RDK_BUILD}
@echo "-----kernel toolchain----"
@echo KTOOLCHAIN_TOP: ${KTOOLCHAIN_TOP}
@echo KTOOLCHAIN_PREFIX: ${KTOOLCHAIN_PREFIX}
@echo KCROSS_COMPILE: ${KCROSS_COMPILE}
@echo "-----userspace toolchain----"
@echo TOOLCHAIN_TOP: ${TOOLCHAIN_TOP}
@echo TOOLCHAIN_PREFIX: ${TOOLCHAIN_PREFIX}
@echo TOOLCHAIN_USR_DIR: ${TOOLCHAIN_USR_DIR}
@echo TOOLCHAIN_INCDIR: ${TOOLCHAIN_INCDIR}
@echo TOOLCHAIN_LIBDIR: ${TOOLCHAIN_LIBDIR}
@echo CROSS_COMPILE: ${CROSS_COMPILE}
@echo LIBDIR: ${LIBDIR}
@echo TOOLCHAIN_INCLUDE_DIR: ${TOOLCHAIN_INCLUDE_DIR}
@echo TOOLCHAIN_SYSROOT: ${TOOLCHAIN_SYSROOT}
CONFIG_BCM_KERNEL_CUSTOM:=y
BCM_KF:=y
LINUX_ZIP_FILE := ${LINUX_ZIP_FILE_${PROFILE_KERNEL_VER}}
LINUX_SUB_DIR := ${LINUX_SUB_DIR_${PROFILE_KERNEL_VER}}
INC_DIR:=include/uapi
KERNEL_DIR := $(BUILD_DIR)/kernel/$(LINUX_SUB_DIR)
KERNEL_LINKS_DIR := $(INC_KERNEL_BASE)
KERNEL_INCLUDE_LINK_NAME := bcm_local_kernel_include
KERNEL_MIPS_INCLUDE_LINK_NAME := bcm_local_kernel_mips_include
KERNEL_ARM_INCLUDE_LINK_NAME := bcm_local_kernel_arm_include
#KERNEL_GEN_INCLUDE_LINK_NAME := bcm_local_kernel_gen_include
KERNEL_INCLUDE_LINK := $(KERNEL_LINKS_DIR)/$(KERNEL_INCLUDE_LINK_NAME)
KERNEL_MIPS_INCLUDE_LINK := $(KERNEL_LINKS_DIR)/$(KERNEL_MIPS_INCLUDE_LINK_NAME)
KERNEL_ARM_INCLUDE_LINK := $(KERNEL_LINKS_DIR)/$(KERNEL_ARM_INCLUDE_LINK_NAME)
#KERNEL_GEN_INCLUDE_LINK_NAME := bcm_local_kernel_gen_include
DTS_DIR := $(BUILD_DIR)/kernel
export DTS_DIR
export BRCM_CHIP
export BRCM_FLASHPSI_SIZE
export BRCM_DRIVER_WIRELESS_PCMCIA_DATASWAP BRCM_DRIVER_WIRELESS_EBI_DMA
export BRCM_DRIVER_USB BRCM_DRIVER_ETHERNET_CONFIG BRCM_DRIVER_GPON BRCM_DRIVER_XTM BRCM_DRIVER_ADSL
export BRCM_DRIVER_LOG
export BRCM_DRIVER_ISDN
export BRCM_DRIVER_EMMC
export BRCM_DEFAULTCFG
export BRCM_CERT_FILE
export BRCM_KERNEL_NF_FIREWALL BRCM_KERNEL_NF_MANGLE
export BRCM_KERNEL_NF_NAT_ALG_FTP BRCM_KERNEL_NF_NAT_ALG_SIP BRCM_KERNEL_NF_NAT_ALG_H323 BRCM_KERNEL_NF_NAT_ALG_H323_SIGNAL_PROXY
export BRCM_KERNEL_NF_NAT_ALG_IRC BRCM_KERNEL_NF_NAT_ALG_WM BRCM_KERNEL_NF_NAT_ALG_PT BRCM_KERNEL_NF_NAT_ALG_PPTP
export BRCM_KERNEL_NF_NAT_ALG_RTSP BRCM_KERNEL_NF_NAT_ALG_SNMP BRCM_KERNEL_NF_NAT_ALG_TALK
export BRCM_EXT_SWITCH_TYPE
export BCM_PHY_54616
export BRCM_BOARD_ID BRCM_NUM_MAC_ADDRESSES BRCM_BASE_MAC_ADDRESS BRCM_PSI_SIZE
export BUILD_SECURE_BOOT SECURE_BOOT_NUM_BTLDR_IMAGES SECURE_BOOT_NUM_BOOT_BLKS SECURE_BOOT_NOR_BOOT_SIZE
export BTRM_BOOT_ONLY BTRM_NAND_BOOT_PARTITION_SIZE BTRM_NUM_IMAGES_IN_PARTITION BTRM_IMAGE_SIZE_ALLOCATION BTRM_NUM_NVRAM_DATA_IN_PARTITION
export SECURE_BOOT_PROCESS_FLD_OEM_COT SECURE_BOOT_ENCRYPT_BTLDRS
export BRCM_AUXFS_PERCENT BRCM_GPON_SERIAL_NUMBER BRCM_GPON_PASSWORD
export BRCM_VOICE_BOARD_ID BRCM_MAIN_TP_NUM
export BRCM_DRIVER_FBOND_DEBUG
export BRCM_MISC1_PARTITION_SIZE BRCM_MISC2_PARTITION_SIZE BRCM_MISC3_PARTITION_SIZE BRCM_MISC4_PARTITION_SIZE
export BUILD_HND_MFG BUILD_HND_NIC BUILD_HND_EAP BUILD_BRCM_CPEROUTER BUILD_BRCM_AIRIQ BUILD_HND_EAP_AP1 BUILD_BRCM_HOSTAPD
export BUILD_BRCM_CMS BUILD_BRCM_BDK
export BRCM_INCREMENTAL_IMAGE_LOAD
export SECURE_BOOT_ARCH SECURE_BOOT_KEY_DIR SECURE_BOOT_TURNKEY SECURE_BOOT_TK_ABORT_TIMEOUT SECURE_BOOT_TK_REQ_FLD SECURE_BOOT_TK_MODE_REQ SECURE_BOOT_TK_MID SECURE_BOOT_TK_KS_OFFS SECURE_BOOT_TK_OID BUILD_SBI_NOHDR BUILD_SBI_SIGN BUILD_SBI_NOHDR_MFG AVS_IMAGE_MAX_SIZE AVS_IMAGE_PATH
endif # PROFILE
endif #menuconfig
###########################################
# Define Basic Variables
#
###########################################
BL_BUILD_DIR=$(BUILD_DIR)/cfe/build/broadcom/bcm63xx_rom
BRCM_BOARD := bcm963xx
BRCMDRIVERS_DIR = $(BUILD_DIR)/bcmdrivers
RDPSDK_DIR=$(BUILD_DIR)/rdp
ifeq ($(strip $(BRCM_CHIP)),63138)
RDP_PROJECT=DSL_63138
endif
ifeq ($(strip $(BRCM_CHIP)),63148)
RDP_PROJECT=DSL_63148
endif
ifneq ($(findstring _$(strip $(BRCM_CHIP))_,_6858_6846_63158_6856_6878_63146_4912_),)
export BRCM_FULL_CHIP_NAME=$(strip $(BRCM_CHIP)$(subst $\",,$(BRCM_CHIP_REV)))
endif
ifeq ($(strip $(BRCM_CHIP)),6858)
ifeq ($(strip $(BRCM_XDSL_DISTPOINT_USE_G9991)),)
ifneq (,$(filter y,$(BRCM_GPON_HGU) $(BRCM_EPON_HGU) $(BUILD_HND_EAP)))
RDP_PROJECT=PON_6858_FC
else
ifeq ($(strip $(BUILD_RDPA_FC)),y)
RDP_PROJECT=PON_6858_FC
ifeq ($(strip $(BUILD_RDPA_PRV)),y)
RDP_PROJECT2=PON_6858_PRV
endif
else
RDP_PROJECT=PON_6858_PRV
endif
endif
else
RDP_PROJECT=PON_6858_G9991
endif
else
endif
ifeq ($(strip $(BRCM_CHIP)),4908)
ifneq ($(strip $(BUILD_HND_EAP)),)
RDP_PROJECT=WL4908_EAP
else
RDP_PROJECT=WL4908
endif
endif
ifeq ($(strip $(BRCM_CHIP)),6846)
ifneq (,$(filter y,$(BRCM_GPON_HGU) $(BRCM_EPON_HGU)))
RDP_PROJECT=PON_6846_FC
else
ifeq ($(strip $(BUILD_RDPA_FC)),y)
RDP_PROJECT=PON_6846_FC
ifeq ($(strip $(BUILD_RDPA_PRV)),y)
RDP_PROJECT2=PON_6846_PRV
endif
else
RDP_PROJECT=PON_6846_PRV
endif
endif
endif
ifeq ($(strip $(BRCM_CHIP)),6878)
RDP_PROJECT=PON_6878_FC
endif
ifeq ($(strip $(BRCM_CHIP)),63158)
RDP_PROJECT=DSL_63158
endif
ifeq ($(strip $(BRCM_CHIP)),63146)
ifeq ($(strip $(BRCM_CHIP_REV)),"A0")
RDP_PROJECT=DSL_63146_A0
else
RDP_PROJECT=DSL_63146
endif
endif
ifeq ($(strip $(BRCM_CHIP)),4912)
RDP_PROJECT=WL4912
endif
ifeq ($(strip $(BRCM_CHIP)),6856)
ifneq (,$(filter y,$(BRCM_GPON_HGU) $(BRCM_EPON_HGU)))
RDP_PROJECT=PON_6856_FC
else
ifeq ($(strip $(BUILD_RDPA_FC)),y)
RDP_PROJECT=PON_6856_FC
ifeq ($(strip $(BUILD_RDPA_PRV)),y)
RDP_PROJECT2=PON_6856_PRV
endif
else
RDP_PROJECT=PON_6856_PRV
endif
endif
endif
ifneq ($(strip $(RDP_PROJECT)),)
PROJECT_DIR = $(RDPSDK_DIR)/projects/$(RDP_PROJECT)
RDP_PROJECT_DIR_RELATIVE = ../../rdp/projects/$(RDP_PROJECT)
include $(PROJECT_DIR)/make.proj_flags
endif
HOSTTOOLS_DIR = $(BUILD_DIR)/hostTools
HOSTTOOLS_PERL_LIB = $(HOSTTOOLS_DIR)/PerlLib:$(HOSTTOOLS_DIR)/local_install/Perl/:$(HOSTTOOLS_DIR)/PerlLib/$(HOST_PERLARCH)/
IMAGES_DIR = $(BUILD_DIR)/images
RELEASE_DIR = $(BUILD_DIR)/release
TARGETS_DIR = $(BUILD_DIR)/targets
DEFAULTCFG_DIR = $(TARGETS_DIR)/defaultcfg
FSSRC_DIR = $(TARGETS_DIR)/fs.src
# nor flash ()
ifeq ($(strip $(BUILD_DYNAMIC_CFE)),y)
# build on the fly
CFE_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_nor/cfe$(BRCM_CHIP).bin
CFESEC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferomsec_nor/cfesec$(BRCM_CHIP).bin
else
# not build-on-the-fly
CFE_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP).bin
CFESEC_FILE = $(TARGETS_DIR)/cfe/cfesec$(BRCM_CHIP).bin
endif
ifeq ($(strip $(SECURE_BOOT_ARCH)),GEN3)
include $(BUILD_DIR)/build/sec.mk
else
include $(BUILD_DIR)/build/sec.gen2.mk
endif
ifeq ($(strip $(BUILD_DYNAMIC_CFE)),y)
# build on the fly
export CFE_ROM_XIP = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_nand_xip/cfe$(BRCM_CHIP)rom.bin
CFE_ROM_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_nand/cfe$(BRCM_CHIP)rom.bin
CFE_ROM_EMMC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_emmc/cfe$(BRCM_CHIP)rom.bin
CFE_RAM_EMMC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferam_emmc/cfe$(BRCM_CHIP)ram.bin
CFE_RAM_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferam_nand/cfe$(BRCM_CHIP)ram.bin
else
# not build-on-the-fly
CFE_ROM_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP)rom.bin
export CFE_ROM_XIP = $(CFE_ROM_FILE)
ifeq ($(find $(strip $(BRCM_FULL_CHIP_NAME))),6858B0)
CFE_ROM_EMMC_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP)rom_emmc.bin
CFE_RAM_EMMC_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP)ram_emmc_b0.bin
else
CFE_ROM_EMMC_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP)rom_emmc.bin
CFE_RAM_EMMC_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP)ram_emmc.bin
endif
CFE_RAM_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP)ram.bin
# end not build-on-the-fly
endif
BUILD_SBI_UNSEC=$(HOSTTOOLS_DIR)/imagetools/image.sbi --smode "UNSEC"
ifeq ($(strip $(BUILD_SECURE_BOOT)),y)
ifeq ($(strip $(SECURE_BOOT_TURNKEY)),y)
SEC_TK=_tk
endif
SEC_CRED_DIR=$(BUILD_DIR)/$(SECURE_BOOT_KEY_DIR)
export SEC_CRED_DIR
ifeq ($(strip $(SECURE_BOOT_ARCH)),GEN2)
SEC_GEN2=_sec
SEC_MODE=OP
SIGN_SECOPT=sign
NOHDR_SECOPT=noheader
else
# GEN3 Secure
SEC_MODE=FLD
ifeq ($(strip $(SECURE_BOOT_PROCESS_FLD_OEM_COT)),y)
NOHDR_SECOPT=oem encrypt noheader
SIGN_SECOPT=oem sign
else
NOHDR_SECOPT=encrypt noheader
SIGN_SECOPT=sign
endif
BUILD_SBI_NOHDR_MFG=$(HOSTTOOLS_DIR)/imagetools/image.sbi --smode "MFG" --nohdr "sbi"
endif #GEN3 Secure
#common set of arguments for each feature: MFG SEC/FLD SEC, encrypted non headered (cferam) and Unsecure headered
BUILD_SBI_SIGN=$(HOSTTOOLS_DIR)/imagetools/image.sbi --smode "$(SEC_MODE)" --nohdr "sign"
BUILD_SBI=$(HOSTTOOLS_DIR)/imagetools/image.sbi --smode "$(SEC_MODE)"
BUILD_SBI_NOHDR=$(HOSTTOOLS_DIR)/imagetools/image.sbi --smode "$(SEC_MODE)" --nohdr "sbi"
ifneq ($(strip $(SEC_TK)),)
ifeq ($(strip $(BUILD_DYNAMIC_CFE)),y)
CFE_ROM_FILE_TK = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_nand$(SEC_TK)/cfe$(BRCM_CHIP)rom.bin
CFE_ROM_EMMC_FILE_TK = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_emmc$(SEC_TK)/cfe$(BRCM_CHIP)rom.bin
ifneq ($(strip $(SEC_GEN2)),)
CFESEC_ROM_FILE_TK = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_nand$(SEC_GEN2)$(SEC_TK)/cfe$(BRCM_CHIP)rom.bin
CFESEC_ROM_EMMC_FILE_TK = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_emmc$(SEC_GEN2)$(SEC_TK)/cfe$(BRCM_CHIP)rom.bin
endif
endif
endif
ifneq ($(findstring _$(strip $(BRCM_CHIP))_,_47622_63178_4908_6838_6848_6858_63158_6856_6878_),)
CFESEC_ROM_FILE = $(CFE_ROM_FILE)
CFESEC_RAM_FILE = $(CFE_RAM_FILE)
CFESEC_ROM_EMMC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_emmc/cfe$(BRCM_CHIP)rom.bin
CFESEC_RAM_EMMC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferam_emmc/cfe$(BRCM_CHIP)ram.bin
else
#GEN2 Platforms
ifeq ($(strip $(BUILD_DYNAMIC_CFE)),y)
CFESEC_ROM_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_nand$(SEC_GEN2)/cfe$(BRCM_CHIP)rom.bin
CFESEC_RAM_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferam_nand$(SEC_GEN2)/cfe$(BRCM_CHIP)ram.bin
CFESEC_ROM_EMMC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferom_emmc$(SEC_GEN2)/cfe$(BRCM_CHIP)rom.bin
CFESEC_RAM_EMMC_FILE = $(BUILD_DIR)/cfe/build/broadcom/build_cferam_emmc$(SEC_GEN2)/cfe$(BRCM_CHIP)ram.bin
else
CFESEC_ROM_FILE = $(TARGETS_DIR)/cfe/cfesec$(BRCM_CHIP)rom.bin
CFESEC_RAM_FILE = $(TARGETS_DIR)/cfe/cfesec$(BRCM_CHIP)ram.bin
endif
endif
endif
ifneq ($(findstring _$(strip $(BRCM_CHIP))_,_63158_47622_),)
CFE_DDR_TYPE_CHECK=y
endif
export CFE_RAM_FILE
ifeq ($(strip $(BRCM_CHIP)),4908)
PRE_CFE_ROM = --precferom $(TARGETS_DIR)/cfe/precfe$(BRCM_CHIP)rom.bin
endif
BRCM_DTB = 9$(BRCM_CHIP).dtb
DTB_DIR = $(DTS_DIR)/dts/$(BRCM_CHIP)
DTB_FILE = $(DTB_DIR)/$(BRCM_DTB)
SHARED_DIR = $(BUILD_DIR)/shared
CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
else if [ -x /bin/bash ]; then echo /bin/bash; \
else echo sh; fi ; fi)
GENDEFCONFIG_CMD = $(HOSTTOOLS_DIR)/scripts/gendefconfig
USERSPACE_PUBLIC_LIBS_DIR=$(BUILD_DIR)/userspace/public/libs
USERSPACE_DL_MODULES_DIR=$(BUILD_DIR)/userspace/dlModules
USERSPACE_DL_MODULES_BEEP_DIR=$(USERSPACE_DL_MODULES_DIR)/beep
BEEP_PKT_INFO_SUFIX = -pkginfo.txt
BEEP_TAR_GZ_PREFIX = pkg_
BEEP_TAR_GZ_SUFIX = .tar.gz
KERNEL_DEBUG?=0
KERNEL_KALLSYMS=0
#need to export perl library path
# as it is needed by root makefile rules
PERL5LIB=$(HOSTTOOLS_PERL_LIB)
export PERL5LIB
# unexport conficting perl switches that Centos 7 adds by default
unexport PERL_MB_OPT PERL_LOCAL_LIB_ROOT PERL_MM_OPT
MLIBTOOL=$(HOSTTOOLS_DIR)/mlibtool/mlibtool
ifdef FORCE
COND_FAIL:=(echo "NOT FAILING DUE TO FORCE=$(FORCE)";true)
else #FORCE
COND_FAIL:=(false)
endif #else FORCE
#
# This is for CMS
# We could put this in the make menuconfig, but it might
# confuse the users. For now, we only support one target OS.
# Everytime we see OALDIR, substitute it with linux
#
TARGET_OS = LINUX
OALDIR = $(subst LINUX,linux,$(strip $(TARGET_OS)))
export PROFILE_ARCH KERNEL_DIR BRCMDRIVERS_DIR PROJECT_DIR RDP_PROJECT_DIR_RELATIVE \
LINUXDIR HOSTTOOLS_DIR TARGETS_DIR DEFAULTCFG_DIR \
FSSRC_DIR SHARED_DIR CONFIG_BCM_KERNEL_CUSTOM BCM_KF\
CMS_LOG_FLAGS OALDIR USERSPACE_PUBLIC_LIBS_DIR \
ARCH ARCH_ENDIAN KARCH TOOLCHAIN_BASE BRCM_DTB DTB_DIR
unexport LS_COLORS
export DESKTOP_LINUX BRCM_BOARD BRCM_UCLIBC
# update profile BCM_WLIMPL if overridden from CLI
ifneq ($(strip $(WLIMPL)),)
export BCM_WLIMPL := $(WLIMPL)
endif
ifneq ($(strip $(BUILD_BRCM_CPEROUTER)),)
$(info "Build BCA Wireless Router")
#enable HND WAY of compiling
export BUILD_BRCM_HNDROUTER=y
export BCA_CPEROUTER=y
endif
ifneq ($(strip $(BUILD_BRCM_HNDROUTER)),)
ifeq ($(strip $(BUILD_HND_NIC)),)
export BCM_EXTFDIMAGE_PATH=/etc/wlan/dhd
endif
HNDCOMP_RDIR = main/components/router
HNDROUTER_DIR = bcmdrivers/broadcom/net/wl/impl$(BCM_WLIMPL)/$(HNDCOMP_RDIR)
HNDROUTER_BASE = $(HNDROUTER_DIR)
HNDDRIVER_BASE = $(HNDCOMP_RDIR)
HNDAPPS_BASE = $(HNDCOMP_RDIR)
export HNDAPPS_IN_COMP=y
export HNDAPPS_DIR=$(BUILD_DIR)/$(HNDROUTER_DIR)
export HNDROUTER_BASE
export HNDDRIVER_BASE
export HNDAPPS_BASE
endif # BCA_HNDROUTER
###########################################
#
# Define Toolchain
#
###########################################
ifeq ($(strip $(DESKTOP_LINUX)),)
KTOOLCHAIN = $(KTOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)
TOOLCHAIN = $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)
TOOLCHAIN_INCLUDE_DIR = $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/$(TOOLCHAIN_INCDIR)
LIBDIR = $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/$(TOOLCHAIN_LIBDIR)
USRGCCLIBDIR = $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/lib/gcc/$(TOOLCHAIN_PREFIX)/$(TOOLCHAIN_VER)
# For legacy makefiles which still use LIB_PATH and LIBCDIR
LIB_PATH = $(LIBDIR)
LIBCDIR = $(LIBDIR)
ifeq ($(strip $(ARCH)),arm64)
EXTRALIBDIR_NAME := lib64
else
EXTRALIBDIR_NAME := lib
endif
EXTRALIBDIR = $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/$(TOOLCHAIN_PREFIX)/$(EXTRALIBDIR_NAME)
EXTRAINCDIR = $(TOOLCHAIN_TOP)/$(TOOLCHAIN_USR_DIR)/lib/gcc/$(TOOLCHAIN_PREFIX)/$(TOOLCHAIN_VER)/include
ifndef NO_WERRS
# The new compiler has a bug that if you specify -Werror=frame-larger-than=X, it treats X as 1 (and errors on all functions)
#export BRCM_WERROR_CFLAGS := -Werror=return-type -Werror=uninitialized -Wframe-larger-than=1024
export BRCM_WERROR_CFLAGS := -Werror=return-type -Werror=uninitialized -Wno-date-time
else
export BRCM_WERROR_CFLAGS := -Wno-date-time
endif
ifeq ($(PROFILE_KERNEL_VER),LINUX_4_19_0)
BRCM_WERROR_CFLAGS += -Wno-implicit-fallthrough -Wno-array-bounds
#BRCM_WERROR_CFLAGS += -Wno-implicit-fallthrough -Wno-misleading-indentation -Wno-format-truncation -Wno-stringop-truncation -Wno-format-overflow
export BRCM_WERROR_CFLAGS
endif
ifeq ($(ARCH),mips)
BRCM_COMMON_CFLAGS := -Os -march=mips32 -fomit-frame-pointer -fno-strict-aliasing -mabi=32 -G0 -msoft-float -pipe -Wa,-mips32 $(BRCM_WERROR_CFLAGS)
BRCM_APP_CFLAGS := $(BRCM_COMMON_CFLAGS) -mno-shared
endif
ifeq ($(ARCH),arm)
BRCM_COMMON_CFLAGS := -Os -march=armv7-a -fomit-frame-pointer -mno-thumb-interwork -mabi=aapcs-linux -marm -fno-common -ffixed-r8 -msoft-float -D__ARM_ARCH_7A__ $(BRCM_WERROR_CFLAGS)
#for mips' -mno-shared (do not generate posistion independent code), arm is -mno-apcs-reentrant which is the default
ifeq ($(CMS_MEM_LEAK_TRACING),y)
# These extra flags are needed by ARM stack backtrace function
BRCM_COMMON_CFLAGS += -fasynchronous-unwind-tables -rdynamic
endif
BRCM_APP_CFLAGS := $(BRCM_COMMON_CFLAGS)
endif # ARCH eq arm
CROSS_COMPILE = $(TOOLCHAIN)/bin/$(TOOLCHAIN_PREFIX)-
KCROSS_COMPILE = $(KTOOLCHAIN)/bin/$(KTOOLCHAIN_PREFIX)-
else # DESKTOP_LINUX
CROSS_COMPILE = $(TOOLCHAIN_BASE)/usr/bin/
TOOLCHAIN_INCLUDE_DIR = /
endif
CMN_COMPILE_FLAGS :=
AR = $(CROSS_COMPILE)ar
AS = $(CROSS_COMPILE)as
LD = $(CROSS_COMPILE)ld
CC = $(CROSS_COMPILE)gcc
CXX = $(CROSS_COMPILE)g++
CPP = $(CROSS_COMPILE)cpp
NM = $(CROSS_COMPILE)nm
STRIP = $(CROSS_COMPILE)strip
SSTRIP = $(CROSS_COMPILE)strip
OBJCOPY = $(CROSS_COMPILE)objcopy
OBJDUMP = $(CROSS_COMPILE)objdump
RANLIB = $(CROSS_COMPILE)ranlib
READELF = $(CROSS_COMPILE)readelf
KSTRIP = $(KCROSS_COMPILE)strip
KOBJCOPY = $(KCROSS_COMPILE)objcopy
KOBJDUMP = $(KCROSS_COMPILE)objdump
# IF using alternate toolchain, specify sysroot on linker line
ifeq ($(strip $(BRCM_USE_ALT_TOOLCHAIN)),y)
LD = $(CROSS_COMPILE)ld --sysroot=$(TOOLCHAIN_SYSROOT)
# need to specify the sysroot for gcc, otherwise stdio.h cant be found
# try to compile a simple C file 'gcc -v -E test.c' to observe where gcc is
# looking for include files.
# Just specifying --sysroot through CFLAGS isn't enough, as some packages will
# call CC for link purpose.
CC = $(CROSS_COMPILE)gcc --sysroot=$(TOOLCHAIN_SYSROOT) -pthread
CXX = $(CROSS_COMPILE)c++ --sysroot=$(TOOLCHAIN_SYSROOT) -pthread
CPP = $(CROSS_COMPILE)cpp --sysroot=$(TOOLCHAIN_SYSROOT) -pthread
endif
# If building on desktop, don't strip binaries
ifeq ($(strip $(DESKTOP_LINUX)),y)
STRIP = /bin/touch
SSTRIP = /bin/touch
endif
# If building on desktop, set LIBDIR for legacy makefiles
# that still use LIBDIR (e.g. zebra)
ifeq ($(strip $(DESKTOP_LINUX)),y)
LIB_PATH = /usr/lib
LIBDIR = /usr/lib
LIBCDIR = /usr/lib
endif
# STRIP is used to strip the kernel modules. Currently, there is no
# usage scenario which requires unstripped kernel modules.
# SSTRIP is used to strip userspace apps in the final fs dir.
export TOOLCHAIN_TOP TOOLCHAIN CROSS_COMPILE \
AR AS LD CC CXX CPP NM STRIP SSTRIP OBJCOPY OBJDUMP RANLIB READELF \
LIB_PATH LIBDIR EXTRALIBDIR EXTRAINCDIR LIBCDIR \
BUILD_GDBSERVER KSTRIP KOBJCOPY KOBJDUMP
###########################################
#
# Application-specific settings
#
###########################################
TARGET_FS = $(TARGETS_DIR)/$(PROFILE)/fs
TARGET_BOOTFS = $(TARGETS_DIR)/$(PROFILE)/bootfs
PROFILE_DIR = $(TARGETS_DIR)/$(PROFILE)
INSTALL_DIR=$(PROFILE_DIR)/fs.install
BCM_FSBUILD_DIR=$(PROFILE_DIR)/fs.build
PROFILE_PATH = $(TARGETS_DIR)/$(PROFILE)/$(PROFILE)
VENDOR_NAME = bcm
FLASH_BASE_IMAGE_NAME = $(VENDOR_NAME)$(PROFILE)
FS_KERNEL_IMAGE_NAME = $(FLASH_BASE_IMAGE_NAME)_fs_kernel
CFE_FS_KERNEL_IMAGE_NAME = $(FLASH_BASE_IMAGE_NAME)_cfe_fs_kernel
FLASH_IMAGE_NAME = $(FLASH_BASE_IMAGE_NAME)_flash_image_$(BRCM_BOARD_ID)
FLASH_IMAGE_NAME_EMMC_DATA_PHYSPART = $(FLASH_BASE_IMAGE_NAME)_emmc_datapartition_flash_image_$(BRCM_BOARD_ID)
FLASH_IMAGE_NAME_EMMC_BOOT_PHYSPART = $(FLASH_BASE_IMAGE_NAME)_emmc_bootpartition_flash_image_$(BRCM_BOARD_ID)
FLASH_NAND_CFEROM_FS_IMAGE_NAME_16 = $(FLASH_BASE_IMAGE_NAME)_nand_cferom_fs_image_16
FLASH_NAND_FS_IMAGE_NAME_16 = $(FLASH_BASE_IMAGE_NAME)_nand_fs_image_16
FLASH_NAND_CFEROM_FS_IMAGE_NAME_128 = $(FLASH_BASE_IMAGE_NAME)_nand_cferom_fs_image_128
FLASH_NAND_FS_IMAGE_NAME_128 = $(FLASH_BASE_IMAGE_NAME)_nand_fs_image_128
FLASH_NAND_CFEROM_FS_IMAGE_NAME_256 = $(FLASH_BASE_IMAGE_NAME)_nand_cferom_fs_image_256
FLASH_NAND_FS_IMAGE_NAME_256 = $(FLASH_BASE_IMAGE_NAME)_nand_fs_image_256
FLASH_NAND_CFEROM_FS_IMAGE_NAME_512 = $(FLASH_BASE_IMAGE_NAME)_nand_cferom_fs_image_512
FLASH_NAND_FS_IMAGE_NAME_512 = $(FLASH_BASE_IMAGE_NAME)_nand_fs_image_512
FLASH_NAND_CFEROM_FS_IMAGE_NAME_1024 = $(FLASH_BASE_IMAGE_NAME)_nand_cferom_fs_image_1024
FLASH_NAND_FS_IMAGE_NAME_1024 = $(FLASH_BASE_IMAGE_NAME)_nand_fs_image_1024
FLASH_NAND_CFEROM_FS_IMAGE_NAME_2048 = $(FLASH_BASE_IMAGE_NAME)_nand_cferom_fs_image_2048
FLASH_NAND_FS_IMAGE_NAME_2048 = $(FLASH_BASE_IMAGE_NAME)_nand_fs_image_2048
FLASH_NAND_BLOCK_16KB=16384
FLASH_NAND_BLOCK_128KB=131072
FLASH_NAND_BLOCK_256KB=262144
FLASH_NAND_BLOCK_512KB=524288
FLASH_NAND_BLOCK_1024KB=1048576
FLASH_NAND_BLOCK_2048KB=2097152
ifneq ($(findstring _$(strip $(BRCM_CHIP))_,_63138_63148_4908_6858_63158_6856_6846_63178_47622_6878_),)
FLASH_BOOT_OFS=65536
else
FLASH_BOOT_OFS=0
endif
INC_BCMDRIVER_PATH=$(PROFILE_DIR)/fs.build/bcmdrivers/
INC_KERNELAPI_PATH=$(PROFILE_DIR)/fs.build/kernel
# Point to installed kernel headers for PROFILE_ARCH
INC_INSTALL_KERNEL_HDR_PATH=$(INC_KERNELAPI_PATH)/$(PROFILE_ARCH)
INC_BCMLIBS_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/bcmlibs/include
INC_BRCMDRIVER_PUB_PATH=$(BRCMDRIVERS_DIR)/opensource/include
INC_BRCMDRIVER_PRIV_PATH=$(BRCMDRIVERS_DIR)/broadcom/include
INC_ADSLDRV_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/adsl/impl1
INC_ATMAPI_DRV_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/atmapi/impl1
INC_GPON_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/gpon/impl6
INC_BRCMSHARED_PUB_PATH=$(SHARED_DIR)/opensource/include
INC_BRCMSHARED_PRIV_PATH=$(SHARED_DIR)/broadcom/include
INC_BRCMBOARDPARMS_PATH=$(SHARED_DIR)/opensource/boardparms
INC_FLASH_PATH=$(SHARED_DIR)/opensource/flash
INC_UTILS_PATH=$(SHARED_DIR)/opensource/utils
INC_SPUDRV_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/spudd/impl1
INC_PWRMNGTDRV_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/pwrmngt/impl1
INC_ENETDRV_PATH=$(BRCMDRIVERS_DIR)/opensource/net/enet/impl5
INC_RDPA_MW_PATH=$(BRCMDRIVERS_DIR)/opensource/char/rdpa_mw/impl1
INC_GENERAL_FLAGS = -I$(INC_BRCMSHARED_PUB_PATH)/rdp \
-I$(INC_BRCMSHARED_PUB_PATH)/drv/mdio \
-I$(INC_BRCMSHARED_PUB_PATH)/drv/phys \
-I$(INC_BRCMSHARED_PRIV_PATH)/$(BRCM_BOARD) \
-I$(INC_BRCMSHARED_PUB_PATH)/$(BRCM_BOARD) \
-I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD) \
-I$(INC_BRCMDRIVER_PUB_PATH)/$(BRCM_BOARD)/pmc \
-I$(INC_BRCMDRIVER_PRIV_PATH)/$(BRCM_BOARD) \
-I$(SHARED_DIR)/opensource/drv/lport \
-I$(KERNEL_DIR)/net/core \
-I$(BRCMDRIVERS_DIR)/opensource/char/rdpa_gpl/impl1/include \
-I$(BRCMDRIVERS_DIR)/opensource/char/rdpa_gpl/impl1/include/autogen \
-I$(BRCMDRIVERS_DIR)/opensource/char/rdpa_gpl_ext/impl1/include \
-I$(BRCMDRIVERS_DIR)/opensource/char/rdpa_gpl_ext/impl1/include/gpon_stack \
-I$(BRCMDRIVERS_DIR)/opensource/char/rdpa_gpl_ext/impl1/include/autogen \
-I$(BRCMDRIVERS_DIR)/broadcom/char/pon_drv/impl1 \
-I$(BRCMDRIVERS_DIR)/opensource/char/fpm/impl1 \
-I$(INC_BCMLIBS_PATH)
INC_RDP_FLAGS = -I$(PROJECT_DIR)/target/bdmf/system \
-I$(PROJECT_DIR)/target/bdmf/system/linux \
-I$(PROJECT_DIR)/target/bdmf/system/linux/ce \
-I$(PROJECT_DIR)/target/bdmf/framework \
-I$(PROJECT_DIR)/target/bdmf/shell \
-I$(PROJECT_DIR)/target/rdp_subsystem \
-I$(PROJECT_DIR)/target/rdp_subsystem/RU \
-I$(PROJECT_DIR)/target/rdpa \
-I$(PROJECT_DIR)/target/rdpa_gpl \
-I$(PROJECT_DIR)/target/rdd \
$(INC_GENERAL_FLAGS) \
$(PROJ_DEFS)
INC_ENET_DMA_FLAGS = -I$(INC_BRCMSHARED_PUB_PATH)/drv/phys \
-I$(INC_BRCMSHARED_PUB_PATH)/bcm963xx \
-I$(BRCMDRIVERS_DIR)/opensource/include/bcm963xx \
-I$(BRCMDRIVERS_DIR)/opensource/net/enet/shared \
-I$(BRCMDRIVERS_DIR)/broadcom/include/bcm963xx
export TARGET_FS TARGET_BOOTFS PROFILE_DIR INSTALL_DIR \
BCM_FSBUILD_DIR BCM_INSTALL_SUFFIX_DIR \
VENDOR_NAME \
INC_BRCMDRIVER_PUB_PATH INC_BRCMDRIVER_PRIV_PATH \
INC_BRCMSHARED_PUB_PATH INC_BRCMSHARED_PRIV_PATH \
INC_BRCMBOARDPARMS_PATH
##################################################################
#
# Start CMS specific defines
#
##################################################################
# Common utility libs
BCM_COMMON_LIBS := -lbcm_flashutil -lbcm_boardctl -lbcm_util -lsys_util -lgen_util -lcrypt
ifeq ($(strip $(DESKTOP_LINUX)),y)
#Defines when are are building for Desktop Linux
ifdef BRCM_CMS_COMPILER_OPTS
CMN_COMPILER_OPTS := -Wall -W $(BRCM_CMS_COMPILER_OPTS) -DDESKTOP_LINUX -fPIC
else
# The -O is needed to detect uninitialized variables, but sometimes prevents
# gdb from printing out a variable value. So if you need to do some serious
# debugging, set BRCM_CMS_COMPILER_OPTS=-g in your shell.
CMN_COMPILER_OPTS := -Wall -W -O -g -DDESKTOP_LINUX -fPIC
endif
ifneq ($(strip $(BUILD_DESKTOP_BEEP)),)
CMN_COMPILER_OPTS += -DBUILD_DESKTOP_BEEP
endif
ifneq ($(strip $(ARCH)),x86)
# Force 32 bit compiles
CMN_COMPILER_OPTS += -m32
export BCM_LD_FLAGS := -m32
endif