blob: 56d1479de41c8c7d72821291ff594d752727342b [file] [log] [blame]
Patrick Venturee7728422018-11-14 20:16:33 -08001#pragma once
2
Patrick Venture7b91cbc2018-11-28 14:24:41 -08003#include "internal/sys.hpp"
Patrick Venture5251da92019-01-17 11:25:26 -08004#include "window_hw_interface.hpp"
Patrick Venturee7728422018-11-14 20:16:33 -08005
Patrick Venturec9c60882019-01-17 11:44:47 -08006#include <cstdint>
Patrick Venture92973f12018-11-16 21:00:44 -08007#include <memory>
Patrick Venturebf064632019-01-17 12:20:21 -08008#include <string>
Patrick Venturec9c60882019-01-17 11:44:47 -08009#include <utility>
10#include <vector>
Patrick Venture92973f12018-11-16 21:00:44 -080011
Patrick Venturee7728422018-11-14 20:16:33 -080012namespace blobs
13{
14
Patrick Venture5251da92019-01-17 11:25:26 -080015class LpcMapperAspeed : public HardwareMapperInterface
Patrick Venturee7728422018-11-14 20:16:33 -080016{
17 public:
Patrick Venture5251da92019-01-17 11:25:26 -080018 static std::unique_ptr<HardwareMapperInterface>
Patrick Venture78b1a662019-01-17 12:38:26 -080019 createAspeedMapper(std::uint32_t regionAddress, std::size_t regionSize);
Patrick Venturee7728422018-11-14 20:16:33 -080020
Patrick Venture78b1a662019-01-17 12:38:26 -080021 LpcMapperAspeed(std::uint32_t regionAddress, std::size_t regionSize,
Patrick Venturefa9d0c92018-12-13 16:38:27 -080022 const internal::Sys* sys = &internal::sys_impl) :
Patrick Venture78b1a662019-01-17 12:38:26 -080023 regionAddress(regionAddress),
24 regionSize(regionSize), sys(sys){};
Patrick Venturee7728422018-11-14 20:16:33 -080025
Patrick Venture2343cfc2019-01-17 13:04:36 -080026 void close() override;
27
Patrick Venturee7728422018-11-14 20:16:33 -080028 std::pair<std::uint32_t, std::uint32_t>
29 mapWindow(std::uint32_t address, std::uint32_t length) override;
Patrick Venture7b91cbc2018-11-28 14:24:41 -080030
Patrick Venture517710d2019-01-17 11:37:40 -080031 std::vector<std::uint8_t> copyFrom(std::uint32_t length) override;
32
Patrick Venturea9e00052019-01-17 12:56:56 -080033 /**
34 * Attempt to mmap the region.
35 *
36 * @return true on success, false otherwise.
37 */
38 bool mapRegion();
39
Patrick Venture7b91cbc2018-11-28 14:24:41 -080040 private:
Patrick Venturebf064632019-01-17 12:20:21 -080041 static const std::string lpcControlPath;
Patrick Venture5d96c352019-01-17 12:44:06 -080042 int mappedFd = -1;
Patrick Venturea9e00052019-01-17 12:56:56 -080043 std::uint8_t* mappedRegion = nullptr;
Patrick Venture78b1a662019-01-17 12:38:26 -080044 std::uint32_t regionAddress;
Patrick Venture28abae72018-12-14 09:44:02 -080045 std::size_t regionSize;
Patrick Venturefa9d0c92018-12-13 16:38:27 -080046 const internal::Sys* sys;
Patrick Venturee7728422018-11-14 20:16:33 -080047};
48
49} // namespace blobs