Skip to content

Commit

Permalink
fix: race condition in EventsTrace ctx init
Browse files Browse the repository at this point in the history
  • Loading branch information
mmat11 committed Jan 14, 2024
1 parent a0d0a8f commit 849e890
Show file tree
Hide file tree
Showing 8 changed files with 53 additions and 90 deletions.
16 changes: 0 additions & 16 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -49,25 +49,9 @@ jobs:
runner: ubuntu-latest
kernels: '[ "amazonlinux2", "debian", "fedora", "mainline", "rocky", "ubuntu-aws", "ubuntu-azure", "ubuntu-gcp", "ubuntu-gke", "ubuntu-oracle" ]'
secrets: inherit
local-build-x86_64:
name: Platform (x86_64)
uses: ./.github/workflows/local-build.yml
with:
architecture: x86_64
runner: ubuntu-latest
secrets: inherit
local-build-aarch64:
name: Platform (aarch64)
uses: ./.github/workflows/local-build.yml
with:
architecture: aarch64
runner: ubuntu-latest
secrets: inherit
merge-auditor:
name: CI Merge Auditor
needs:
- local-build-x86_64
- local-build-aarch64
- multikernel-tester-x86_64
- multikernel-tester-aarch64
runs-on: ubuntu-latest
Expand Down
21 changes: 0 additions & 21 deletions .github/workflows/issues.yml

This file was deleted.

42 changes: 0 additions & 42 deletions .github/workflows/local-build.yml

This file was deleted.

10 changes: 9 additions & 1 deletion non-GPL/Events/EventsTrace/EventsTrace.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
#include <string.h>
#include <sys/resource.h>
#include <sys/time.h>
#include <unistd.h>

#include <arpa/inet.h>
#include <netinet/in.h>
Expand Down Expand Up @@ -109,6 +110,7 @@ uint64_t g_events_env = 0;
uint64_t g_features_env = 0;

bool g_print_features_init = 0;
bool g_features_printed = 0;
bool g_unbuffer_stdout = 0;
bool g_libbpf_verbose = 0;

Expand Down Expand Up @@ -859,6 +861,10 @@ static void out_network_connection_closed_event(struct ebpf_net_event *evt)

static int event_ctx_callback(struct ebpf_event_header *evt_hdr)
{
if (g_print_features_init)
while (!g_features_printed)
usleep(100000);

switch (evt_hdr->type) {
case EBPF_EVENT_PROCESS_FORK:
out_process_fork((struct ebpf_process_fork_event *)evt_hdr);
Expand Down Expand Up @@ -945,8 +951,10 @@ int main(int argc, char **argv)
goto out;
}

if (g_print_features_init)
if (g_print_features_init) {
print_init_msg(ebpf_event_ctx__get_features(ctx));
g_features_printed = 1;
}

while (!exiting) {
err = ebpf_event_ctx__next(ctx, 10);
Expand Down
1 change: 1 addition & 0 deletions testing/scripts/invoke_qemu.sh
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ main() {

qemu-system-${arch} \
-nographic -m 1G \
-smp 8 \
-kernel $kernel \
-initrd $initramfs \
-append "$bootparams" \
Expand Down
38 changes: 33 additions & 5 deletions testing/test_bins/create_rename_delete_file.c
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,11 @@
* License 2.0.
*/

#include <fcntl.h>
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/uio.h>
#include <unistd.h>

#include "common.h"
Expand All @@ -24,14 +26,40 @@ int main()
printf("{ \"pid_info\": %s, \"filename_orig\": \"%s\", \"filename_new\": \"%s\"}\n", pid_info,
filename_orig, filename_new);

FILE *f;
CHECK(f = fopen(filename_orig, "w"), NULL);
int fd;

// create
CHECK(fd = open(filename_orig, O_WRONLY | O_CREAT | O_TRUNC, 0644), -1);

// rename
CHECK(rename(filename_orig, filename_new), -1);

// modify(permissions)
CHECK(chmod(filename_new, S_IRWXU | S_IRWXG | S_IRWXO), -1);
CHECK(fprintf(f, "test"), -1);
CHECK(ftruncate(fileno(f), 0), -1);
CHECK(fclose(f), EOF);

// modify(content)
if (write(fd, "test", 4) != 4) {
perror("write failed");
return -1;
}

// modify(content)
struct iovec iov[2];
iov[0].iov_base = "test2";
iov[0].iov_len = 5;
iov[1].iov_base = "test3";
iov[1].iov_len = 5;
if (writev(fd, iov, 2) != 10) {
perror("writev failed");
return -1;
}

// modify(content)
CHECK(ftruncate(fd, 0), -1);

close(fd);

// delete
CHECK(unlink(filename_new), -1);

return 0;
Expand Down
13 changes: 9 additions & 4 deletions testing/testrunner/tests.go
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ func TestFileDelete(et *EventsTraceInstance) {
AssertStringsEqual(fileDeleteEvent.Finfo.Type, "FILE")
AssertUint64NotEqual(fileDeleteEvent.Finfo.Inode, 0)
AssertUint64Equal(fileDeleteEvent.Finfo.Mode, 100777)
AssertUint64Equal(fileDeleteEvent.Finfo.Size, 4)
AssertUint64Equal(fileDeleteEvent.Finfo.Size, 0)
AssertUint64Equal(fileDeleteEvent.Finfo.Uid, 0)
AssertUint64Equal(fileDeleteEvent.Finfo.Gid, 0)
}
Expand Down Expand Up @@ -401,7 +401,7 @@ func TestFileModify(et *EventsTraceInstance) {
TestFail("failed to unmarshal json", err)
}

eventsCount := 3 // chmod, write, truncate
eventsCount := 4 // chmod, write, writev, truncate
events := make([]FileModifyEvent, 0, eventsCount)
for {
var event FileModifyEvent
Expand All @@ -427,12 +427,17 @@ func TestFileModify(et *EventsTraceInstance) {
// write
AssertStringsEqual(events[1].Path, binOutput.FileNameNew)
AssertStringsEqual(events[1].ChangeType, "CONTENT")
AssertUint64Equal(events[1].Finfo.Size, 4)

// truncate
// writev
AssertStringsEqual(events[2].Path, binOutput.FileNameNew)
AssertStringsEqual(events[2].ChangeType, "CONTENT")
AssertUint64Equal(events[2].Finfo.Size, 4+5+5)

AssertTrue(events[1].Finfo.Size != events[2].Finfo.Size)
// truncate
AssertStringsEqual(events[3].Path, binOutput.FileNameNew)
AssertStringsEqual(events[3].ChangeType, "CONTENT")
AssertUint64Equal(events[3].Finfo.Size, 0)
}

func TestTtyWrite(et *EventsTraceInstance) {
Expand Down
2 changes: 1 addition & 1 deletion testing/testrunner/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -343,7 +343,7 @@ func RunTest(f func()) {

func RunEventsTest(f func(*EventsTraceInstance), args ...string) {
testFuncName := runtime.FuncForPC(reflect.ValueOf(f).Pointer()).Name()
ctx, cancel := context.WithTimeout(context.TODO(), 30*time.Second)
ctx, cancel := context.WithTimeout(context.TODO(), 90*time.Second)

et := NewEventsTrace(ctx, args...)
et.Start(ctx)
Expand Down

0 comments on commit 849e890

Please sign in to comment.