-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
49c6a90
commit 591f399
Showing
30 changed files
with
2,369 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
image boot.vfat { | ||
vfat { | ||
files = { | ||
"Image", | ||
"sunxi.dtb", | ||
"../board/lt527x/syter_boot/bl31/bl31.bin", | ||
"../utils/bl33/output/syter_bl33.bin" | ||
} | ||
} | ||
size = 128M | ||
} | ||
|
||
image sdcard.img { | ||
hdimage {} | ||
|
||
partition boot0 { | ||
in-partition-table = "no" | ||
image = "../build/board/lt527x/syter_boot/syter_boot_bin_card.bin" | ||
offset = 8K | ||
} | ||
|
||
partition boot0-gpt { | ||
in-partition-table = "no" | ||
image = "../build/board/lt527x/syter_boot/syter_boot_bin_card.bin" | ||
offset = 128K | ||
} | ||
|
||
partition kernel { | ||
partition-type = 0xC | ||
bootable = "true" | ||
image = "boot.vfat" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
output/ | ||
.obj/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
# | ||
# Top makefile | ||
# | ||
|
||
CROSS ?= arm-none-eabi- | ||
NAME := syter_bl33 | ||
|
||
# | ||
# System environment variable. | ||
# | ||
ifeq ($(OS), Windows_NT) | ||
HOSTOS := windows | ||
else | ||
ifneq (,$(findstring Linux, $(shell uname -a))) | ||
HOSTOS := linux | ||
endif | ||
endif | ||
|
||
# | ||
# Load default variables. | ||
# | ||
ASFLAGS := -g -ggdb -Wall -O3 | ||
CFLAGS := -g -ggdb -Wall -O3 | ||
CXXFLAGS := -g -ggdb -Wall -O3 | ||
LDFLAGS := -T link.ld -nostdlib | ||
ARFLAGS := -rcs | ||
OCFLAGS := -v -O binary | ||
ODFLAGS := | ||
MCFLAGS := -nostdinc -nostdlib -mabi=aapcs-linux -march=armv7-a -Wno-builtin-declaration-mismatch -Wno-int-to-pointer-cast -Wno-pointer-to-int-cast | ||
|
||
LIBDIRS := | ||
LIBS := | ||
INCDIRS := | ||
SRCDIRS := | ||
|
||
# | ||
# Add external library | ||
# | ||
INCDIRS += include | ||
SRCDIRS += source | ||
|
||
# | ||
# You shouldn't need to change anything below this point. | ||
# | ||
AS := $(CROSS)gcc -x assembler-with-cpp | ||
CC := $(CROSS)gcc | ||
CXX := $(CROSS)g++ | ||
LD := $(CROSS)ld | ||
AR := $(CROSS)ar | ||
OC := $(CROSS)objcopy | ||
OD := $(CROSS)objdump | ||
MKDIR := mkdir -p | ||
CP := cp -af | ||
RM := rm -fr | ||
CD := cd | ||
FIND := find | ||
|
||
# | ||
# X variables | ||
# | ||
G_ASFLAGS := $(MCFLAGS) $(ASFLAGS) | ||
G_CFLAGS := $(MCFLAGS) $(CFLAGS) | ||
G_CXXFLAGS := $(MCFLAGS) $(CXXFLAGS) | ||
G_LDFLAGS := $(LDFLAGS) | ||
G_OCFLAGS := $(OCFLAGS) | ||
G_LIBDIRS := $(LIBDIRS) | ||
G_LIBS := $(LIBS) -lgcc | ||
|
||
G_OUT := output | ||
G_NAME := $(patsubst %, $(G_OUT)/%, $(NAME)) | ||
G_INCDIRS := $(patsubst %, -I %, $(INCDIRS)) | ||
G_SRCDIRS := $(patsubst %, %, $(SRCDIRS)) | ||
G_OBJDIRS := $(patsubst %, .obj/%, $(G_SRCDIRS)) | ||
|
||
G_SFILES := $(foreach dir, $(G_SRCDIRS), $(wildcard $(dir)/*.S)) | ||
G_CFILES := $(foreach dir, $(G_SRCDIRS), $(wildcard $(dir)/*.c)) | ||
G_CPPFILES := $(foreach dir, $(G_SRCDIRS), $(wildcard $(dir)/*.cpp)) | ||
|
||
G_SDEPS := $(patsubst %, .obj/%, $(G_SFILES:.S=.o.d)) | ||
G_CDEPS := $(patsubst %, .obj/%, $(G_CFILES:.c=.o.d)) | ||
G_CPPDEPS := $(patsubst %, .obj/%, $(G_CPPFILES:.cpp=.o.d)) | ||
G_DEPS := $(G_SDEPS) $(G_CDEPS) $(G_CPPDEPS) | ||
|
||
G_SOBJS := $(patsubst %, .obj/%, $(G_SFILES:.S=.o)) | ||
G_COBJS := $(patsubst %, .obj/%, $(G_CFILES:.c=.o)) | ||
G_CPPOBJS := $(patsubst %, .obj/%, $(G_CPPFILES:.cpp=.o)) | ||
G_OBJS := $(G_SOBJS) $(G_COBJS) $(G_CPPOBJS) | ||
|
||
VPATH := $(G_OBJDIRS) | ||
|
||
.PHONY: all clean | ||
all : $(G_NAME) | ||
|
||
$(G_NAME) : $(G_OBJS) | ||
@echo [LD] Linking $@.elf | ||
@$(CC) $(G_LDFLAGS) $(G_LIBDIRS) -Wl,--cref,-Map=$@.map $^ -o $@.elf $(G_LIBS) | ||
@echo [OC] Objcopying $@.bin | ||
@$(OC) $(G_OCFLAGS) $@.elf $@.bin | ||
|
||
$(G_SOBJS) : .obj/%.o : %.S | ||
@echo [AS] $< | ||
@$(AS) $(G_ASFLAGS) -MD -MP -MF $@.d $(G_INCDIRS) -c $< -o $@ | ||
|
||
$(G_COBJS) : .obj/%.o : %.c | ||
@echo [CC] $< | ||
@$(CC) $(G_CFLAGS) -MD -MP -MF $@.d $(G_INCDIRS) -c $< -o $@ | ||
|
||
$(G_CPPOBJS) : .obj/%.o : %.cpp | ||
@echo [CXX] $< | ||
@$(CXX) $(G_CXXFLAGS) -MD -MP -MF $@.d $(G_INCDIRS) -c $< -o $@ | ||
|
||
clean: | ||
@$(RM) .obj $(G_OUT) | ||
|
||
# | ||
# Include the dependency files, should be place the last of makefile | ||
# | ||
sinclude $(shell $(MKDIR) $(G_OBJDIRS) $(G_OUT)) $(G_DEPS) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
#ifndef __BYTEORDER_H__ | ||
#define __BYTEORDER_H__ | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
#include <types.h> | ||
#include <endian.h> | ||
|
||
static inline u16_t __swab16(u16_t x) | ||
{ | ||
return ( (x<<8) | (x>>8) ); | ||
} | ||
|
||
static inline u32_t __swab32(u32_t x) | ||
{ | ||
return ( (x<<24) | (x>>24) | \ | ||
((x & (u32_t)0x0000ff00UL)<<8) | \ | ||
((x & (u32_t)0x00ff0000UL)>>8) ); | ||
} | ||
|
||
static inline u64_t __swab64(u64_t x) | ||
{ | ||
return ( (x<<56) | (x>>56) | \ | ||
((x & (u64_t)0x000000000000ff00ULL)<<40) | \ | ||
((x & (u64_t)0x0000000000ff0000ULL)<<24) | \ | ||
((x & (u64_t)0x00000000ff000000ULL)<< 8) | \ | ||
((x & (u64_t)0x000000ff00000000ULL)>> 8) | \ | ||
((x & (u64_t)0x0000ff0000000000ULL)>>24) | \ | ||
((x & (u64_t)0x00ff000000000000ULL)>>40) ); | ||
} | ||
|
||
/* | ||
* swap bytes bizarrely. | ||
* swahw32 - swap 16-bit half-words in a 32-bit word | ||
*/ | ||
static inline u32_t __swahw32(u32_t x) | ||
{ | ||
return ( ((x & (u32_t)0x0000ffffUL)<<16) | ((x & (u32_t)0xffff0000UL)>>16) ); | ||
} | ||
|
||
/* | ||
* swap bytes bizarrely. | ||
* swahb32 - swap 8-bit halves of each 16-bit half-word in a 32-bit word | ||
*/ | ||
static inline u32_t __swahb32(u32_t x) | ||
{ | ||
return ( ((x & (u32_t)0x00ff00ffUL)<<8) | ((x & (u32_t)0xff00ff00UL)>>8) ); | ||
} | ||
|
||
#if (BYTE_ORDER == BIG_ENDIAN) | ||
#define cpu_to_le64(x) (__swab64((u64_t)(x))) | ||
#define le64_to_cpu(x) (__swab64((u64_t)(x))) | ||
#define cpu_to_le32(x) (__swab32((u32_t)(x))) | ||
#define le32_to_cpu(x) (__swab32((u32_t)(x))) | ||
#define cpu_to_le16(x) (__swab16((u16_t)(x))) | ||
#define le16_to_cpu(x) (__swab16((u16_t)(x))) | ||
#define cpu_to_be64(x) ((u64_t)(x)) | ||
#define be64_to_cpu(x) ((u64_t)(x)) | ||
#define cpu_to_be32(x) ((u32_t)(x)) | ||
#define be32_to_cpu(x) ((u32_t)(x)) | ||
#define cpu_to_be16(x) ((u16_t)(x)) | ||
#define be16_to_cpu(x) ((u16_t)(x)) | ||
#else | ||
#define cpu_to_le64(x) ((u64_t)(x)) | ||
#define le64_to_cpu(x) ((u64_t)(x)) | ||
#define cpu_to_le32(x) ((u32_t)(x)) | ||
#define le32_to_cpu(x) ((u32_t)(x)) | ||
#define cpu_to_le16(x) ((u16_t)(x)) | ||
#define le16_to_cpu(x) ((u16_t)(x)) | ||
#define cpu_to_be64(x) (__swab64((u64_t)(x))) | ||
#define be64_to_cpu(x) (__swab64((u64_t)(x))) | ||
#define cpu_to_be32(x) (__swab32((u32_t)(x))) | ||
#define be32_to_cpu(x) (__swab32((u32_t)(x))) | ||
#define cpu_to_be16(x) (__swab16((u16_t)(x))) | ||
#define be16_to_cpu(x) (__swab16((u16_t)(x))) | ||
#endif | ||
|
||
#ifdef __cplusplus | ||
} | ||
#endif | ||
|
||
#endif /* __BYTEORDER_H__ */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
#ifndef __ARM32_ENDIAN_H__ | ||
#define __ARM32_ENDIAN_H__ | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
#define LITTLE_ENDIAN (0x1234) | ||
#define BIG_ENDIAN (0x4321) | ||
|
||
#if ( !defined(__LITTLE_ENDIAN) && !defined(__BIG_ENDIAN) ) | ||
#define __LITTLE_ENDIAN | ||
#endif | ||
|
||
#if defined(__LITTLE_ENDIAN) | ||
#define BYTE_ORDER LITTLE_ENDIAN | ||
#elif defined(__BIG_ENDIAN) | ||
#define BYTE_ORDER BIG_ENDIAN | ||
#else | ||
#error "Unknown byte order!" | ||
#endif | ||
|
||
#ifdef __cplusplus | ||
} | ||
#endif | ||
|
||
#endif /* __ARM32_ENDIAN_H__ */ |
Oops, something went wrong.