2016-07-12 21:42:23 -04:00
|
|
|
//
|
|
|
|
// DigitalPhaseLockedLoopBridge.m
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 12/07/2016.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2016 Thomas Harte. All rights reserved.
|
2016-07-12 21:42:23 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#import "DigitalPhaseLockedLoopBridge.h"
|
|
|
|
|
|
|
|
#include "DigitalPhaseLockedLoop.hpp"
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
@interface DigitalPhaseLockedLoopBridge(BitPushing)
|
|
|
|
- (void)pushBit:(int)value;
|
|
|
|
@end
|
|
|
|
|
2020-01-12 17:25:21 -05:00
|
|
|
class DigitalPhaseLockedLoopDelegate {
|
2016-07-12 21:42:23 -04:00
|
|
|
public:
|
|
|
|
__weak DigitalPhaseLockedLoopBridge *bridge;
|
|
|
|
|
2017-07-16 20:55:57 -04:00
|
|
|
void digital_phase_locked_loop_output_bit(int value) {
|
2016-07-12 21:42:23 -04:00
|
|
|
[bridge pushBit:value ? 1 : 0];
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-07-16 20:55:57 -04:00
|
|
|
@implementation DigitalPhaseLockedLoopBridge {
|
2020-01-12 17:25:21 -05:00
|
|
|
std::unique_ptr<Storage::DigitalPhaseLockedLoop<DigitalPhaseLockedLoopDelegate>> _digitalPhaseLockedLoop;
|
2016-07-12 21:42:23 -04:00
|
|
|
DigitalPhaseLockedLoopDelegate _delegate;
|
|
|
|
}
|
|
|
|
|
2020-01-12 17:25:21 -05:00
|
|
|
- (instancetype)initWithClocksPerBit:(NSUInteger)clocksPerBit {
|
2016-07-12 21:42:23 -04:00
|
|
|
self = [super init];
|
2017-07-16 20:55:57 -04:00
|
|
|
if(self) {
|
2020-01-27 20:35:58 -05:00
|
|
|
_digitalPhaseLockedLoop = std::make_unique<Storage::DigitalPhaseLockedLoop<DigitalPhaseLockedLoopDelegate>>((unsigned int)clocksPerBit, _delegate);
|
2016-07-12 21:42:23 -04:00
|
|
|
_delegate.bridge = self;
|
|
|
|
}
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
2017-07-16 20:55:57 -04:00
|
|
|
- (void)runForCycles:(NSUInteger)cycles {
|
2017-07-24 21:04:47 -04:00
|
|
|
_digitalPhaseLockedLoop->run_for(Cycles((int)cycles));
|
2016-07-12 21:42:23 -04:00
|
|
|
}
|
|
|
|
|
2017-07-16 20:55:57 -04:00
|
|
|
- (void)addPulse {
|
2016-07-12 21:42:23 -04:00
|
|
|
_digitalPhaseLockedLoop->add_pulse();
|
|
|
|
}
|
|
|
|
|
2017-07-16 20:55:57 -04:00
|
|
|
- (void)pushBit:(int)value {
|
2016-07-12 21:42:23 -04:00
|
|
|
_stream = (_stream << 1) | value;
|
|
|
|
}
|
|
|
|
|
|
|
|
@end
|