/*
 * Copyright (c) 2018-2020 Atmosphère-NX
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
#include <stratosphere.hpp>
#include "cal_fs_utils.hpp"

namespace ams::cal {

    namespace {

        constexpr inline s64 BatteryLotOffset  = 0x2CE0;
        constexpr inline size_t BatteryLotSize = 0x20;

        constexpr inline s64 BatteryVersionOffset  = 0x4310;
        constexpr inline size_t BatteryVersionSize = 0x10;

        constexpr inline size_t BatteryVendorSizeMax = 0x18;

    }

    Result GetBatteryVersion(u8 *out) {
        /* Read the battery version. */
        u8 battery_version[BatteryVersionSize];
        R_TRY(cal::impl::ReadCalibrationBlock(BatteryVersionOffset, battery_version, sizeof(battery_version)));

        /* Write the output. */
        *out = battery_version[0];
        return ResultSuccess();
    }

    Result GetBatteryVendor(size_t *out_vendor_size, void *dst, size_t dst_size) {
        /* Read the battery lot. */
        char battery_lot[BatteryLotSize];
        R_TRY(cal::impl::ReadCalibrationBlock(BatteryLotOffset, battery_lot, sizeof(battery_lot)));

        /* Copy output. */
        *out_vendor_size = static_cast<size_t>(util::Strlcpy(static_cast<char *>(dst), battery_lot, std::min(dst_size, BatteryVendorSizeMax)));
        return ResultSuccess();
    }

}