Firmware  0.7.1
Loading...
Searching...
No Matches
service.hpp
Go to the documentation of this file.
1// Copyright (C) 2025 Vincent Hamp
2//
3// This program is free software: you can redistribute it and/or modify
4// it under the terms of the GNU General Public License as published by
5// the Free Software Foundation, either version 3 of the License, or
6// (at your option) any later version.
7//
8// This program is distributed in the hope that it will be useful,
9// but WITHOUT ANY WARRANTY; without even the implied warranty of
10// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11// GNU General Public License for more details.
12//
13// You should have received a copy of the GNU General Public License
14// along with this program. If not, see <https://www.gnu.org/licenses/>.
15
16#pragma once
17
18#include <mutex>
19#include <optional>
20#include <z21/z21.hpp>
21#include "accessories.hpp"
23#include "locos.hpp"
24#include "turnouts.hpp"
25
26namespace mw::dcc {
27
29class Service : public z21::server::intf::Dcc {
30public:
31 Service();
32
33 //
34 void z21(std::shared_ptr<z21::server::intf::System> z21_system_service,
35 std::shared_ptr<z21::server::intf::Dcc> z21_dcc_service);
36
37 //
40
41 //
45
46 //
50
51private:
52 // This gets called by FreeRTOS
53 [[noreturn]] void taskFunction(void*);
54
55 void operationsLoop();
56 void operationsLocos();
57 void operationsTurnouts();
58 void operationsBiDi();
59
60 void serviceLoop();
61 std::optional<uint8_t> serviceRead(uint16_t cv_addr);
62 std::optional<uint8_t> serviceWrite(uint16_t cv_addr, uint8_t byte);
63 std::optional<bool> serviceReceiveBit();
64 std::optional<uint8_t> serviceReceiveByte();
65
66 void sendToFront(Packet const& packet, size_t n = 1uz) const;
67 void sendToBack(Packet const& packet, size_t n = 1uz) const;
68
69 // Driving interface
70 void locoEStop(uint16_t loco_addr) final;
71 void locoPurge(uint16_t loco_addr) final;
72 z21::LocoInfo locoInfo(uint16_t loco_addr) final;
73 void locoDrive(uint16_t loco_addr,
74 z21::LocoInfo::SpeedSteps speed_steps,
75 uint8_t rvvvvvvv) final;
76 void locoFunction(uint16_t loco_addr, uint32_t mask, uint32_t state) final;
77 z21::LocoInfo::Mode locoMode(uint16_t loco_addr) final;
78 void locoMode(uint16_t, z21::LocoInfo::Mode mode) final;
79 void broadcastLocoInfo(uint16_t loco_addr) final;
80
81 // Switching interface
82 [[nodiscard]] z21::TurnoutInfo turnoutInfo(uint16_t accy_addr) final;
83 [[nodiscard]] z21::AccessoryInfo accessoryInfo(uint16_t accy_addr) final;
84 void turnout(uint16_t accy_addr, bool p, bool a, bool q) final;
85 void accessory(uint16_t accy_addr, uint8_t dddddddd) final;
86 [[nodiscard]] z21::TurnoutInfo::Mode turnoutMode(uint16_t accy_addr) final;
87 void turnoutMode(uint16_t accy_addr, z21::TurnoutInfo::Mode mode) final;
88 void broadcastTurnoutInfo(uint16_t accy_addr) final;
89 void broadcastExtAccessoryInfo(uint16_t accy_addr) final;
90
91 // Programming interface
92 [[nodiscard]] bool cvRead(uint16_t cv_addr) final;
93 [[nodiscard]] bool cvWrite(uint16_t cv_addr, uint8_t byte) final;
94 void cvPomRead(uint16_t loco_addr, uint16_t cv_addr) final;
95 void cvPomWrite(uint16_t loco_addr, uint16_t cv_addr, uint8_t byte) final;
96 void cvPomAccessoryRead(uint16_t accy_addr, uint16_t cv_addr, bool) final;
97 void cvPomAccessoryWrite(uint16_t accy_addr,
98 uint16_t cv_addr,
99 uint8_t byte,
100 bool) final;
101 void cvNackShortCircuit() final;
102 void cvNack() final;
103 void cvAck(uint16_t cv_addr, uint8_t byte) final;
104
105 // RailCom interface
106 [[nodiscard]] z21::RailComData railComData(uint16_t loco_addr) final;
107 void broadcastRailComData(uint16_t loco_addr) final;
108
109 //
110 void resume();
111 void suspend();
112
113 //
114 Loco& getOrInsertLoco(uint16_t loco_addr);
115 Turnout& getOrInsertTurnout(uint16_t accy_addr);
116
117 //
118 Address basicOrExtendedLocoAddress(Address::value_type addr) const;
119 bool maybeInvertR(bool p) const;
120 void sendLocoSpeedAndDirection(Address::value_type addr,
121 Loco const& loco) const;
122
125
126 std::mutex _internal_mutex;
127 std::shared_ptr<z21::server::intf::System> _z21_system_service;
128 std::shared_ptr<z21::server::intf::Dcc> _z21_dcc_service;
129
130 // NVS cache
131 struct {
135 uint8_t loco_flags{};
136 uint8_t accy_flags{};
139 } _nvs{};
140
142 struct CvRequest {
143 TickType_t timeout_tick{};
144 uint16_t addr{};
145 uint16_t cv_addr{};
146 std::optional<uint8_t> byte{};
147 };
148 ztl::inplace_deque<CvRequest, Z21_SERVER_MAX_LOCO_ADDRESSES_PER_CLIENT>
150 ztl::inplace_deque<CvRequest, Z21_SERVER_MAX_LOCO_ADDRESSES_PER_CLIENT>
152};
153
154} // namespace mw::dcc
uint8_t loco_flags
Definition service.hpp:135
ztl::inplace_deque< CvRequest, Z21_SERVER_MAX_LOCO_ADDRESSES_PER_CLIENT > _cv_pom_request_deque
Definition service.hpp:151
void locoFunction(uint16_t loco_addr, uint32_t mask, uint32_t state) final
Definition service.cpp:737
std::optional< bool > serviceReceiveBit()
Definition service.cpp:618
intf::http::Response locosGetRequest(intf::http::Request const &req)
Definition service.cpp:102
Locos _locos
Definition service.hpp:123
Address basicOrExtendedLocoAddress(Address::value_type addr) const
Definition service.cpp:1026
void resume()
Definition service.cpp:972
Turnout & getOrInsertTurnout(uint16_t accy_addr)
Definition service.cpp:1007
std::shared_ptr< z21::server::intf::System > _z21_system_service
Definition service.hpp:127
void cvNack() final
Definition service.cpp:951
void cvNackShortCircuit() final
Definition service.cpp:948
void cvAck(uint16_t cv_addr, uint8_t byte) final
Definition service.cpp:954
intf::http::Response turnoutsGetRequest(intf::http::Request const &req)
Definition service.cpp:216
intf::http::Response turnoutsDeleteRequest(intf::http::Request const &req)
Definition service.cpp:249
uint8_t programming_type
Definition service.hpp:132
std::shared_ptr< z21::server::intf::Dcc > _z21_dcc_service
Definition service.hpp:128
void cvPomWrite(uint16_t loco_addr, uint16_t cv_addr, uint8_t byte) final
Definition service.cpp:898
void operationsLocos()
Currently fills message buffer between 25 and 50%.
Definition service.cpp:360
std::optional< uint8_t > serviceRead(uint16_t cv_addr)
Definition service.cpp:566
void sendLocoSpeedAndDirection(Address::value_type addr, Loco const &loco) const
Definition service.cpp:1044
void operationsBiDi()
Definition service.cpp:444
Loco & getOrInsertLoco(uint16_t loco_addr)
Definition service.cpp:996
z21::TurnoutInfo turnoutInfo(uint16_t accy_addr) final
Definition service.cpp:786
void suspend()
Definition service.cpp:988
z21::LocoInfo locoInfo(uint16_t loco_addr) final
Definition service.cpp:704
void locoPurge(uint16_t loco_addr) final
Definition service.cpp:693
void broadcastExtAccessoryInfo(uint16_t accy_addr) final
Definition service.cpp:859
z21::AccessoryInfo accessoryInfo(uint16_t accy_addr) final
Definition service.cpp:795
void broadcastLocoInfo(uint16_t loco_addr) final
Definition service.cpp:781
struct mw::dcc::Service::@375351017336315001104246161026011227303125012136 _nvs
z21::TurnoutInfo::Mode turnoutMode(uint16_t accy_addr) final
Definition service.cpp:844
uint8_t accy_flags
Definition service.hpp:136
ztl::inplace_deque< CvRequest, Z21_SERVER_MAX_LOCO_ADDRESSES_PER_CLIENT > _cv_request_deque
Definition service.hpp:149
void sendToBack(Packet const &packet, size_t n=1uz) const
Definition service.cpp:654
bool cvRead(uint16_t cv_addr) final
Definition service.cpp:864
void turnout(uint16_t accy_addr, bool p, bool a, bool q) final
Definition service.cpp:804
std::optional< uint8_t > serviceWrite(uint16_t cv_addr, uint8_t byte)
Definition service.cpp:607
void accessory(uint16_t accy_addr, uint8_t dddddddd) final
Definition service.cpp:839
Service()
Definition service.cpp:36
void sendToFront(Packet const &packet, size_t n=1uz) const
Definition service.cpp:640
void locoEStop(uint16_t loco_addr) final
Definition service.cpp:661
z21::RailComData railComData(uint16_t loco_addr) final
Definition service.cpp:959
uint8_t accy_packet_count
Definition service.hpp:138
void operationsLoop()
Definition service.cpp:347
void broadcastRailComData(uint16_t loco_addr) final
Definition service.cpp:967
intf::http::Response turnoutsPutRequest(intf::http::Request const &req)
Definition service.cpp:272
std::mutex _internal_mutex
Definition service.hpp:126
intf::http::Response locosDeleteRequest(intf::http::Request const &req)
Definition service.cpp:136
void z21(std::shared_ptr< z21::server::intf::System > z21_system_service, std::shared_ptr< z21::server::intf::Dcc > z21_dcc_service)
Definition service.cpp:51
void locoDrive(uint16_t loco_addr, z21::LocoInfo::SpeedSteps speed_steps, uint8_t rvvvvvvv) final
Definition service.cpp:716
intf::http::Response locosPutRequest(intf::http::Request const &req)
Definition service.cpp:158
intf::http::Response postRequest(intf::http::Request const &req)
Definition service.cpp:69
bool maybeInvertR(bool p) const
Definition service.cpp:1037
void operationsTurnouts()
Definition service.cpp:429
uint8_t accy_switch_time
Definition service.hpp:137
void serviceLoop()
Definition service.cpp:523
Turnouts _turnouts
Definition service.hpp:124
std::optional< uint8_t > serviceReceiveByte()
Definition service.cpp:630
bool bit_verify_to_1
Definition service.hpp:134
uint8_t program_packet_count
Definition service.hpp:133
z21::LocoInfo::Mode locoMode(uint16_t loco_addr) final
Definition service.cpp:771
void cvPomRead(uint16_t loco_addr, uint16_t cv_addr) final
Definition service.cpp:878
void taskFunction(void *)
Definition service.cpp:329
void cvPomAccessoryWrite(uint16_t accy_addr, uint16_t cv_addr, uint8_t byte, bool) final
Definition service.cpp:933
bool cvWrite(uint16_t cv_addr, uint8_t byte) final
Definition service.cpp:871
void cvPomAccessoryRead(uint16_t accy_addr, uint16_t cv_addr, bool) final
Definition service.cpp:909
intf::http::Response getRequest(intf::http::Request const &req)
Definition service.cpp:58
void broadcastTurnoutInfo(uint16_t accy_addr) final
Definition service.cpp:854
std::atomic< State > state
Restricts access to low-level tasks.
Definition config.hpp:177
HTTP and WebSocket endpoints.
std::expected< std::string, std::string > Response
Definition response.hpp:29
Definition config.hpp:540
std::map< Address::value_type, Loco > Locos
Definition locos.hpp:23
std::map< Address::value_type, Turnout > Turnouts
Definition turnouts.hpp:23
Definition request.hpp:28
Actual object with volatile and non-volatile stuff.
Definition loco.hpp:43
Definition service.hpp:142
uint16_t addr
Definition service.hpp:144
uint16_t cv_addr
Definition service.hpp:145
TickType_t timeout_tick
Definition service.hpp:143
Actual object with volatile and non-volatile stuff.
Definition turnout.hpp:75