output_base.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /*
  2. * Copyright (c) Meta Platforms, Inc. and affiliates.
  3. * All rights reserved.
  4. *
  5. * This source code is licensed under the BSD-style license found in the
  6. * LICENSE file in the root directory of this source tree.
  7. */
  8. #pragma once
  9. #include <fstream>
  10. #include <map>
  11. #include <ostream>
  12. #include <thread>
  13. #include <unordered_map>
  14. // TODO(T90238193)
  15. // @lint-ignore-every CLANGTIDY facebook-hte-RelativeInclude
  16. #include "IActivityProfiler.h"
  17. #include "GenericTraceActivity.h"
  18. #include "ThreadUtil.h"
  19. #include "TraceSpan.h"
  20. namespace KINETO_NAMESPACE {
  21. struct ActivityBuffers;
  22. }
  23. namespace libkineto {
  24. using namespace KINETO_NAMESPACE;
  25. class ActivityLogger {
  26. public:
  27. virtual ~ActivityLogger() = default;
  28. struct OverheadInfo {
  29. explicit OverheadInfo(const std::string& name) : name(name) {}
  30. const std::string name;
  31. };
  32. virtual void handleDeviceInfo(
  33. const DeviceInfo &info,
  34. uint64_t time) = 0;
  35. virtual void handleResourceInfo(const ResourceInfo& info, int64_t time) = 0;
  36. virtual void handleOverheadInfo(const OverheadInfo& info, int64_t time) = 0;
  37. virtual void handleTraceSpan(const TraceSpan& span) = 0;
  38. virtual void handleActivity(
  39. const libkineto::ITraceActivity& activity) = 0;
  40. virtual void handleGenericActivity(
  41. const libkineto::GenericTraceActivity& activity) = 0;
  42. virtual void handleTraceStart(
  43. const std::unordered_map<std::string, std::string>& metadata) = 0;
  44. void handleTraceStart() {
  45. handleTraceStart(std::unordered_map<std::string, std::string>());
  46. }
  47. virtual void finalizeTrace(
  48. const Config& config,
  49. std::unique_ptr<ActivityBuffers> buffers,
  50. int64_t endTime,
  51. std::unordered_map<std::string, std::vector<std::string>>& metadata) = 0;
  52. protected:
  53. ActivityLogger() = default;
  54. };
  55. } // namespace libkineto