Work
This commit is contained in:
parent
ef54b50d5b
commit
272fb88bca
5 changed files with 62 additions and 32 deletions
|
@ -92,7 +92,7 @@ BreakBeforeTernaryOperators: true
|
||||||
BreakConstructorInitializers: BeforeColon
|
BreakConstructorInitializers: BeforeColon
|
||||||
BreakInheritanceList: BeforeColon
|
BreakInheritanceList: BeforeColon
|
||||||
BreakStringLiterals: true
|
BreakStringLiterals: true
|
||||||
ColumnLimit: 120
|
ColumnLimit: 80
|
||||||
CommentPragmas: '^ IWYU pragma:'
|
CommentPragmas: '^ IWYU pragma:'
|
||||||
CompactNamespaces: false
|
CompactNamespaces: false
|
||||||
ConstructorInitializerIndentWidth: 4
|
ConstructorInitializerIndentWidth: 4
|
||||||
|
@ -164,7 +164,7 @@ PackConstructorInitializers: BinPack
|
||||||
PenaltyBreakAssignment: 2
|
PenaltyBreakAssignment: 2
|
||||||
PenaltyBreakBeforeFirstCallParameter: 19
|
PenaltyBreakBeforeFirstCallParameter: 19
|
||||||
PenaltyBreakComment: 300
|
PenaltyBreakComment: 300
|
||||||
PenaltyBreakFirstLessLess: 120
|
PenaltyBreakFirstLessLess: 80
|
||||||
PenaltyBreakOpenParenthesis: 0
|
PenaltyBreakOpenParenthesis: 0
|
||||||
PenaltyBreakScopeResolution: 500
|
PenaltyBreakScopeResolution: 500
|
||||||
PenaltyBreakString: 1000
|
PenaltyBreakString: 1000
|
||||||
|
|
21
Makefile
21
Makefile
|
@ -1,13 +1,20 @@
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
CC = gcc
|
CC = gcc
|
||||||
CFLAGS = -Wall -Wextra -Werror -Wno-unused-parameter
|
# CFLAGS = -Wall -Wextra -Werror -Wno-unused-parameter
|
||||||
CFLAGS += -Wno-unused-variable -Wno-unused-function
|
# CFLAGS += -Wno-unused-variable -Wno-unused-function
|
||||||
CFLAGS += -Wno-unused-but-set-variable -Wno-unused-value -Wno-unused-label
|
# CFLAGS += -Wno-unused-but-set-variable -Wno-unused-value -Wno-unused-label
|
||||||
CFLAGS += -Wno-unused-result -Wno-unused-const-variable
|
# CFLAGS += -Wno-unused-result -Wno-unused-const-variable
|
||||||
CFLAGS += -fno-exceptions -fno-asynchronous-unwind-tables -fno-ident
|
|
||||||
CFLAGS += -fno-unwind-tables -fno-stack-protector -fno-plt -fno-pic
|
# ifeq ($(RELEASE), 1)
|
||||||
CFLAGS += -O3 -std=c99 -march=native -mtune=native -fomit-frame-pointer
|
# CFLAGS += -fno-exceptions -fno-asynchronous-unwind-tables -fno-ident
|
||||||
|
# CFLAGS += -fno-unwind-tables -fno-stack-protector -fno-plt -fno-pic
|
||||||
|
# CFLAGS += -O3 -std=c99 -march=native -mtune=native -fomit-frame-pointer
|
||||||
|
# endif
|
||||||
|
|
||||||
|
# Include debug flags
|
||||||
|
CFLAGS += -g -O0 -std=c99 -march=native -mtune=native
|
||||||
|
|
||||||
|
|
||||||
C_SOURCES = $(wildcard *.c)
|
C_SOURCES = $(wildcard *.c)
|
||||||
C_HEADERS = $(wildcard *.h)
|
C_HEADERS = $(wildcard *.h)
|
||||||
|
|
10
driver.c
10
driver.c
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
#define rb_size_t size_t
|
#define rb_size_t size_t
|
||||||
#include "ringbuf.h"
|
#include "ringbuf.h"
|
||||||
|
@ -15,7 +16,14 @@ main(void)
|
||||||
int data[] = { 1, 2, 3, 4, 5 };
|
int data[] = { 1, 2, 3, 4, 5 };
|
||||||
rb_push(&rb, (void **)data, 5, memcpy);
|
rb_push(&rb, (void **)data, 5, memcpy);
|
||||||
|
|
||||||
// rb_destroy(&rb, free);
|
int dest[5];
|
||||||
|
rb_read(&rb, (void *)dest, 5);
|
||||||
|
|
||||||
|
for (int i = 0; i < 5; i++) {
|
||||||
|
printf("Data: %d\n", dest[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
rb_destroy(&rb, free);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
51
ringbuf.c
51
ringbuf.c
|
@ -17,10 +17,19 @@ rb_init(struct RingBuf *rb, rb_size_t capacity, ALLOC_T, rb_size_t struct_size)
|
||||||
rb->write_idx = 0;
|
rb->write_idx = 0;
|
||||||
rb->read_idx = 0;
|
rb->read_idx = 0;
|
||||||
rb->buffer = alloc(capacity * struct_size); /* Calloc? */
|
rb->buffer = alloc(capacity * struct_size); /* Calloc? */
|
||||||
|
|
||||||
|
// Read from buffer at max position to force a segfault if theres an issue
|
||||||
|
printf("Reading from buffer at position %d\n",
|
||||||
|
rb->capacity * rb->struct_size);
|
||||||
|
void *top = rb->buffer[rb->capacity * rb->struct_size];
|
||||||
|
printf("Buffer top successfully read at virtual address: %p\n", &top);
|
||||||
|
|
||||||
|
printf("Initialized ring buffer. Capacit: %d, struct_size: %d, total: %d\n",
|
||||||
|
rb->capacity, rb->struct_size, rb->capacity * rb->struct_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
rb_destroy(struct RingBuf *rb, rb_size_t(free)(void *))
|
rb_destroy(struct RingBuf *rb, void(free)())
|
||||||
{
|
{
|
||||||
free(rb->buffer);
|
free(rb->buffer);
|
||||||
}
|
}
|
||||||
|
@ -28,28 +37,30 @@ rb_destroy(struct RingBuf *rb, rb_size_t(free)(void *))
|
||||||
enum WriteResult
|
enum WriteResult
|
||||||
rb_push(struct RingBuf *rb, void *data[], rb_size_t amount, MEMCPY_T)
|
rb_push(struct RingBuf *rb, void *data[], rb_size_t amount, MEMCPY_T)
|
||||||
{
|
{
|
||||||
if(rb->write_idx + amount >= rb->capacity) {
|
printf("\nWriting %d elements\n", amount);
|
||||||
return CollisionError;
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("write_idx: %d\n", rb->write_idx);
|
|
||||||
printf("amount: %d\n", amount);
|
|
||||||
|
|
||||||
for(rb_size_t i = 0; i < amount; i++) {
|
for(rb_size_t i = 0; i < amount; i++) {
|
||||||
printf("memcpy: %d, write_idx: %d\n", i, rb->write_idx);
|
// printf("Index: %d\n", rb->write_idx);
|
||||||
// write to the buffer
|
int position = (rb->write_idx + i) % rb->capacity;
|
||||||
rb->buffer[rb->write_idx] = data[i];
|
int offset = position * rb->struct_size;
|
||||||
// memcpy(rb->buffer + rb->write_idx * rb->struct_size, data[i], rb->struct_size);
|
printf("Position: %d\n", position);
|
||||||
|
printf("Offset: %d\n", offset);
|
||||||
|
memcpy(rb->buffer + offset, data + offset, rb->struct_size);
|
||||||
|
|
||||||
rb->write_idx = (rb->write_idx + 1) % rb->capacity;
|
printf("Data at location %d: %d\n", position, *(int *)(rb->buffer + offset));
|
||||||
}
|
|
||||||
|
|
||||||
// Read it back to stdout
|
|
||||||
for(rb_size_t i = 0; i < amount; i++) {
|
|
||||||
printf("read_idx: %d\n", rb->read_idx);
|
|
||||||
printf("data: %d\n", *(int *)rb->buffer[rb->read_idx]);
|
|
||||||
rb->read_idx = (rb->read_idx + 1) % rb->capacity;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return Ok;
|
return Ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
rb_read(struct RingBuf *rb, void *dest, int amount)
|
||||||
|
{
|
||||||
|
printf("\nReading %d elements\n", amount);
|
||||||
|
for (int i = 0; i < amount; i++) {
|
||||||
|
int position = (rb->read_idx + i) % rb->capacity;
|
||||||
|
int offset = position * rb->struct_size;
|
||||||
|
printf("Position: %d\n", position);
|
||||||
|
printf("Offset: %d\n", offset);
|
||||||
|
memcpy(dest + offset, rb->buffer + offset, rb->struct_size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -20,11 +20,15 @@ struct RingBuf {
|
||||||
enum WriteResult { CollisionError, Ok };
|
enum WriteResult { CollisionError, Ok };
|
||||||
|
|
||||||
/** Initialize the ring buffer */
|
/** Initialize the ring buffer */
|
||||||
void rb_init(struct RingBuf *rb, rb_size_t capacity, void *(*alloc)(rb_size_t), rb_size_t struct_size);
|
void rb_init(struct RingBuf *rb, rb_size_t capacity, void *(*alloc)(rb_size_t),
|
||||||
|
rb_size_t struct_size);
|
||||||
|
|
||||||
/** Insert data to the ring buffer */
|
/** Insert data to the ring buffer */
|
||||||
enum WriteResult rb_push(struct RingBuf *rb, void *data[], rb_size_t amount,
|
enum WriteResult rb_push(struct RingBuf *rb, void *data[], rb_size_t amount,
|
||||||
void *(*memcpy)(void *, const void *, rb_size_t));
|
void *(*memcpy)(void *, const void *, rb_size_t));
|
||||||
|
|
||||||
/** Read data from the ring buffer */
|
/** Read data from the ring buffer */
|
||||||
// void *rb_read(struct RingBuf *rb, int amount);
|
void rb_read(struct RingBuf *rb, void *dest, int amount);
|
||||||
|
|
||||||
|
/** Free the ring buffer */
|
||||||
|
void rb_destroy(struct RingBuf *rb, void(free)());
|
||||||
|
|
Loading…
Reference in a new issue