Details
Diff Detail
- Build Status
Buildable 10257 Build 10257: arc lint + arc unit
Event Timeline
Adding in @kpw who also has more context on this implementation.
include/xray/xray_log_interface.h | ||
---|---|---|
166 | Because of ABI reasons, we really shouldn't change this struct. The comments say that if implementations need to add their arg1 handler, they should do it in the init implementation. | |
lib/xray/xray_fdr_logging.cc | ||
169 | You dropped the XRAY_NEVER_INSTRUMENT? Also now you probably want to mark this always inline. It would also make it more efficient to just return a 16-byte struct, so the inliner doesn't have to guess whether TSC and/or CPU alias. | |
179–180 | I'm ambivalent about this API change. Let me try to explain why. First, while the compiler might tail-call into the specified function, it was already using 7 arguments. In SysV64, that means the first 6 arguments that fit in registers will be in the registers already. Adding an argument spills more stuff onto the stack. That's one. Second, we're paying this cost in the path where we know we don't have an argument. That seems like a waste to me. Maybe it's better to refactor this differently, so we have the innards of processFunctionHook extracted appropriately so we can handle the "we are logging arguments" case and "we are not logging arguments" better? Or at least be able to compose either of these functions in an easier manner so while there will be a little redundancy, it's going to be easier to read and reason about. Packing on more arguments to the already overloaded processFunctionHook function seems like a bad way to go especially if we intend to support multiple argument logging in the future. |
after a long discussion and a long time on a different project, update to reflect comments
include/xray/xray_log_interface.h | ||
---|---|---|
166 | After our discussions about why we can't change this ABI (despite the fact LLVM itself is incredibly progressive in this regard), I've changed this to describe the proposed behaviour for anyone reading this code later. | |
lib/xray/xray_fdr_logging.cc | ||
169 | It was never there, fixed. I don't see the point of "inline" since it's already static and because processFunctionHook is so huge, we obviously don't care about the function call overhead here. Can we change this later, when that FIXME is being fixed properly? | |
179–180 | While I agree with you on the problems with the code structure, I tried making the change the least intrusive possible, and refactor later. I'll take your comment as a permission to tear processFunctionHook apart. |
lib/xray/xray_fdr_logging.cc | ||
---|---|---|
293 | Actually, you want to install the arg1 logging handler first, so that all the functions that have arg1 logging enabled don't sometimes use the arg0 then switch to the arg1 handler. | |
lib/xray/xray_fdr_logging_impl.h | ||
670 | Why make a copy of the shared_ptr here? I don't think we actually need a copy, do we? | |
747 | You want to use the global instead of a function-local here. See what we do in the logArg0 case. | |
776 | No validation here on the type of the entry? Nothing like what we do in the logArg0 handler to see that the EntryType isn't one of the unexpected values? | |
test/xray/TestCases/Linux/fdr-mode.cc | ||
92 | I think you want 'TRACE-DAG' still, but also need to look for the actual arguments too. Aren't we writing the list of arguments yet? |
lib/xray/xray_fdr_logging.cc | ||
---|---|---|
293 | Good point. Fixed and documented. |
LGTM
test/xray/TestCases/Linux/fdr-mode.cc | ||
---|---|---|
99–100 | Probably use UNWRITE-DAG here instead, similar to how we use TRACE-DAG above. |
lib/xray/xray_fdr_logging_impl.h | ||
---|---|---|
640–649 | Makes sense. | |
670 | Good point. I haven't gotten used to using shared_ptr properly yet. (C programmer learning.) | |
736–737 | Because of the ordering. The metadata need to be after the function record as that means it belongs to the function. | |
test/xray/TestCases/Linux/fdr-mode.cc | ||
99–100 | As discussed, we can't do that here since the point of UNWRITE is testing the other calls will *not* fire. The previous version of the test made sure of that which means putting UNWRITE-DAG here would actually destroy the tested behaviour. |
Because of ABI reasons, we really shouldn't change this struct. The comments say that if implementations need to add their arg1 handler, they should do it in the init implementation.