brcm2708: add DT support
Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com> SVN-Revision: 46344
This commit is contained in:
		@@ -1,4 +1,4 @@
 | 
				
			|||||||
CONFIG_ARCH_BCM2708=y
 | 
					CONFIG_ARCH_BCM2708=y
 | 
				
			||||||
# CONFIG_BCM2708_DT is not set
 | 
					CONFIG_BCM2708_DT=y
 | 
				
			||||||
CONFIG_MACH_BCM2708=y
 | 
					CONFIG_MACH_BCM2708=y
 | 
				
			||||||
CONFIG_VMSPLIT_3G=y
 | 
					CONFIG_VMSPLIT_3G=y
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,7 @@ CONFIG_ARCH_BCM2709=y
 | 
				
			|||||||
# CONFIG_ARM_THUMBEE is not set
 | 
					# CONFIG_ARM_THUMBEE is not set
 | 
				
			||||||
CONFIG_ARM_ARCH_TIMER_EVTSTREAM=y
 | 
					CONFIG_ARM_ARCH_TIMER_EVTSTREAM=y
 | 
				
			||||||
CONFIG_BCM2708_NOL2CACHE=y
 | 
					CONFIG_BCM2708_NOL2CACHE=y
 | 
				
			||||||
# CONFIG_BCM2709_DT is not set
 | 
					CONFIG_BCM2709_DT=y
 | 
				
			||||||
# CONFIG_CRYPTO_SHA1_ARM_NEON is not set
 | 
					# CONFIG_CRYPTO_SHA1_ARM_NEON is not set
 | 
				
			||||||
# CONFIG_CRYPTO_SHA512_ARM_NEON is not set
 | 
					# CONFIG_CRYPTO_SHA512_ARM_NEON is not set
 | 
				
			||||||
CONFIG_HAVE_ARM_ARCH_TIMER=y
 | 
					CONFIG_HAVE_ARM_ARCH_TIMER=y
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -203,6 +203,8 @@ CONFIG_NLS_ASCII=y
 | 
				
			|||||||
CONFIG_NLS_DEFAULT="utf8"
 | 
					CONFIG_NLS_DEFAULT="utf8"
 | 
				
			||||||
CONFIG_NO_HZ=y
 | 
					CONFIG_NO_HZ=y
 | 
				
			||||||
CONFIG_OABI_COMPAT=y
 | 
					CONFIG_OABI_COMPAT=y
 | 
				
			||||||
 | 
					CONFIG_OF=y
 | 
				
			||||||
 | 
					CONFIG_OF_GPIO=y
 | 
				
			||||||
CONFIG_PAGEFLAGS_EXTENDED=y
 | 
					CONFIG_PAGEFLAGS_EXTENDED=y
 | 
				
			||||||
CONFIG_PAGE_OFFSET=0xC0000000
 | 
					CONFIG_PAGE_OFFSET=0xC0000000
 | 
				
			||||||
# CONFIG_PCI_SYSCALL is not set
 | 
					# CONFIG_PCI_SYSCALL is not set
 | 
				
			||||||
@@ -223,10 +225,16 @@ CONFIG_SCSI=y
 | 
				
			|||||||
# CONFIG_SCSI_LOWLEVEL is not set
 | 
					# CONFIG_SCSI_LOWLEVEL is not set
 | 
				
			||||||
# CONFIG_SCSI_PROC_FS is not set
 | 
					# CONFIG_SCSI_PROC_FS is not set
 | 
				
			||||||
# CONFIG_SENSORS_BCM2835 is not set
 | 
					# CONFIG_SENSORS_BCM2835 is not set
 | 
				
			||||||
# CONFIG_SERIAL_8250 is not set
 | 
					CONFIG_SERIAL_8250=y
 | 
				
			||||||
 | 
					# CONFIG_SERIAL_8250_DEPRECATED_OPTIONS is not set
 | 
				
			||||||
 | 
					CONFIG_SERIAL_8250_CONSOLE=y
 | 
				
			||||||
 | 
					# CONFIG_SERIAL_8250_DMA is not set
 | 
				
			||||||
 | 
					CONFIG_SERIAL_8250_NR_UARTS=1
 | 
				
			||||||
 | 
					CONFIG_SERIAL_8250_RUNTIME_UARTS=0
 | 
				
			||||||
# CONFIG_SERIAL_AMBA_PL010 is not set
 | 
					# CONFIG_SERIAL_AMBA_PL010 is not set
 | 
				
			||||||
CONFIG_SERIAL_AMBA_PL011=y
 | 
					CONFIG_SERIAL_AMBA_PL011=y
 | 
				
			||||||
CONFIG_SERIAL_AMBA_PL011_CONSOLE=y
 | 
					CONFIG_SERIAL_AMBA_PL011_CONSOLE=y
 | 
				
			||||||
 | 
					CONFIG_SERIAL_OF_PLATFORM=y
 | 
				
			||||||
# CONFIG_SND_BCM2708_SOC_I2S is not set
 | 
					# CONFIG_SND_BCM2708_SOC_I2S is not set
 | 
				
			||||||
