diff --git a/src/apps/cam/camera_session.cpp b/src/apps/cam/camera_session.cpp
index f6894340b..e50b26a5a 100644
--- a/src/apps/cam/camera_session.cpp
+++ b/src/apps/cam/camera_session.cpp
@@ -285,6 +285,17 @@ int CameraSession::start()
 
 	camera_->requestCompleted.connect(this, &CameraSession::requestComplete);
 
+	if (printMetadata_) {
+		camera_->metadataAvailable.connect(this, [](Request *r, MetadataList::Diff update) {
+			std::cout << ">> early metadata for " << r->sequence() << " with " << update.size() << " entries {\n";
+			for (auto &&[tag, v] : update) {
+				const auto *id = controls::controls.at(tag);
+				std::cout << '\t' << id->name() << " = " << v << '\n';
+			}
+			std::cout << "}" << std::endl;
+		});
+	}
+
 #ifdef HAVE_KMS
 	if (options_.isSet(OptDisplay))
 		sink_ = std::make_unique<KMSSink>(options_[OptDisplay].toString());
