aboutsummaryrefslogtreecommitdiff
path: root/vp8/vp8_ratectrl_rtc.h
diff options
context:
space:
mode:
Diffstat (limited to 'vp8/vp8_ratectrl_rtc.h')
-rw-r--r--vp8/vp8_ratectrl_rtc.h33
1 files changed, 17 insertions, 16 deletions
diff --git a/vp8/vp8_ratectrl_rtc.h b/vp8/vp8_ratectrl_rtc.h
index def7dd8f9..59fb60752 100644
--- a/vp8/vp8_ratectrl_rtc.h
+++ b/vp8/vp8_ratectrl_rtc.h
@@ -12,23 +12,24 @@
#define VPX_VP8_RATECTRL_RTC_H_
#include <cstdint>
+#include <cstring>
#include <memory>
-#include "vp8/encoder/onyx_int.h"
-#include "vp8/common/common.h"
#include "vpx/internal/vpx_ratectrl_rtc.h"
+struct VP8_COMP;
+
namespace libvpx {
struct VP8RateControlRtcConfig : public VpxRateControlRtcConfig {
public:
VP8RateControlRtcConfig() {
- vp8_zero(layer_target_bitrate);
- vp8_zero(ts_rate_decimator);
+ memset(&layer_target_bitrate, 0, sizeof(layer_target_bitrate));
+ memset(&ts_rate_decimator, 0, sizeof(ts_rate_decimator));
}
};
struct VP8FrameParamsQpRTC {
- FRAME_TYPE frame_type;
+ RcFrameType frame_type;
int temporal_layer_id;
};
@@ -36,25 +37,25 @@ class VP8RateControlRTC {
public:
static std::unique_ptr<VP8RateControlRTC> Create(
const VP8RateControlRtcConfig &cfg);
- ~VP8RateControlRTC() {
- if (cpi_) {
- vpx_free(cpi_->gf_active_flags);
- vpx_free(cpi_);
- }
- }
+ ~VP8RateControlRTC();
- void UpdateRateControl(const VP8RateControlRtcConfig &rc_cfg);
+ bool UpdateRateControl(const VP8RateControlRtcConfig &rc_cfg);
// GetQP() needs to be called after ComputeQP() to get the latest QP
int GetQP() const;
- // int GetLoopfilterLevel() const;
- void ComputeQP(const VP8FrameParamsQpRTC &frame_params);
+ // GetLoopfilterLevel() needs to be called after ComputeQP() since loopfilter
+ // level is calculated from frame qp.
+ int GetLoopfilterLevel() const;
+ // ComputeQP computes the QP if the frame is not dropped (kOk return),
+ // otherwise it returns kDrop and subsequent GetQP and PostEncodeUpdate
+ // are not to be called.
+ FrameDropDecision ComputeQP(const VP8FrameParamsQpRTC &frame_params);
// Feedback to rate control with the size of current encoded frame
void PostEncodeUpdate(uint64_t encoded_frame_size);
private:
VP8RateControlRTC() {}
- void InitRateControl(const VP8RateControlRtcConfig &cfg);
- VP8_COMP *cpi_;
+ bool InitRateControl(const VP8RateControlRtcConfig &cfg);
+ struct VP8_COMP *cpi_;
int q_;
};