wip
This commit is contained in:
54
src/06_optimization/clock/Makefile
Normal file
54
src/06_optimization/clock/Makefile
Normal file
@@ -0,0 +1,54 @@
|
||||
EXE=clock
|
||||
SRCS=$(wildcard *.c)
|
||||
|
||||
ifeq ($(target),)
|
||||
target=nano
|
||||
endif
|
||||
|
||||
CFLAGS=-Wall -Wextra -g -c -O0 -MD -std=gnu11 -D_GNU_SOURCE
|
||||
|
||||
ifeq ($(target),nano)
|
||||
TOOLCHAIN_PATH=/buildroot/output/host/usr/bin/
|
||||
TOOLCHAIN=$(TOOLCHAIN_PATH)aarch64-linux-
|
||||
CFLAGS+=-mcpu=cortex-a53 -funwind-tables
|
||||
##CFLAGS+=-O2 -fno-omit-frame-pointer
|
||||
OBJDIR=.obj/nano
|
||||
EXEC=$(EXE)
|
||||
endif
|
||||
|
||||
ifeq ($(target),host)
|
||||
EXEC=$(EXE)_h
|
||||
endif
|
||||
|
||||
CC=$(TOOLCHAIN)gcc
|
||||
LD=$(TOOLCHAIN)gcc
|
||||
AR=$(TOOLCHAIN)ar
|
||||
STRIP=$(TOOLCHAIN)strip
|
||||
OBJDUMP=$(TOOLCHAIN)objdump
|
||||
|
||||
OBJDIR=.obj/$(target)
|
||||
OBJS= $(addprefix $(OBJDIR)/, $(SRCS:.c=.o))
|
||||
|
||||
$(OBJDIR)/%o: %c
|
||||
$(CC) $(CFLAGS) $< -o $@
|
||||
|
||||
all: $(OBJDIR)/ $(EXEC)
|
||||
|
||||
$(EXEC): $(OBJS) $(LINKER_SCRIPT)
|
||||
$(LD) $(OBJS) $(LDFLAGS) -o $@
|
||||
|
||||
$(OBJDIR)/:
|
||||
mkdir -p $(OBJDIR)
|
||||
|
||||
clean:
|
||||
rm -Rf $(OBJDIR) $(EXEC) $(EXEC)_s *~ t.txt
|
||||
|
||||
clean_all: clean
|
||||
rm -Rf .obj $(EXE) $(EXE)_s $(EXE)_a $(EXE)_a_s $(EXE)_h $(EXE)_h_s
|
||||
|
||||
dump: all
|
||||
$(OBJDUMP) -dS $(EXEC) > t.txt
|
||||
|
||||
-include $(OBJS:.o=.d)
|
||||
|
||||
.PHONY: all clean clean_all dump
|
||||
56
src/06_optimization/clock/clock.c
Normal file
56
src/06_optimization/clock/clock.c
Normal file
@@ -0,0 +1,56 @@
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include <sched.h>
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
void measure (int mode, int samples)
|
||||
{
|
||||
struct timespec start_time;
|
||||
struct timespec stop_time;
|
||||
clock_gettime (mode, &start_time); // setup...
|
||||
clock_gettime (mode, &start_time);
|
||||
for (int i = 0; i<samples; i++)
|
||||
{
|
||||
clock_gettime (mode, &start_time);
|
||||
clock_gettime (mode, &stop_time);
|
||||
long long t = (stop_time.tv_nsec - start_time.tv_nsec) +
|
||||
(stop_time.tv_sec - start_time.tv_sec) * 1000000000;
|
||||
printf ("%lld\n", t);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* main program...
|
||||
*/
|
||||
int main(int argc, char* argv[])
|
||||
{
|
||||
cpu_set_t my_set;
|
||||
CPU_ZERO(&my_set);
|
||||
CPU_SET(2, &my_set);
|
||||
sched_setaffinity(0, sizeof(cpu_set_t), &my_set);
|
||||
|
||||
printf ("clocks_per_sec=%ld\n", CLOCKS_PER_SEC);
|
||||
|
||||
int samples = 1000;
|
||||
if (argc == 2)
|
||||
samples = atol(argv[1]);
|
||||
|
||||
struct timespec start_time;
|
||||
clock_getres (CLOCK_MONOTONIC_RAW, &start_time);
|
||||
long t = start_time.tv_sec * 1000000000 + start_time.tv_nsec;
|
||||
printf ("time=%ld'%03ld'%03ld ns\n", t/1000000, (t/1000)%1000, t%1000);
|
||||
|
||||
measure (CLOCK_MONOTONIC_RAW, samples);
|
||||
|
||||
return 0;
|
||||
}
|
||||
BIN
src/06_optimization/clock/meazure.xlsx
Normal file
BIN
src/06_optimization/clock/meazure.xlsx
Normal file
Binary file not shown.
34
src/06_optimization/gcov/Makefile
Normal file
34
src/06_optimization/gcov/Makefile
Normal file
@@ -0,0 +1,34 @@
|
||||
CC?=gcc
|
||||
CFLAGS=-std=c11 -Wall -g -fprofile-arcs -ftest-coverage
|
||||
SOURCES=$(wildcard *.c)
|
||||
OBJECTS=$(SOURCES:.c=.o)
|
||||
EXECUTABLE=example-gcov
|
||||
|
||||
all: $(SOURCES) $(EXECUTABLE)
|
||||
|
||||
$(EXECUTABLE): $(OBJECTS)
|
||||
$(CC) $(CFLAGS) -o $@ $(OBJECTS)
|
||||
|
||||
.c.o:
|
||||
$(CC) -c $(CFLAGS) $< -o $@
|
||||
|
||||
|
||||
clean:
|
||||
@rm -f $(OBJECTS)
|
||||
@rm -f *.d
|
||||
|
||||
clean_all: clean
|
||||
@rm -f $(EXECUTABLE)
|
||||
@rm -f perf.data perf.data.old
|
||||
@rm -f *.gcno *.gcda *.gcov
|
||||
|
||||
|
||||
gcov-generate: all
|
||||
./$(EXECUTABLE)
|
||||
gcov main.c
|
||||
|
||||
gcov-read: gcov-generate
|
||||
less main.c.gcov
|
||||
|
||||
|
||||
-include *.d
|
||||
19
src/06_optimization/gcov/main.c
Normal file
19
src/06_optimization/gcov/main.c
Normal file
@@ -0,0 +1,19 @@
|
||||
#include <stdio.h>
|
||||
|
||||
int main (void)
|
||||
{
|
||||
int res = 1;
|
||||
for (int i=0; i<16; i++)
|
||||
{
|
||||
res *= 2;
|
||||
}
|
||||
|
||||
if(res < 10)
|
||||
{
|
||||
printf("dead code\n");
|
||||
}
|
||||
|
||||
printf("res=%d\n", res);
|
||||
|
||||
return 0;
|
||||
}
|
||||
54
src/06_optimization/gpio/Makefile
Normal file
54
src/06_optimization/gpio/Makefile
Normal file
@@ -0,0 +1,54 @@
|
||||
EXE=gpio
|
||||
SRCS=$(wildcard *.c)
|
||||
|
||||
ifeq ($(target),)
|
||||
target=nano
|
||||
endif
|
||||
|
||||
CFLAGS=-Wall -Wextra -g -c -O1 -MD -std=gnu11 -D_GNU_SOURCE
|
||||
|
||||
ifeq ($(target),nano)
|
||||
TOOLCHAIN_PATH=/buildroot/output/host/usr/bin/
|
||||
TOOLCHAIN=$(TOOLCHAIN_PATH)aarch64-linux-
|
||||
CFLAGS+=-mcpu=cortex-a53 -funwind-tables
|
||||
##CFLAGS+=-O2 -fno-omit-frame-pointer
|
||||
OBJDIR=.obj/nano
|
||||
EXEC=$(EXE)
|
||||
endif
|
||||
|
||||
ifeq ($(target),host)
|
||||
EXEC=$(EXE)_h
|
||||
endif
|
||||
|
||||
CC=$(TOOLCHAIN)gcc
|
||||
LD=$(TOOLCHAIN)gcc
|
||||
AR=$(TOOLCHAIN)ar
|
||||
STRIP=$(TOOLCHAIN)strip
|
||||
OBJDUMP=$(TOOLCHAIN)objdump
|
||||
|
||||
OBJDIR=.obj/$(target)
|
||||
OBJS= $(addprefix $(OBJDIR)/, $(SRCS:.c=.o))
|
||||
|
||||
$(OBJDIR)/%o: %c
|
||||
$(CC) $(CFLAGS) $< -o $@
|
||||
|
||||
all: $(OBJDIR)/ $(EXEC)
|
||||
|
||||
$(EXEC): $(OBJS) $(LINKER_SCRIPT)
|
||||
$(LD) $(OBJS) $(LDFLAGS) -o $@
|
||||
|
||||
$(OBJDIR)/:
|
||||
mkdir -p $(OBJDIR)
|
||||
|
||||
clean:
|
||||
rm -Rf $(OBJDIR) $(EXEC) $(EXEC)_s *~ t.txt
|
||||
|
||||
clean_all: clean
|
||||
rm -Rf .obj $(EXE) $(EXE)_s $(EXE)_a $(EXE)_a_s $(EXE)_h $(EXE)_h_s
|
||||
|
||||
dump: all
|
||||
$(OBJDUMP) -dS $(EXEC) > t.txt
|
||||
|
||||
-include $(OBJS:.o=.d)
|
||||
|
||||
.PHONY: all clean clean_all dump
|
||||
87
src/06_optimization/gpio/gpio.c
Normal file
87
src/06_optimization/gpio/gpio.c
Normal file
@@ -0,0 +1,87 @@
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include <sched.h>
|
||||
#include <sys/mman.h>
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
|
||||
#define GPIO_EXPORT "/sys/class/gpio/export"
|
||||
#define GPIO_UNEXPORT "/sys/class/gpio/unexport"
|
||||
#define GPIO_GPIOG11 "/sys/class/gpio/gpio203"
|
||||
#define GPIOG11 "203"
|
||||
|
||||
static int open_gpio()
|
||||
{
|
||||
// unexport pin out of sysfs (reinitialization)
|
||||
int f = open (GPIO_UNEXPORT, O_WRONLY);
|
||||
write (f, GPIOG11, strlen(GPIOG11));
|
||||
close (f);
|
||||
|
||||
// export pin to sysfs
|
||||
f = open (GPIO_EXPORT, O_WRONLY);
|
||||
write (f, GPIOG11, strlen(GPIOG11));
|
||||
close (f);
|
||||
|
||||
// config pin
|
||||
f = open (GPIO_GPIOG11 "/direction", O_WRONLY);
|
||||
write (f, "out", 3);
|
||||
close (f);
|
||||
|
||||
// open gpio value attribute
|
||||
f = open (GPIO_GPIOG11 "/value", O_RDWR);
|
||||
return f;
|
||||
}
|
||||
|
||||
/**
|
||||
* main program...
|
||||
*/
|
||||
int main()
|
||||
{
|
||||
cpu_set_t my_set;
|
||||
CPU_ZERO(&my_set);
|
||||
CPU_SET(2, &my_set);
|
||||
sched_setaffinity(0, sizeof(cpu_set_t), &my_set);
|
||||
|
||||
int gpio = open_gpio();
|
||||
bool on = false;
|
||||
struct timespec start_time;
|
||||
struct timespec stop_time;
|
||||
clock_gettime (CLOCK_MONOTONIC, &start_time); // setup...
|
||||
|
||||
|
||||
// --> measurement with internal timers
|
||||
clock_gettime (CLOCK_MONOTONIC, &start_time);
|
||||
for (int i=0; i<1000; i++) {
|
||||
if (on) {
|
||||
pwrite (gpio, "1", sizeof("1"), 0);
|
||||
} else {
|
||||
pwrite (gpio, "0", sizeof("0"), 0);
|
||||
}
|
||||
on = !on;
|
||||
}
|
||||
clock_gettime (CLOCK_MONOTONIC, &stop_time);
|
||||
long long t = (stop_time.tv_nsec - start_time.tv_nsec) +
|
||||
(stop_time.tv_sec - start_time.tv_sec) * 1000000000;
|
||||
printf ("pwrite (gpio, \"1\", sizeof(\"1\"), 0) -> %lld ns\n", t/1000);
|
||||
|
||||
|
||||
// --> measurement with oscilloscope
|
||||
while(true) {
|
||||
if (on) {
|
||||
pwrite (gpio, "1", sizeof("1"), 0);
|
||||
} else {
|
||||
pwrite (gpio, "0", sizeof("0"), 0);
|
||||
}
|
||||
on = !on;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
34
src/06_optimization/gprof/Makefile
Normal file
34
src/06_optimization/gprof/Makefile
Normal file
@@ -0,0 +1,34 @@
|
||||
CC?=gcc
|
||||
CFLAGS=-std=c11 -Wall -pg
|
||||
SOURCES=$(wildcard *.c)
|
||||
OBJECTS=$(SOURCES:.c=.o)
|
||||
EXECUTABLE=example-gprof
|
||||
|
||||
all: $(SOURCES) $(EXECUTABLE)
|
||||
|
||||
$(EXECUTABLE): $(OBJECTS)
|
||||
$(CC) $(CFLAGS) -o $@ $(OBJECTS)
|
||||
|
||||
.c.o:
|
||||
$(CC) -c $(CFLAGS) $< -o $@
|
||||
|
||||
|
||||
clean:
|
||||
@rm -f $(OBJECTS)
|
||||
@rm -f *.d
|
||||
|
||||
clean_all: clean
|
||||
@rm -f $(EXECUTABLE)
|
||||
@rm -f perf.data perf.data.old
|
||||
@rm -f gmon.out gprof.out
|
||||
|
||||
|
||||
gprof-generate: all
|
||||
./$(EXECUTABLE)
|
||||
gprof $(EXECUTABLE) > gprof.out
|
||||
|
||||
gprof-read:
|
||||
less gprof.out
|
||||
|
||||
|
||||
-include *.d
|
||||
21
src/06_optimization/gprof/main.c
Normal file
21
src/06_optimization/gprof/main.c
Normal file
@@ -0,0 +1,21 @@
|
||||
void func1(void)
|
||||
{
|
||||
for(int i=0; i<0xfffffff; i++); // wait...
|
||||
return;
|
||||
}
|
||||
|
||||
void func2(void)
|
||||
{
|
||||
for(int i=0;i<0xfffffff;i++); // wait...
|
||||
func1();
|
||||
return;
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
for(int i=0;i<0xfffffff;i++);
|
||||
func1();
|
||||
func2();
|
||||
|
||||
return 0;
|
||||
}
|
||||
71
src/06_optimization/gprof/target.mk
Normal file
71
src/06_optimization/gprof/target.mk
Normal file
@@ -0,0 +1,71 @@
|
||||
EXE=example-gprof
|
||||
SRCS=$(wildcard *.c)
|
||||
|
||||
ifeq ($(target),)
|
||||
target=nano
|
||||
endif
|
||||
|
||||
CFLAGS=-Wall -Wextra -g -c -O1 -MD -std=gnu11 -D_GNU_SOURCE -pg
|
||||
|
||||
ifeq ($(target),nano)
|
||||
TOOLCHAIN_PATH=/buildroot/output/host/usr/bin/
|
||||
TOOLCHAIN=$(TOOLCHAIN_PATH)aarch64-linux-
|
||||
CFLAGS+=-mcpu=cortex-a53 -funwind-tables
|
||||
CFLAGS+=-O2 -fno-omit-frame-pointer
|
||||
OBJDIR=.obj/nano
|
||||
EXEC=$(EXE)
|
||||
endif
|
||||
|
||||
ifeq ($(target),host)
|
||||
EXEC=$(EXE)_h
|
||||
endif
|
||||
|
||||
ifeq ($(target),xu3)
|
||||
TOOLCHAIN_PATH=~/workspace/xu3/buildroot/output/host/usr/bin/
|
||||
TOOLCHAIN=$(TOOLCHAIN_PATH)arm-linux-gnueabihf-
|
||||
CFLAGS+=-mcpu=cortex-a15.cortex-a7 -funwind-tables
|
||||
##CFLAGS+=-O2 -fno-omit-frame-pointer
|
||||
OBJDIR=.obj/xu3
|
||||
EXEC=$(EXE)_a
|
||||
endif
|
||||
|
||||
CC=$(TOOLCHAIN)gcc
|
||||
LD=$(TOOLCHAIN)gcc
|
||||
AR=$(TOOLCHAIN)ar
|
||||
STRIP=$(TOOLCHAIN)strip
|
||||
OBJDUMP=$(TOOLCHAIN)objdump
|
||||
|
||||
OBJDIR=.obj/$(target)
|
||||
OBJS= $(addprefix $(OBJDIR)/, $(SRCS:.c=.o))
|
||||
|
||||
$(OBJDIR)/%o: %c
|
||||
$(CC) $(CFLAGS) $< -o $@
|
||||
|
||||
all: $(OBJDIR)/ $(EXEC)
|
||||
|
||||
$(EXEC): $(OBJS) $(LINKER_SCRIPT)
|
||||
$(LD) $(OBJS) $(LDFLAGS) -o $@
|
||||
|
||||
$(OBJDIR)/:
|
||||
mkdir -p $(OBJDIR)
|
||||
|
||||
clean:
|
||||
rm -Rf $(OBJDIR) $(EXEC) $(EXEC)_s *~ t.txt
|
||||
|
||||
clean_all: clean
|
||||
rm -Rf .obj $(EXE) $(EXE)_s $(EXE)_a $(EXE)_a_s $(EXE)_h $(EXE)_h_s
|
||||
@rm -f perf.data perf.data.old gmon.out gprof.out
|
||||
|
||||
dump: all
|
||||
$(OBJDUMP) -dS $(EXEC) > t.txt
|
||||
|
||||
gprof-generate: all
|
||||
./$(EXECUTABLE)
|
||||
gprof $(EXECUTABLE) > gprof.out
|
||||
|
||||
gprof-read:
|
||||
less gprof.out
|
||||
|
||||
-include $(OBJS:.o=.d)
|
||||
|
||||
.PHONY: all clean clean_all dump
|
||||
54
src/06_optimization/mmio/Makefile
Normal file
54
src/06_optimization/mmio/Makefile
Normal file
@@ -0,0 +1,54 @@
|
||||
EXE=mmio
|
||||
SRCS=$(wildcard *.c)
|
||||
|
||||
ifeq ($(target),)
|
||||
target=nano
|
||||
endif
|
||||
|
||||
CFLAGS=-Wall -Wextra -g -c -O1 -MD -std=gnu11 -D_GNU_SOURCE
|
||||
|
||||
ifeq ($(target),nano)
|
||||
TOOLCHAIN_PATH=/buildroot/output/host/usr/bin/
|
||||
TOOLCHAIN=$(TOOLCHAIN_PATH)aarch64-linux-
|
||||
CFLAGS+=-mcpu=cortex-a53 -funwind-tables
|
||||
##CFLAGS+=-O2 -fno-omit-frame-pointer
|
||||
OBJDIR=.obj/nano
|
||||
EXEC=$(EXE)
|
||||
endif
|
||||
|
||||
ifeq ($(target),host)
|
||||
EXEC=$(EXE)_h
|
||||
endif
|
||||
|
||||
CC=$(TOOLCHAIN)gcc
|
||||
LD=$(TOOLCHAIN)gcc
|
||||
AR=$(TOOLCHAIN)ar
|
||||
STRIP=$(TOOLCHAIN)strip
|
||||
OBJDUMP=$(TOOLCHAIN)objdump
|
||||
|
||||
OBJDIR=.obj/$(target)
|
||||
OBJS= $(addprefix $(OBJDIR)/, $(SRCS:.c=.o))
|
||||
|
||||
$(OBJDIR)/%o: %c
|
||||
$(CC) $(CFLAGS) $< -o $@
|
||||
|
||||
all: $(OBJDIR)/ $(EXEC)
|
||||
|
||||
$(EXEC): $(OBJS) $(LINKER_SCRIPT)
|
||||
$(LD) $(OBJS) $(LDFLAGS) -o $@
|
||||
|
||||
$(OBJDIR)/:
|
||||
mkdir -p $(OBJDIR)
|
||||
|
||||
clean:
|
||||
rm -Rf $(OBJDIR) $(EXEC) $(EXEC)_s *~ t.txt
|
||||
|
||||
clean_all: clean
|
||||
rm -Rf .obj $(EXE) $(EXE)_s $(EXE)_a $(EXE)_a_s $(EXE)_h $(EXE)_h_s
|
||||
|
||||
dump: all
|
||||
$(OBJDUMP) -dS $(EXEC) > t.txt
|
||||
|
||||
-include $(OBJS:.o=.d)
|
||||
|
||||
.PHONY: all clean clean_all dump
|
||||
98
src/06_optimization/mmio/mmio.c
Normal file
98
src/06_optimization/mmio/mmio.c
Normal file
@@ -0,0 +1,98 @@
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include <sched.h>
|
||||
#include <sys/mman.h>
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
|
||||
#define GPIO_EXPORT "/sys/class/gpio/export"
|
||||
#define GPIO_UNEXPORT "/sys/class/gpio/unexport"
|
||||
#define GPIO_GPIOG11 "/sys/class/gpio/gpio203"
|
||||
#define GPIOG11 "203"
|
||||
|
||||
static int open_gpio()
|
||||
{
|
||||
// unexport pin out of sysfs (reinitialization)
|
||||
int f = open (GPIO_UNEXPORT, O_WRONLY);
|
||||
write (f, GPIOG11, strlen(GPIOG11));
|
||||
close (f);
|
||||
|
||||
// export pin to sysfs
|
||||
f = open (GPIO_EXPORT, O_WRONLY);
|
||||
write (f, GPIOG11, strlen(GPIOG11));
|
||||
close (f);
|
||||
|
||||
// config pin
|
||||
f = open (GPIO_GPIOG11 "/direction", O_WRONLY);
|
||||
write (f, "out", 3);
|
||||
close (f);
|
||||
|
||||
// open gpio value attribute
|
||||
f = open (GPIO_GPIOG11 "/value", O_RDWR);
|
||||
return f;
|
||||
}
|
||||
|
||||
/**
|
||||
* main program...
|
||||
*/
|
||||
int main()
|
||||
{
|
||||
cpu_set_t my_set;
|
||||
CPU_ZERO(&my_set);
|
||||
CPU_SET(2, &my_set);
|
||||
sched_setaffinity(0, sizeof(cpu_set_t), &my_set);
|
||||
|
||||
int gpio = open_gpio();
|
||||
pwrite (gpio, "1", sizeof("1"), 0);
|
||||
pwrite (gpio, "0", sizeof("0"), 0);
|
||||
|
||||
int fd = open ("/dev/mem", O_RDWR);
|
||||
if (fd == -1) return -1;
|
||||
off_t psz = getpagesize();
|
||||
volatile uint32_t* pio = mmap (0, psz, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0x01c20000);
|
||||
volatile uint32_t* dat_pio = pio + (0x810+6*0x24)/4;
|
||||
|
||||
struct timespec start_time;
|
||||
struct timespec stop_time;
|
||||
clock_gettime (CLOCK_MONOTONIC, &start_time); // setup...
|
||||
|
||||
// --> measurement with internal timers on gpio
|
||||
clock_gettime (CLOCK_MONOTONIC, &start_time);
|
||||
|
||||
for (int i=0; i<1000; i++)
|
||||
*dat_pio ^= (1<<11);
|
||||
|
||||
clock_gettime (CLOCK_MONOTONIC, &stop_time);
|
||||
long long t = (stop_time.tv_nsec - start_time.tv_nsec) +
|
||||
(stop_time.tv_sec - start_time.tv_sec) * 1000000000;
|
||||
printf ("*dat_pio ^= (1<<11) --> %6lld ns\n", t/1000);
|
||||
|
||||
|
||||
// --> measurement on internal data with internal timers
|
||||
volatile uint32_t data = 0;
|
||||
clock_gettime (CLOCK_MONOTONIC, &start_time);
|
||||
|
||||
for (int i=0; i<1000; i++)
|
||||
data ^= (1<<11);
|
||||
|
||||
clock_gettime (CLOCK_MONOTONIC, &stop_time);
|
||||
t = (stop_time.tv_nsec - start_time.tv_nsec) +
|
||||
(stop_time.tv_sec - start_time.tv_sec) * 1000000000;
|
||||
printf ("data ^= (1<<11) --> %6lld ns\n", t/1000);
|
||||
|
||||
|
||||
// --> measurement with oscilloscope
|
||||
while(true) {
|
||||
*dat_pio ^= (1<<11);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
54
src/06_optimization/trace/Makefile
Normal file
54
src/06_optimization/trace/Makefile
Normal file
@@ -0,0 +1,54 @@
|
||||
EXE=tracing
|
||||
SRCS=$(wildcard *.c)
|
||||
|
||||
ifeq ($(target),)
|
||||
target=nano
|
||||
endif
|
||||
|
||||
CFLAGS=-Wall -Wextra -g -c -O1 -MD -std=gnu11 -D_GNU_SOURCE
|
||||
|
||||
ifeq ($(target),nano)
|
||||
TOOLCHAIN_PATH=/buildroot/output/host/usr/bin/
|
||||
TOOLCHAIN=$(TOOLCHAIN_PATH)aarch64-linux-
|
||||
CFLAGS+=-mcpu=cortex-a53 -funwind-tables
|
||||
##CFLAGS+=-O2 -fno-omit-frame-pointer
|
||||
OBJDIR=.obj/nano
|
||||
EXEC=$(EXE)
|
||||
endif
|
||||
|
||||
ifeq ($(target),host)
|
||||
EXEC=$(EXE)_h
|
||||
endif
|
||||
|
||||
CC=$(TOOLCHAIN)gcc
|
||||
LD=$(TOOLCHAIN)gcc
|
||||
AR=$(TOOLCHAIN)ar
|
||||
STRIP=$(TOOLCHAIN)strip
|
||||
OBJDUMP=$(TOOLCHAIN)objdump
|
||||
|
||||
OBJDIR=.obj/$(target)
|
||||
OBJS= $(addprefix $(OBJDIR)/, $(SRCS:.c=.o))
|
||||
|
||||
$(OBJDIR)/%o: %c
|
||||
$(CC) $(CFLAGS) $< -o $@
|
||||
|
||||
all: $(OBJDIR)/ $(EXEC)
|
||||
|
||||
$(EXEC): $(OBJS) $(LINKER_SCRIPT)
|
||||
$(LD) $(OBJS) $(LDFLAGS) -o $@
|
||||
|
||||
$(OBJDIR)/:
|
||||
mkdir -p $(OBJDIR)
|
||||
|
||||
clean:
|
||||
rm -Rf $(OBJDIR) $(EXEC) $(EXEC)_s *~ t.txt
|
||||
|
||||
clean_all: clean
|
||||
rm -Rf .obj $(EXE) $(EXE)_s $(EXE)_a $(EXE)_a_s $(EXE)_h $(EXE)_h_s
|
||||
|
||||
dump: all
|
||||
$(OBJDUMP) -dS $(EXEC) > t.txt
|
||||
|
||||
-include $(OBJS:.o=.d)
|
||||
|
||||
.PHONY: all clean clean_all dump
|
||||
7
src/06_optimization/trace/example1.sh
Normal file
7
src/06_optimization/trace/example1.sh
Normal file
@@ -0,0 +1,7 @@
|
||||
#!/bin/sh
|
||||
# 1. example
|
||||
echo 1 > /sys/kernel/debug/tracing/events/sched/sched_switch/enable
|
||||
./tracing &
|
||||
pidof tracing > /sys/kernel/debug/tracing/set_event_pid
|
||||
echo 1 > /sys/kernel/debug/tracing/tracing_on ; sleep 2 ; echo 0 > /sys/kernel/debug/tracing/tracing_on
|
||||
trace-cmd show
|
||||
10
src/06_optimization/trace/example2.sh
Normal file
10
src/06_optimization/trace/example2.sh
Normal file
@@ -0,0 +1,10 @@
|
||||
#!/bin/sh
|
||||
# 2. example
|
||||
echo function_graph > /sys/kernel/debug/tracing/current_tracer
|
||||
echo *i2c* > /sys/kernel/debug/tracing/set_ftrace_filter
|
||||
echo 1 > /sys/kernel/debug/tracing/tracing_on
|
||||
i2cdetect -y 0
|
||||
echo 0 > /sys/kernel/debug/tracing/tracing_on
|
||||
trace-cmd show
|
||||
echo nop > /sys/kernel/debug/tracing/current_tracer
|
||||
|
||||
8
src/06_optimization/trace/main.c
Normal file
8
src/06_optimization/trace/main.c
Normal file
@@ -0,0 +1,8 @@
|
||||
#include <unistd.h>
|
||||
|
||||
int main()
|
||||
{
|
||||
while(1)
|
||||
sleep(1);
|
||||
return 0;
|
||||
}
|
||||
1
src/06_optimization/trace/setup.sh
Normal file
1
src/06_optimization/trace/setup.sh
Normal file
@@ -0,0 +1 @@
|
||||
mount -t debugfs nodev /sys/kernel/debug
|
||||
Reference in New Issue
Block a user