-
Notifications
You must be signed in to change notification settings - Fork 42
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for finding oxide processes on a sled #7194
Add support for finding oxide processes on a sled #7194
Conversation
Created using spr 1.3.6-beta.1
Created using spr 1.3.6-beta.1
Created using spr 1.3.6-beta.1
Created using spr 1.3.6-beta.1
@citrus-it I added you as a reviewer - if you have time do you mind looking over the libcontract bindings this is using? |
// The lifetime of this string is tied to the lifetime of the status | ||
// handle itself and will be cleaned up when the handle is freed. | ||
let mut ptr: *mut c_char = std::ptr::null_mut(); | ||
libcall_io!(ct_pr_status_get_svc_fmri(self.handle, &mut ptr)).map_err( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The ct_pr_status_get_svc_fmri(), ct_pr_status_get_svc_creator(), and ct_pr_status_get_svc_aux() functions read, respectively, the service FMRI, the contract's creator execname and the creator's auxiliary field. The buffer pointed to by fmri, aux or creator, is freed by a call to ct_status_free() and should not be modified.
I'm under the impression that the ptr
value here must be freed via a call to ct_status_free
- is that right? or is this just saying that the lifetime of the returned result must be shorter than ContractStatus
?
If it's the former (the ptr
value must be freed explicitly): Are we leaking?
If it's the latter (the ptr
values lives as long as ContractStatus
): Is this code unsound? Would it be possible to keep using the returned CString
after self
has been dropped?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The ptr returned is tied to the lifetime of the contract status handle ct_stathdl_t
. We read that pointer as a cstr but the function returns a CString which copies the data to own it. If I understand correctly the ptr returned from the call to ct_pr_status_get_svc_fmri
will not leave anything around because it will be cleaned up when ct_status_free
is called via the drop method on ContractStatus
.
I will verify this, but this was at least my intention upon writing this code.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, gotcha, so:
let cstr = unsafe { CStr::from_ptr(ptr) }
Would create a cstr
that needs to have a shorter lifetime than the handle, but:
cstr.to_owned()
Would clone it, and free us from that lifetime constraint when the function returns
I wonder if it would be valuable to add an |
Yes! The plan is to introduce a diagnostics command that lets you call the same endpoints that the support bundle sagas are using to collect all of the info. |
Created using spr 1.3.6-beta.1
Created using spr 1.3.6-beta.1
1d19061
into
spr/papertigers/main.add-support-for-finding-oxide-processes-on-a-sled
This reverts commit 1d19061.
This PR adds support for finding all oxide processes via libcontract and relying on the fact that we deploy oxide services with the fmri prefix svc:/oxide/. This allows us to find every pid started via smf even if the smf script uses ctrun.
You can see this for yourself by running pfexec ctstat -av on a helios/illumos based system:
This PR is on top of: