Project

General

Profile

Actions

Task #3334

open

rust: cleanup registration of C function pointers in SuricataContext

Added by Jason Ish about 5 years ago. Updated 13 days ago.

Status:
New
Priority:
Normal
Assignee:
Target version:
Effort:
Difficulty:
Label:

Description

In Suricata's main() a SuricataContext is setup with no comments on what it is for. This is used to send some C functions as function pointers inside Rust.

This solves a chicken and egg problem when running the Rust unit tests. When the Rust code is simply compiled we can reference any of the C functions, they will get resolved when the resulting Rust library is linked into the C executable. However, when running the Rust unit tests (via cargo test), these C functions don't exist, so the tests fail to compile. To get around this we pass some functions to Rust as pointers wrapped in an Option and resolve it. This process is at best a hack.

At a minimum just clean this up behind some more explicit Rust initialization, but it may be worth researching alternatives.


Related issues 1 (1 open0 closed)

Related to Suricata - Story #7141: misc: general improvements and cleanupsNewVictor JulienActions
Actions #1

Updated by Jason Ish about 5 years ago

  • Project changed from Suricata-Update to Suricata
Actions #2

Updated by Victor Julien almost 5 years ago

  • Priority changed from Normal to High
Actions #3

Updated by Victor Julien over 4 years ago

  • Target version set to 7.0.0-beta1
Actions #4

Updated by Jason Ish over 3 years ago

  • Target version changed from 7.0.0-beta1 to 8.0.0-beta1

Retargeting to 8. I don't think we can get rid of this as long as we have C that calls Rust, and Rust that calls C.

Actions #5

Updated by Victor Julien 7 months ago

  • Subject changed from Cleanup registration of C function pointers in SuricataContext in main() to rust: cleanup registration of C function pointers in SuricataContext
  • Priority changed from High to Normal
Actions #6

Updated by Victor Julien 7 months ago

  • Related to Story #7141: misc: general improvements and cleanups added
Actions #7

Updated by Victor Julien 13 days ago

  • Target version changed from 8.0.0-beta1 to 8.0.0-rc1

Looks like a number of them, like the File* API wrappers can be removed.

Actions

Also available in: Atom PDF