blob: 965296f0e0ee95ac0f0ee80cb719eef9552f51a7 [file] [log] [blame]
Austin Schuhdb2ed9d2022-12-26 14:02:26 -08001#include "absl/strings/str_cat.h"
2#include "absl/strings/str_split.h"
3#include "aos/events/shm_event_loop.h"
4#include "aos/init.h"
5#include "frc971/vision/media_device.h"
6#include "frc971/vision/v4l2_reader.h"
7
8DEFINE_string(config, "aos_config.json", "Path to the config file to use.");
9
10namespace y2022 {
11namespace vision {
12namespace {
13
14using namespace frc971::vision;
15
16class CameraReader {
17 public:
18 CameraReader(aos::EventLoop *event_loop, V4L2ReaderBase *reader)
19 : event_loop_(event_loop),
20 reader_(reader),
21 read_image_timer_(event_loop->AddTimer([this]() { ReadImage(); })) {
22 event_loop->OnRun(
23 [this]() { read_image_timer_->Setup(event_loop_->monotonic_now()); });
24 }
25
26 void ReadImage() {
27 if (!reader_->ReadLatestImage()) {
28 read_image_timer_->Setup(event_loop_->monotonic_now() +
29 std::chrono::milliseconds(10));
30 return;
31 }
32 reader_->SendLatestImage();
33
34 read_image_timer_->Setup(event_loop_->monotonic_now());
35 }
36
37 private:
38 aos::EventLoop *event_loop_;
39 V4L2ReaderBase *reader_;
40
41 aos::TimerHandler *const read_image_timer_;
42};
43
44void CameraReaderMain() {
45 std::optional<MediaDevice> media_device = FindMediaDevice("platform:rkisp1");
46
47 if (VLOG_IS_ON(1)) {
48 media_device->Log();
49 }
50
51 media_device->Reset();
52
53 media_device->Enable(
54 media_device->FindLink("ov5647 4-0036", 0, "rkisp1_csi", 0));
55 media_device->Enable(
56 media_device->FindLink("rkisp1_csi", 1, "rkisp1_isp", 0));
57 media_device->Enable(
58 media_device->FindLink("rkisp1_isp", 2, "rkisp1_resizer_selfpath", 0));
59 media_device->Enable(
60 media_device->FindLink("rkisp1_isp", 2, "rkisp1_resizer_mainpath", 0));
61
62 media_device->FindEntity("ov5647 4-0036")
63 ->pads()[0]
64 ->SetSubdevFormat(1296, 972, MEDIA_BUS_FMT_SBGGR10_1X10);
65
66 Entity *rkisp1_csi = media_device->FindEntity("rkisp1_csi");
67 rkisp1_csi->pads()[0]->SetSubdevFormat(1296, 972, MEDIA_BUS_FMT_SBGGR10_1X10);
68 rkisp1_csi->pads()[1]->SetSubdevFormat(1296, 972, MEDIA_BUS_FMT_SBGGR10_1X10);
69
70 // TODO(austin): Should we set this on the link?
71 // TODO(austin): Need to update crop too.
72 Entity *rkisp1_isp = media_device->FindEntity("rkisp1_isp");
73 rkisp1_isp->pads(0)->SetSubdevCrop(1296, 972);
74 rkisp1_isp->pads(0)->SetSubdevFormat(1296, 972, MEDIA_BUS_FMT_SBGGR10_1X10);
75
76 rkisp1_isp->pads(2)->SetSubdevCrop(1296, 972);
77 rkisp1_isp->pads(2)->SetSubdevFormat(1296, 972, MEDIA_BUS_FMT_YUYV8_2X8);
78
79 Entity *rkisp1_resizer_selfpath =
80 media_device->FindEntity("rkisp1_resizer_selfpath");
81 rkisp1_resizer_selfpath->pads(0)->SetSubdevFormat(1296, 972,
82 MEDIA_BUS_FMT_YUYV8_2X8);
83 rkisp1_resizer_selfpath->pads(1)->SetSubdevFormat(1296, 972,
84 MEDIA_BUS_FMT_YUYV8_2X8);
85 rkisp1_resizer_selfpath->pads(0)->SetSubdevCrop(1296, 972);
86
87 Entity *rkisp1_resizer_mainpath =
88 media_device->FindEntity("rkisp1_resizer_mainpath");
89 rkisp1_resizer_mainpath->pads(0)->SetSubdevFormat(1296, 972,
90 MEDIA_BUS_FMT_YUYV8_2X8);
91 rkisp1_resizer_mainpath->pads(1)->SetSubdevFormat(1296 / 2, 972 / 2,
92 MEDIA_BUS_FMT_YUYV8_2X8);
93 rkisp1_resizer_mainpath->pads(0)->SetSubdevCrop(1296 / 2, 972 / 2);
94
95 Entity *rkisp1_mainpath = media_device->FindEntity("rkisp1_mainpath");
96 rkisp1_mainpath->SetFormat(1296 / 2, 972 / 2, V4L2_PIX_FMT_YUV422P);
97
98 Entity *rkisp1_selfpath = media_device->FindEntity("rkisp1_selfpath");
99 rkisp1_selfpath->SetFormat(1296, 972, V4L2_PIX_FMT_YUYV);
100
101 aos::FlatbufferDetachedBuffer<aos::Configuration> config =
102 aos::configuration::ReadConfig(FLAGS_config);
103
104 aos::ShmEventLoop event_loop(&config.message());
105
106 event_loop.SetRuntimeRealtimePriority(55);
107
108 RockchipV4L2Reader v4l2_reader(&event_loop, rkisp1_selfpath->device());
109
110 // TODO(austin): Figure out exposure and stuff.
111 /*
112 const uint32_t exposure =
113 (FLAGS_use_outdoors ? FLAGS_outdoors_exposure : FLAGS_exposure);
114 if (exposure > 0) {
115 LOG(INFO) << "Setting camera to Manual Exposure mode with exposure = "
116 << exposure << " or " << static_cast<double>(exposure) / 10.0
117 << " ms";
118 v4l2_reader.SetExposure(exposure);
119 } else {
120 LOG(INFO) << "Setting camera to use Auto Exposure";
121 v4l2_reader.UseAutoExposure();
122 }
123 */
124
125 CameraReader camera_reader(&event_loop, &v4l2_reader);
126
127 event_loop.Run();
128}
129
130} // namespace
131} // namespace vision
132} // namespace y2022
133
134int main(int argc, char **argv) {
135 aos::InitGoogle(&argc, &argv);
136 y2022::vision::CameraReaderMain();
137}