aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Arun Prakash Jana <engineerarun@gmail.com>2017-12-29 11:08:07 +0530
committerGravatar Arun Prakash Jana <engineerarun@gmail.com>2017-12-29 11:08:07 +0530
commit3a88e31a0e134e8ce80a6439ca215111c95871fc (patch)
tree58edfdabd4b78a3fad65972c1bef08d77a771d86
parent9b010b1c033b404f58505e02af29d7291ba3b386 (diff)
downloadnnn-3a88e31a0e134e8ce80a6439ca215111c95871fc.tar.gz
Check alignment and enable -O3
-rw-r--r--Makefile4
-rw-r--r--nnn.c19
2 files changed, 11 insertions, 12 deletions
diff --git a/Makefile b/Makefile
index 03dfd77..e8224d8 100644
--- a/Makefile
+++ b/Makefile
@@ -3,7 +3,7 @@ VERSION = 1.6
PREFIX ?= /usr/local
MANPREFIX = $(PREFIX)/share/man
-CFLAGS += -Wall -Wextra -Wno-unused-parameter
+CFLAGS += -O3 -Wall -Wextra -Wno-unused-parameter
LDLIBS = -lreadline
ifeq ($(shell pkg-config ncursesw && echo 1),1)
@@ -23,7 +23,7 @@ all: $(BIN) $(PLAYER)
$(SRC): nnn.h
$(BIN): $(SRC)
- $(CC) -O2 $(CFLAGS) -o $@ $^ $(LDFLAGS) $(LDLIBS)
+ $(CC) $(CFLAGS) -o $@ $^ $(LDFLAGS) $(LDLIBS)
strip $@
debug: $(SRC)
diff --git a/nnn.c b/nnn.c
index fb1d5b4..721ef80 100644
--- a/nnn.c
+++ b/nnn.c
@@ -357,11 +357,12 @@ xstrlen(const char *s)
static size_t
xstrlcpy(char *dest, const char *src, size_t n)
{
+ static ulong *s, *d;
static size_t len, blocks;
static const uint lsize = sizeof(ulong);
static const uint _WSHIFT = (sizeof(ulong) == 8) ? 3 : 2;
- if (!src || !dest)
+ if (!src || !dest || !n)
return 0;
len = xstrlen(src) + 1;
@@ -371,17 +372,15 @@ xstrlcpy(char *dest, const char *src, size_t n)
/* Save total number of bytes to copy in len */
len = n;
- if (n >= lsize) {
- blocks = n >> _WSHIFT;
- n -= (blocks << _WSHIFT);
- } else
- blocks = 0;
-
- if (blocks) {
- static ulong *s, *d;
-
+ /*
+ * To enable -O3 ensure src and dest are 16-byte aligned
+ * More info: http://www.felixcloutier.com/x86/MOVDQA.html
+ */
+ if ((n >= lsize) && !((ulong)src & (ulong)dest & 0xF)) {
s = (ulong *)src;
d = (ulong *)dest;
+ blocks = n >> _WSHIFT;
+ n -= (blocks << _WSHIFT);
while (blocks) {
*d = *s;