1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-25 10:52:11 +01:00

193 lines
4.5 KiB
C
Raw Normal View History

/*
* YAFFS: Yet Another Flash File System. A NAND-flash specific file system.
*
* Copyright (C) 2002-2011 Aleph One Ltd.
* for Toby Churchill Ltd and Brightstar Engineering
*
* Created by Charles Manning <charles@aleph1.co.uk>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
/*
* yaffscfg2k.c The configuration for the "direct" use of yaffs.
*
* This file is intended to be modified to your requirements.
* There is no need to redistribute this file.
*/
#include "yaffscfg.h"
#include "yaffs_guts.h"
#include "yaffsfs.h"
#include "yaffs_trace.h"
#include "yaffs_osglue.h"
#include <errno.h>
#include <signal.h>
#include "pios.h"
#include "pios_trace.h"
#include "pios_stdio.h"
#include <openpilot.h>
#include "pios_flashfs.h" /* API for flash filesystem */
#include "pios_flashfs_logfs_priv.h"
#include <pios_stdio.h>
unsigned yaffs_trace_mask = 0;
2014-11-08 12:59:16 +01:00
// YAFFS_TRACE_ERROR |
// YAFFS_TRACE_BUG |
// YAFFS_TRACE_ALWAYS |
// 0;
int random_seed;
int simulate_power_failure = 0;
2014-11-08 12:59:16 +01:00
static unsigned int pios_flash_device_count = 0;
/* Configure the devices that will be used */
#include "yaffs_nor_drv.h"
// called first before device device driver setup so need to change
int yaffs_start_up(void)
{
2014-11-08 12:59:16 +01:00
static int start_up_called = 0;
2014-11-08 12:59:16 +01:00
if (start_up_called) {
return 0;
}
start_up_called = 1;
2014-11-08 12:59:16 +01:00
/* Call the OS initialisation (eg. set up lock semaphore */
yaffsfs_OSInitialisation();
2014-11-08 12:59:16 +01:00
return 0;
}
2014-11-08 12:59:16 +01:00
void yaffsSigHandler(int sig)
{
char devicename[8];
int fs_id;
2014-11-08 12:59:16 +01:00
pios_trace(PIOS_TRACE_TEST, "yaffsSigHandler sig=%d", sig);
switch (sig) {
case SIGQUIT:
case SIGTERM:
case SIGKILL:
case SIGINT:
2014-11-08 12:59:16 +01:00
for (fs_id = 0; fs_id < pios_flash_device_count; fs_id++) {
snprintf(devicename, 6, "/dev%01u", (unsigned)fs_id);
2014-11-08 12:59:16 +01:00
pios_umount((const char *)devicename);
}
2014-11-08 12:59:16 +01:00
pios_flash_device_count = 0;
exit(1);
break;
default:
break;
}
}
2014-11-08 12:59:16 +01:00
static void yaffsSigSetup(
void (*sighandler)(int sig))
{
2014-11-08 12:59:16 +01:00
// sigset_t block_sigusr;
struct sigaction sa;
sigemptyset(&sa.sa_mask);
2014-11-08 12:59:16 +01:00
sa.sa_flags = 0;
sa.sa_handler = sighandler;
2014-11-08 12:59:16 +01:00
if (sigaction(SIGQUIT, &sa, NULL)) {
return;
}
sigemptyset(&sa.sa_mask);
2014-11-08 12:59:16 +01:00
sa.sa_flags = 0;
sa.sa_handler = sighandler;
2014-11-08 12:59:16 +01:00
if (sigaction(SIGINT, &sa, NULL)) {
return;
}
sigemptyset(&sa.sa_mask);
2014-11-08 12:59:16 +01:00
sa.sa_flags = 0;
sa.sa_handler = sighandler;
2014-11-08 12:59:16 +01:00
if (sigaction(SIGTERM, &sa, NULL)) {
return;
}
sigemptyset(&sa.sa_mask);
2014-11-08 12:59:16 +01:00
sa.sa_flags = 0;
sa.sa_handler = sighandler;
2014-11-08 12:59:16 +01:00
if (sigaction(SIGKILL, &sa, NULL)) {
return;
}
}
/**
* @brief Initialize the flash object setting FS. Each call creates a yaffs device
* @return 0 if success, -1 if failure
*/
int32_t PIOS_FLASHFS_Logfs_Init(
2014-11-08 12:59:16 +01:00
__attribute__((unused)) uintptr_t *fs_id, // return identifier for fs device
__attribute__((unused)) const struct flashfs_logfs_cfg *cfg, // optional - if flash
__attribute__((unused)) const struct pios_flash_driver *driver, // optional - if flash
__attribute__((unused)) uintptr_t flash_id) // optional - if flash
{
int retval;
2014-11-08 12:59:16 +01:00
pios_trace(PIOS_TRACE_TEST, "PIOS_FLASHFS_Logfs_Init");
char devicename[8];
char logfs_path[12];
// Initialise the yaffs OS subsystem
if (yaffs_start_up()) {
PIOS_Assert(0);
}
// Allocate the next device id
*fs_id = pios_flash_device_count;
pios_flash_device_count++;
2014-11-08 12:59:16 +01:00
snprintf(devicename, 6, "/dev%01u", (unsigned)*fs_id);
2014-11-08 12:59:16 +01:00
// Simposix implementation uses a ram nor simulation which can be installed
// as multiple instances
2014-11-08 12:59:16 +01:00
yaffs_nor_install_drv(devicename);
2014-11-08 12:59:16 +01:00
sigset_t sigset;
sigemptyset(&sigset);
yaffsSigSetup(yaffsSigHandler);
2014-11-08 12:59:16 +01:00
// Attempt to mount the device
retval = pios_mount(devicename);
if (retval < 0) {
pios_trace(PIOS_TRACE_ERROR, "Couldn't mount %s", devicename);
2014-11-08 12:59:16 +01:00
} else {
// Create a "logfs" directory on each yaffs device for use by the
// pios_logfs API.
snprintf(logfs_path, 12, "%s/%s", devicename, PIOS_LOGFS_DIR);
// Create the logfs directory if it does not already exist
2014-11-08 12:59:16 +01:00
retval = pios_mkdir(logfs_path, O_CREAT);
if (retval < 0) {
pios_trace(PIOS_TRACE_ERROR, "Couldn't mkdir %s", logfs_path);
}
}
return retval;
}