trifid/docs/tfclient/why_not_this_os.md

1.6 KiB

Why cant tfclient support XXXXX?

There are limits to what operating systems and architectures tfclient can support. As you may know, tfclient is based upon the Nebula project, maintained by Slack and Defined Networking. tfclient can only support architectures and operating systems that Nebula itself supports.

In addition, tfclient, being written in Rust, can only function in environments where Rust compiles well. For example, this rules out MIPS - rustc currently does not function correctly on that architecture, and thus tfclient cannot, and likely never will support that architecture.

Finally, tfclient generally requires a functioning CGo compiler, in order to properly link to Nebula. If this is not available, but tfclient itself compiles fine, this is known as a 'Tier 2' platform - you must compile and run Nebula separately, and tfclient will be unable to manage it other than providing it's config.

Did Nebula add a new architecture, and we missed it? Rust supports a new architecture in a new release? Let us know! We love adding support for new systems whenever we can.

Did we miss an architecture? If your architecture is supported by Nebula, Rust, and CGo, but you still get linking errors or segfaults when trying to build tfclient, we might have missed you - get in touch and we will work with you to get your system supported :D