2020-04-15 20:06:41 -04:00
|
|
|
/*
|
2020-07-03 05:31:22 -04:00
|
|
|
* utils.h
|
2020-04-15 20:06:41 -04:00
|
|
|
*
|
2020-07-03 05:31:22 -04:00
|
|
|
* Copyright (c) 2020, DarkMatterCore <pabloacurielz@gmail.com>.
|
|
|
|
*
|
|
|
|
* This file is part of nxdumptool (https://github.com/DarkMatterCore/nxdumptool).
|
|
|
|
*
|
|
|
|
* nxdumptool is free software; you can redistribute it and/or modify it
|
2020-04-15 20:06:41 -04:00
|
|
|
* under the terms and conditions of the GNU General Public License,
|
|
|
|
* version 2, as published by the Free Software Foundation.
|
|
|
|
*
|
2020-07-03 05:31:22 -04:00
|
|
|
* nxdumptool is distributed in the hope it will be useful, but WITHOUT
|
2020-04-15 20:06:41 -04:00
|
|
|
* 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/>.
|
|
|
|
*/
|
|
|
|
|
2020-04-15 16:50:07 -04:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#ifndef __UTILS_H__
|
|
|
|
#define __UTILS_H__
|
|
|
|
|
2020-07-03 05:31:22 -04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <malloc.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <ctype.h>
|
2020-07-26 00:57:12 -04:00
|
|
|
#include <math.h>
|
2020-07-03 05:31:22 -04:00
|
|
|
#include <time.h>
|
2020-07-25 01:56:35 -04:00
|
|
|
#include <sys/stat.h>
|
2020-07-12 11:29:08 -04:00
|
|
|
#include <stdatomic.h>
|
2020-04-15 16:50:07 -04:00
|
|
|
#include <switch.h>
|
2020-12-07 01:26:59 -03:00
|
|
|
#include <usbhsfs.h>
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-10-08 15:31:09 -03:00
|
|
|
#include "common.h"
|
|
|
|
|
2020-07-22 04:03:28 -04:00
|
|
|
#define APP_BASE_PATH "sdmc:/switch/" APP_TITLE "/"
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-04-17 17:59:05 -04:00
|
|
|
#define MEMBER_SIZE(type, member) sizeof(((type*)NULL)->member)
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-04-17 17:59:05 -04:00
|
|
|
#define MAX_ELEMENTS(x) ((sizeof((x))) / (sizeof((x)[0])))
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-07-13 02:36:17 -04:00
|
|
|
#define LOGFILE(fmt, ...) utilsWriteMessageToLogFile(__func__, fmt, ##__VA_ARGS__)
|
|
|
|
#define LOGBUF(dst, dst_size, fmt, ...) utilsWriteMessageToLogBuffer(dst, dst_size, __func__, fmt, ##__VA_ARGS__)
|
|
|
|
|
2020-10-08 18:52:31 -03:00
|
|
|
#define BIT_LONG(n) (1UL << (n))
|
|
|
|
|
2020-04-26 04:35:01 -04:00
|
|
|
#define ALIGN_DOWN(x, y) ((x) & ~((y) - 1))
|
|
|
|
#define ALIGN_UP(x, y) ((((y) - 1) + (x)) & ~((y) - 1))
|
2020-05-11 15:12:03 -04:00
|
|
|
#define IS_ALIGNED(x, y) (((x) & ((y) - 1)) == 0)
|
2020-10-04 04:05:05 -03:00
|
|
|
#define IS_POWER_OF_TWO(x) (((x) & ((x) - 1)) == 0)
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-04-17 17:59:05 -04:00
|
|
|
#define BIS_SYSTEM_PARTITION_MOUNT_NAME "sys:"
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-04-29 17:11:27 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-05-02 19:40:50 -04:00
|
|
|
|
2020-04-29 17:11:27 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Used to determine which CFW is the application running under.
|
2020-04-15 16:50:07 -04:00
|
|
|
typedef enum {
|
2020-04-16 06:13:11 -04:00
|
|
|
UtilsCustomFirmwareType_Unknown = 0,
|
|
|
|
UtilsCustomFirmwareType_Atmosphere = 1,
|
|
|
|
UtilsCustomFirmwareType_SXOS = 2,
|
|
|
|
UtilsCustomFirmwareType_ReiNX = 3
|
2020-04-15 16:50:07 -04:00
|
|
|
} UtilsCustomFirmwareType;
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Resource (de)initialization.
|
|
|
|
/// Called at program startup.
|
2020-05-02 19:40:50 -04:00
|
|
|
bool utilsInitializeResources(void);
|
|
|
|
void utilsCloseResources(void);
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Thread management functions.
|
2020-08-18 01:04:13 -04:00
|
|
|
bool utilsCreateThread(Thread *out_thread, ThreadFunc func, void *arg, int cpu_id);
|
|
|
|
void utilsJoinThread(Thread *thread);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Returns true if the application is running under a development unit.
|
2020-08-15 17:22:49 -04:00
|
|
|
bool utilsIsDevelopmentUnit(void);
|
|
|
|
|
2020-12-04 03:38:44 -03:00
|
|
|
/// Functions to retrieve down/held buttons from all input controllers.
|
|
|
|
/// utilsScanPads() must be called before utilsGetButtonsDown() / utilsGetButtonsHeld().
|
|
|
|
void utilsScanPads(void);
|
|
|
|
u64 utilsGetButtonsDown(void);
|
|
|
|
u64 utilsGetButtonsHeld(void);
|
2020-07-29 17:02:21 -04:00
|
|
|
|
2020-12-04 03:38:44 -03:00
|
|
|
/// Waits until any button matching the provided input flag is pressed.
|
|
|
|
/// If 'flag' is set to zero, any button press will count.
|
2020-07-05 20:10:07 -04:00
|
|
|
void utilsWaitForButtonPress(u64 flag);
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Formats a string and appends it to the provided buffer.
|
|
|
|
/// If the buffer isn't big enough to hold both its current contents and the new formatted string, it will be resized.
|
2020-10-02 06:53:58 -03:00
|
|
|
bool utilsAppendFormattedStringToBuffer(char **dst, size_t *dst_size, const char *fmt, ...);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Logfile management functions.
|
2020-07-13 02:36:17 -04:00
|
|
|
void utilsWriteMessageToLogFile(const char *func_name, const char *fmt, ...);
|
2020-10-02 06:53:58 -03:00
|
|
|
void utilsWriteMessageToLogBuffer(char **dst, size_t *dst_size, const char *func_name, const char *fmt, ...);
|
2020-07-13 02:36:17 -04:00
|
|
|
void utilsWriteLogBufferToLogFile(const char *src);
|
|
|
|
void utilsLogFileMutexControl(bool lock);
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Replaces illegal FAT characters in the provided string with underscores.
|
|
|
|
/// If 'ascii_only' is set to true, all characters outside the (0x20,0x7E] range will also be replaced with underscores.
|
2020-05-05 14:04:23 -04:00
|
|
|
void utilsReplaceIllegalCharacters(char *str, bool ascii_only);
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Trims whitespace characters from the provided string.
|
2020-05-02 19:40:50 -04:00
|
|
|
void utilsTrimString(char *str);
|
2020-04-16 06:13:11 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Generates a lowercase hex string representation of the binary data stored in 'src' and stores it in 'dst'.
|
2020-04-17 17:59:05 -04:00
|
|
|
void utilsGenerateHexStringFromData(char *dst, size_t dst_size, const void *src, size_t src_size);
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Formats the provided 'size' value to a human readable size string and stores it in 'dst'.
|
2020-07-26 00:57:12 -04:00
|
|
|
void utilsGenerateFormattedSizeString(u64 size, char *dst, size_t dst_size);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Saves the free file space from the filesystem pointed to by the input path (e.g. "sdmc:/") to 'out'.
|
|
|
|
/// Returns false if there's an error.
|
|
|
|
bool utilsGetFreeSpaceFromFileSystemByPath(const char *path, u64 *out);
|
|
|
|
|
|
|
|
/// Commits SD card filesystem changes.
|
|
|
|
/// Must be used after closing a file handle from the SD card.
|
2020-08-01 00:43:55 -04:00
|
|
|
bool utilsCommitSdCardFileSystemChanges(void);
|
2020-05-02 19:40:50 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Returns true if a file exists.
|
2020-05-02 19:40:50 -04:00
|
|
|
bool utilsCheckIfFileExists(const char *path);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Deletes a ConcatenationFile located at the input path.
|
2020-10-22 01:38:14 -03:00
|
|
|
void utilsRemoveConcatenationFile(const char *path);
|
2020-12-02 03:28:35 -03:00
|
|
|
|
|
|
|
/// Creates a ConcatenationFile at the input path.
|
2020-05-02 19:40:50 -04:00
|
|
|
bool utilsCreateConcatenationFile(const char *path);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Creates a full directory tree using the provided path.
|
|
|
|
/// If 'create_last_element' is true, the last element from the provided path will be created as well.
|
2020-07-29 17:02:21 -04:00
|
|
|
void utilsCreateDirectoryTree(const char *path, bool create_last_element);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Returns a pointer to a dynamically allocated string that holds the full path formed by the provided arguments.
|
2020-10-21 01:27:48 -03:00
|
|
|
char *utilsGeneratePath(const char *prefix, const char *filename, const char *extension);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Returns true if the application is running under Applet Mode.
|
2020-05-02 19:40:50 -04:00
|
|
|
bool utilsAppletModeCheck(void);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// (Un)blocks HOME button presses.
|
2020-05-02 19:40:50 -04:00
|
|
|
void utilsChangeHomeButtonBlockStatus(bool block);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Returns a UtilsCustomFirmwareType value.
|
|
|
|
u8 utilsGetCustomFirmwareType(void);
|
2020-05-02 19:40:50 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Returns a pointer to the FsStorage object for the eMMC BIS System partition.
|
2020-04-17 17:59:05 -04:00
|
|
|
FsStorage *utilsGetEmmcBisSystemPartitionStorage(void);
|
2020-04-15 16:50:07 -04:00
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Enables/disables CPU/MEM overclocking.
|
2020-05-02 19:40:50 -04:00
|
|
|
void utilsOverclockSystem(bool overclock);
|
|
|
|
|
2020-12-02 03:28:35 -03:00
|
|
|
/// Simple wrapper to sleep the current thread for a specific number of full seconds.
|
2020-05-02 19:40:50 -04:00
|
|
|
NX_INLINE void utilsSleep(u64 seconds)
|
2020-04-15 16:50:07 -04:00
|
|
|
{
|
2020-04-17 17:59:05 -04:00
|
|
|
if (seconds) svcSleepThread(seconds * (u64)1000000000);
|
2020-04-15 16:50:07 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* __UTILS_H__ */
|