# CONFIG_SQUASHFS is not set
 | 
					# CONFIG_SQUASHFS is not set
 | 
				
			||||||
# CONFIG_STAGING is not set
 | 
					# CONFIG_STAGING is not set
 | 
				
			||||||
@@ -255,6 +263,7 @@ CONFIG_USB_STORAGE=y
 | 
				
			|||||||
CONFIG_USB_SUPPORT=y
 | 
					CONFIG_USB_SUPPORT=y
 | 
				
			||||||
CONFIG_USB_UAS=y
 | 
					CONFIG_USB_UAS=y
 | 
				
			||||||
CONFIG_USB_USBNET=y
 | 
					CONFIG_USB_USBNET=y
 | 
				
			||||||
 | 
					CONFIG_USE_OF=y
 | 
				
			||||||
CONFIG_VECTORS_BASE=0xffff0000
 | 
					CONFIG_VECTORS_BASE=0xffff0000
 | 
				
			||||||
CONFIG_VFP=y
 | 
					CONFIG_VFP=y
 | 
				
			||||||
# CONFIG_VIDEO_BCM2835 is not set
 | 
					# CONFIG_VIDEO_BCM2835 is not set
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,30 +11,67 @@ include $(INCLUDE_DIR)/host.mk
 | 
				
			|||||||
FAT32_BLOCK_SIZE=1024
 | 
					FAT32_BLOCK_SIZE=1024
 | 
				
			||||||
FAT32_BLOCKS=$(shell echo $$(($(CONFIG_BRCM2708_SD_BOOT_PARTSIZE)*1024*1024/$(FAT32_BLOCK_SIZE))))
 | 
					FAT32_BLOCKS=$(shell echo $$(($(CONFIG_BRCM2708_SD_BOOT_PARTSIZE)*1024*1024/$(FAT32_BLOCK_SIZE))))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Image/Build/RaspberryPi
 | 
					### Image scripts ###
 | 
				
			||||||
	rm -f $(KDIR)/boot.img
 | 
					define Build/build-dtb
 | 
				
			||||||
 | 
						$(LINUX_DIR)/scripts/dtc/dtc -O dtb -o $@.dtb $(DTS_DIR)/$(DEVICE_DTS).dts
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	mkfs.fat -C $(KDIR)/boot.img $(FAT32_BLOCKS)
 | 
					define Build/gen-cfg
 | 
				
			||||||
	# Raspberry Pi has no bootloader, instead the GPU loads and starts the kernel
 | 
						cat config.txt > $@.config
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/bootcode.bin ::
 | 
						echo -e "\ndevice_tree=$(DEVICE_DTS).dtb" >> $@.config
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/COPYING.linux ::
 | 
					endef
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/LICENCE.broadcom ::
 | 
					
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/start.elf ::
 | 
					define Build/boot-img
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/start_cd.elf ::
 | 
						rm -f $@.boot
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/fixup.dat ::
 | 
						mkfs.fat -C $@.boot $(FAT32_BLOCKS)
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/fixup_cd.dat ::
 | 
						mcopy -i $@.boot $(KDIR)/bootcode.bin ::
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img cmdline.txt ::
 | 
						mcopy -i $@.boot $(KDIR)/COPYING.linux ::
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img config.txt ::
 | 
						mcopy -i $@.boot $(KDIR)/LICENCE.broadcom ::
 | 
				
			||||||
	mcopy -i $(KDIR)/boot.img $(KDIR)/Image ::kernel.img  # Copy OpenWrt built kernel
 | 
						mcopy -i $@.boot $(KDIR)/start.elf ::
 | 
				
			||||||
	./gen_rpi_sdcard_img.sh $(BIN_DIR)/$(IMG_PREFIX)-sdcard-vfat-$(1).img $(KDIR)/boot.img $(KDIR)/root.$(1) \
 | 
						mcopy -i $@.boot $(KDIR)/start_cd.elf ::
 | 
				
			||||||
 | 
						mcopy -i $@.boot $(KDIR)/fixup.dat ::
 | 
				
			||||||
 | 
						mcopy -i $@.boot $(KDIR)/fixup_cd.dat ::
 | 
				
			||||||
 | 
						mcopy -i $@.boot cmdline.txt ::
 | 
				
			||||||
 | 
						mcopy -i $@.boot $@.config ::config.txt
 | 
				
			||||||
 | 
						mcopy -i $@.boot $(word 1,$^) ::kernel.img
 | 
				
			||||||
 | 
						mcopy -i $@.boot $@.dtb ::$(DEVICE_DTS).dtb
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Build/sdcard-img
 | 
				
			||||||
 | 
						./gen_rpi_sdcard_img.sh $@ $@.boot $(word 2,$^) \
 | 
				
			||||||
		$(CONFIG_BRCM2708_SD_BOOT_PARTSIZE) $(CONFIG_TARGET_ROOTFS_PARTSIZE)
 | 
							$(CONFIG_BRCM2708_SD_BOOT_PARTSIZE) $(CONFIG_TARGET_ROOTFS_PARTSIZE)
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Image/Build
 | 
					### Device macros ###
 | 
				
			||||||
	$(CP) $(KDIR)/root.$(1) $(BIN_DIR)/$(IMG_PREFIX)-$(1).img
 | 
					define Device/Default
 | 
				
			||||||
	$(CP) $(KDIR)/Image $(BIN_DIR)/$(IMG_PREFIX)-Image
 | 
					  FILESYSTEMS := ext4
 | 
				
			||||||
 | 
					  PROFILES = Default $$(DEVICE_PROFILE)
 | 
				
			||||||
 | 
					  KERNEL := kernel-bin
 | 
				
			||||||
 | 
					  IMAGES := sdcard.bin
 | 
				
			||||||
 | 
					  IMAGE/sdcard.bin := build-dtb | gen-cfg | boot-img | sdcard-img
 | 
				
			||||||
 | 
					  DEVICE_PROFILE :=
 | 
				
			||||||
 | 
					  DEVICE_NAME :=
 | 
				
			||||||
 | 
					  DEVICE_DTS :=
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					DEVICE_VARS += DEVICE_PROFILE DEVICE_NAME DEVICE_DTS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	$(call Image/Build/RaspberryPi,$(1))
 | 
					# $(1) = profile
 | 
				
			||||||
 | 
					# $(2) = image name
 | 
				
			||||||
 | 
					# $(3) = dts
 | 
				
			||||||
 | 
					define add_bcm2708
 | 
				
			||||||
 | 
					  define Device/$(2)
 | 
				
			||||||
 | 
					    DEVICE_PROFILE := $(1)
 | 
				
			||||||
 | 
					    DEVICE_NAME := $(2)
 | 
				
			||||||
 | 
					    DEVICE_DTS := $(3)
 | 
				
			||||||
 | 
					  endef
 | 
				
			||||||
 | 
					  TARGET_DEVICES += $(2)
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Raspberry Pi Model B
 | 
				
			||||||
 | 
					$(eval $(call add_bcm2708,RaspberryPi,rpi-b,bcm2708-rpi-b))
 | 
				
			||||||
 | 
					# Raspberry Pi Model B+
 | 
				
			||||||
 | 
					$(eval $(call add_bcm2708,RaspberryPi,rpi-b-plus,bcm2708-rpi-b-plus))
 | 
				
			||||||
 | 
					# Raspberry Pi 2 Model B
 | 
				
			||||||
 | 
					$(eval $(call add_bcm2708,RaspberryPi2,rpi-2-b,bcm2709-rpi-2-b))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(eval $(call BuildImage))
 | 
					$(eval $(call BuildImage))
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -476,7 +476,7 @@
 | 
				
			|||||||
##     Stop start.elf from filling in ATAGS (memory from 0x100) before
 | 
					##     Stop start.elf from filling in ATAGS (memory from 0x100) before
 | 
				
			||||||
##     launching kernel
 | 
					##     launching kernel
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
#disable_commandline_tags=0
 | 
					disable_commandline_tags=1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## cmdline (string)
 | 
					## cmdline (string)
 | 
				
			||||||
##     Command line parameters. Can be used instead of cmdline.txt file
 | 
					##     Command line parameters. Can be used instead of cmdline.txt file
 | 
				
			||||||
@@ -491,7 +491,7 @@
 | 
				
			|||||||
## kernel_address
 | 
					## kernel_address
 | 
				
			||||||
##     Address to load kernel.img file at
 | 
					##     Address to load kernel.img file at
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
#kernel_address=0x00000000
 | 
					kernel_address=0x8000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## ramfsfile (string)
 | 
					## ramfsfile (string)
 | 
				
			||||||
##     ramfs file to load
 | 
					##     ramfs file to load
 | 
				
			||||||
@@ -515,21 +515,21 @@
 | 
				
			|||||||
## device_tree_address
 | 
					## device_tree_address
 | 
				
			||||||
##     Address to load device_tree at
 | 
					##     Address to load device_tree at
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
#device_tree_address=0x00000000
 | 
					device_tree_address=0x100
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## init_uart_baud
 | 
					## init_uart_baud
 | 
				
			||||||
##     Initial uart baud rate.
 | 
					##     Initial uart baud rate.
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
##     Default 115200
 | 
					##     Default 115200
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
#init_uart_baud=115200
 | 
					init_uart_baud=115200
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## init_uart_clock
 | 
					## init_uart_clock
 | 
				
			||||||
##     Initial uart clock.
 | 
					##     Initial uart clock.
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
##     Default 3000000 (3MHz)
 | 
					##     Default 3000000 (3MHz)
 | 
				
			||||||
##
 | 
					##
 | 
				
			||||||
#init_uart_clock=3000000
 | 
					init_uart_clock=3000000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## init_emmc_clock
 | 
					## init_emmc_clock
 | 
				
			||||||
##     Initial emmc clock, increasing this can speedup your SD-card.
 | 
					##     Initial emmc clock, increasing this can speedup your SD-card.
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user