亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mpfs.c

?? 單片機c語言程序設計100例--基于PIC+PROTEUS
?? C
字號:
/*********************************************************************
 *
 *               Microchip File System Implementaion on PIC18
 *
 *********************************************************************
 * FileName:        MPFS.c
 * Dependencies:    StackTsk.h
 *                  MPFS.h
 * Processor:       PIC18, PIC24F, PIC24H, dsPIC30F, dsPIC33F
 * Complier:        Microchip C18 v3.02 or higher
 *					Microchip C30 v2.01 or higher
 * Company:         Microchip Technology, Inc.
 *
 * Software License Agreement
 *
 * This software is owned by Microchip Technology Inc. ("Microchip") 
 * and is supplied to you for use exclusively as described in the 
 * associated software agreement.  This software is protected by 
 * software and other intellectual property laws.  Any use in 
 * violation of the software license may subject the user to criminal 
 * sanctions as well as civil liability.  Copyright 2006 Microchip
 * Technology Inc.  All rights reserved.
 *
 * This software is provided "AS IS."  MICROCHIP DISCLAIMS ALL 
 * WARRANTIES, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, NOT LIMITED 
 * TO MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND 
 * INFRINGEMENT.  Microchip shall in no event be liable for special, 
 * incidental, or consequential damages.
 *
 *
 * Author               Date        Comment
 *~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 * Nilesh Rajbharti     8/14/01     Original (Rev. 1.0)
 * Nilesh Rajbharti     2/9/02      Cleanup
 * Nilesh Rajbharti     5/22/02     Rev 2.0 (See version.log for detail)
 * Howard Schlunder     3/31/05		Changed MPFS_ENTRY and mpfs_Flags for C30
********************************************************************/
#define THIS_IS_MPFS

#include <string.h>
#include <stdlib.h>

#include "..\Include\MPFS.h"
#include "..\Include\Helpers.h"

#if defined(MPFS_USE_EEPROM)
    #include "..\Include\XEEPROM.h"
#endif
// This file system supports short file names i.e. 8 + 3.
#define MAX_FILE_NAME_LEN   (12u)

#define MPFS_DATA          (0x00u)
#define MPFS_DELETED       (0x01u)
#define MPFS_DLE           (0x03u)
#define MPFS_ETX           (0x04u)

/*
 * MPFS Structure:
 *
 * MPFS_Start:
 *      <MPFS_DATA><Address1><FileName1>
 *      <MPFS_DATA><Address2><FileName2>
 *      ...
 *      <MPFS_ETX><Addressn><FileNamen>
 * Address1:
 *      <Data1>[<Data2>...<Datan>]<MPFS_ETX><MPFS_INVALID>
 *      ...
 *
 * Note: If File data contains either MPFS_DLE or MPFS_ETX
 *       extra MPFS_DLE is stuffed before that byte.
 */
#ifdef MPFS_USE_PGRM
typedef struct  _MPFS_ENTRY
{
    BYTE Flag;
    MPFS Address;
    BYTE Name[MAX_FILE_NAME_LEN];
} MPFS_ENTRY;
#else	//MPFS_USE_EEPROM
typedef struct  _MPFS_ENTRY
{
    BYTE Flag __attribute__((__packed__));
    MPFS Address __attribute__((__packed__));
    BYTE Name[MAX_FILE_NAME_LEN] __attribute__((__packed__));
} MPFS_ENTRY;
#endif

static union
{
    struct
    {
        unsigned char bNotAvailable : 1;
    } bits;
    BYTE Val;
} mpfsFlags;

BYTE mpfsOpenCount;

#if defined(MPFS_USE_PGRM)

	// An address where MPFS data starts in program memory.
    extern MPFS MPFS_Start;

#else

#define MPFS_Start     MPFS_RESERVE_BLOCK

#endif

MPFS _currentHandle;
MPFS _currentFile;
BYTE _currentCount;


/*********************************************************************
 * Function:        BOOL MPFSInit(void)
 *
 * PreCondition:    None
 *
 * Input:           None
 *
 * Output:          TRUE, if MPFS Storage access is initialized and
 *                          MPFS is ready to be used.
 *                  FALSE otherwise
 *
 * Side Effects:    None
 *
 * Overview:        None
 *
 * Note:            None
 ********************************************************************/
BOOL MPFSInit(void)
{
    mpfsOpenCount = 0;
    mpfsFlags.Val = 0;

#if defined(MPFS_USE_PGRM)
    return TRUE;
#else
    /*
     * Initialize the EEPROM access routines.
     * Use ~ 400 Khz.
     */
    XEEInit(EE_BAUD(CLOCK_FREQ, 400000));

    return TRUE;
#endif
}


/*********************************************************************
 * Function:        MPFS MPFSOpen(BYTE* file)
 *
 * PreCondition:    None
 *
 * Input:           file        - NULL terminated file name.
 *
 * Output:          A handle if file is found
 *                  MPFS_INVALID if file is not found.
 *
 * Side Effects:    None
 *
 * Overview:        None
 *
 * Note:            None
 ********************************************************************/
MPFS MPFSOpen(BYTE* file)
{
    MPFS_ENTRY entry;
    MPFS FAT;
    BYTE fileNameLen;

    if( mpfsFlags.bits.bNotAvailable )
        return MPFS_NOT_AVAILABLE;

#if defined(MPFS_USE_PGRM)
    FAT = (MPFS)&MPFS_Start;
#else
    FAT = MPFS_Start;
#endif

    // If string is empty, do not attempt to find it in FAT.
    if ( *file == '\0' )
        return MPFS_INVALID;

    file = (BYTE*)strupr((char*)file);

    while(1)
    {
#if defined(MPFS_USE_PGRM)
        // Bring current FAT entry into RAM.
        memcpypgm2ram(&entry, (ROM void*)FAT, sizeof(entry));
#else
        XEEReadArray(EEPROM_CONTROL, FAT, (unsigned char*)&entry, sizeof(entry));
#endif

        // Make sure that it is a valid entry.
        if (entry.Flag == MPFS_DATA)
        {
            // Does the file name match ?
            fileNameLen = strlen((char*)file);
            if ( fileNameLen > MAX_FILE_NAME_LEN )
                fileNameLen = MAX_FILE_NAME_LEN;

            if( memcmp((void*)file, (void*)entry.Name, fileNameLen) == 0 )
            {
                _currentFile = (MPFS)entry.Address;
                mpfsOpenCount++;
                return entry.Address;
            }

            // File does not match.  Try next entry...
            FAT += sizeof(entry);
        }
        else if ( entry.Flag == MPFS_ETX )
        {
            if ( entry.Address != (MPFS)MPFS_INVALID )
                FAT = (MPFS)entry.Address;
            else
                break;
        }
	    else
	        return (MPFS)MPFS_INVALID;
    }
    return (MPFS)MPFS_INVALID;
}


/*********************************************************************
 * Function:        void MPFSClose(void)
 *
 * PreCondition:    None
 *
 * Input:           handle      - File handle to be closed
 *
 * Output:          None
 *
 * Side Effects:    None
 *
 * Overview:        None
 *
 * Note:            None
 ********************************************************************/
void MPFSClose(void)
{
    _currentCount = 0;
    mpfsFlags.bits.bNotAvailable = FALSE;
    if ( mpfsOpenCount )
        mpfsOpenCount--;
}


/*********************************************************************
 * Function:        BOOL MPFSGetBegin(MPFS handle)
 *
 * PreCondition:    MPFSOpen() != MPFS_INVALID &&
 *
 * Input:           handle      - handle of file that is to be read
 *
 * Output:          TRUE if successful
 *                  !TRUE otherwise
 *
 * Side Effects:    None
 *
 * Overview:        Prepares MPFS storage media for subsequent reads.
 *
 * Note:            None
 ********************************************************************/
#if defined(MPFS_USE_EEPROM)
BOOL MPFSGetBegin(MPFS handle)
{
    _currentHandle = handle;
    return (XEEBeginRead(EEPROM_CONTROL, handle) == XEE_SUCCESS);
}
#endif

/*********************************************************************
 * Function:        BYTE MPFSGet(void)
 *
 * PreCondition:    MPFSOpen() != MPFS_INVALID &&
 *                  MPFSGetBegin() == TRUE
 *
 * Input:           None
 *
 * Output:          Data byte from current address.
 *
 * Side Effects:    None
 *
 * Overview:        Reads a byte from current address.
 *
 * Note:            Caller must call MPFSIsEOF() to check for end of
 *                  file condition
 ********************************************************************/
BYTE MPFSGet(void)
{
    BYTE t;
    
#if defined(MPFS_USE_PGRM)
    t = (BYTE)*_currentHandle;
#else
    t = XEERead();
#endif
    _currentHandle++;

    if ( t == MPFS_DLE )
    {
#if defined(MPFS_USE_PGRM)
        t = (BYTE)*_currentHandle;
#else
        t = XEERead();
#endif
        _currentHandle++;
    }
    else if ( t == MPFS_ETX )
    {
        _currentHandle = MPFS_INVALID;
    }

    return t;

}


/*********************************************************************
 * Function:        MPFS MPFSGetEnd(void)
 *
 * PreCondition:    MPFSOpen() != MPFS_INVALID &&
 *                  MPFSGetBegin() = TRUE
 *
 * Input:           None
 *
 * Output:          Current mpfs handle.
 *
 * Side Effects:    None
 *
 * Overview:        Ends on-going read cycle.
 *                  MPFS handle that is returned must be used
 *                  for subsequent begin gets..
 *
 * Note:            None
 ********************************************************************/
#if defined(MPFS_USE_EEPROM)
MPFS MPFSGetEnd(void)
{
    XEEEndRead();
    return _currentHandle;
}
#endif


/*********************************************************************
 * Function:        MPFS MPFSFormat(void)
 *
 * PreCondition:    None
 *
 * Input:           None
 *
 * Output:          A valid MPFS handle that can be used for MPFSPut
 *
 * Side Effects:    None
 *
 * Overview:        Prepares MPFS image to get re-written
 *                  Declares MPFS as in use.
 *
 * Note:            MPFS will be unaccessible until MPFSClose is
 *                  called.
 ********************************************************************/
MPFS MPFSFormat(void)
{
    mpfsFlags.bits.bNotAvailable = TRUE;
    return (MPFS)MPFS_RESERVE_BLOCK;
}


/*********************************************************************
 * Function:        BOOL MPFSPutBegin(MPFS handle)
 *
 * PreCondition:    MPFSInit() and MPFSFormat() are already called.
 *
 * Input:           handle  - handle to where put to begin
 *
 * Output:          TRUE if successful
 *                  !TRUE otherwise
 *
 * Side Effects:    None
 *
 * Overview:        Prepares MPFS image to get re-written
 *
 * Note:            MPFS will be unaccessible until MPFSClose is
 *                  called.
 ********************************************************************/
#if defined(MPFS_USE_EEPROM)
BOOL MPFSPutBegin(MPFS handle)
{
    //_currentCount = 0;
    _currentHandle = handle;
    _currentCount = (BYTE)handle;
    _currentCount &= (MPFS_WRITE_PAGE_SIZE-1);
    return (XEEBeginWrite(EEPROM_CONTROL, handle) == XEE_SUCCESS);
}
#endif


/*********************************************************************
 * Function:        BOOL MPFSPut(BYTE b)
 *
 * PreCondition:    MPFSFormat() or MPFSCreate() must be called
 *                  MPFSPutBegin() is already called.
 *
 * Input:           b       - data to write.
 *
 * Output:          TRUE if successfull
 *                  !TRUE if failed.
 *
 * Side Effects:    Original MPFS handle is no longer valid.
 *                  Updated MPFS handle must be obtained by calling
 *                  MPFSPutEnd().
 *
 * Overview:        None
 *
 * Note:            Actual write may not get started until internal
 *                  write page is full.  To ensure that previously
 *                  data gets written, caller must call MPFSPutEnd()
 *                  after last call to MPFSPut().
 ********************************************************************/
BOOL MPFSPut(BYTE b)
{
#if defined(MPFS_USE_EEPROM)
    if ( XEEWrite(b) )
        return FALSE;

    _currentCount++;
    _currentHandle++;
    if ( _currentCount >= MPFS_WRITE_PAGE_SIZE )
    {
        MPFSPutEnd();
        XEEBeginWrite(EEPROM_CONTROL, _currentHandle);
    }
#endif
    return TRUE;
}

/*********************************************************************
 * Function:        MPFS MPFSPutEnd(void)
 *
 * PreCondition:    MPFSPutBegin() is already called.
 *
 * Input:           None
 *
 * Output:          Up-to-date MPFS handle
 *
 * Side Effects:    Original MPFS handle is no longer valid.
 *                  Updated MPFS handle must be obtained by calling
 *                  MPFSPutEnd().
 *
 * Overview:        None
 *
 * Note:            Actual write may not get started until internal
 *                  write page is full.  To ensure that previously
 *                  data gets written, caller must call MPFSPutEnd()
 *                  after last call to MPFSPut().
 ********************************************************************/
MPFS MPFSPutEnd(void)
{
#if defined(MPFS_USE_EEPROM)
    _currentCount = 0;
    XEEEndWrite();
    while( XEEIsBusy(EEPROM_CONTROL) );
#endif

    return _currentHandle;
}

/*********************************************************************
 * Function:        MPFS MPFSSeek(MPFS_OFFSET offset)
 *
 * PreCondition:    MPFSGetBegin() is already called.
 *
 * Input:           offset      - Offset from current pointer
 *
 * Output:          New MPFS handle located to given offset
 *
 * Side Effects:    None.
 *
 * Overview:        None
 *
 * Note:            None.
 ********************************************************************/
MPFS MPFSSeek(MPFS_OFFSET offset)
{
    WORD i;

    MPFSGetBegin(_currentFile);

    i = 0;
    while(i++ != offset)
        MPFSGet();

    MPFSGetEnd();

    return _currentHandle;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美喷水一区二区| 久久亚洲捆绑美女| 精品美女在线观看| 一区二区三区成人在线视频| 日韩av成人高清| 91网站黄www| 久久影院午夜片一区| 亚洲成av人片在线观看| 成人网男人的天堂| 欧美另类高清zo欧美| 亚洲欧洲精品一区二区三区| 激情综合一区二区三区| 91久久精品网| 国产精品久久久久影院色老大| 蜜臀久久99精品久久久久久9 | 国产精品午夜电影| 丝袜亚洲另类欧美综合| 色诱亚洲精品久久久久久| 久久久亚洲精品一区二区三区 | 欧美在线小视频| 国产丝袜在线精品| 久久精品国产999大香线蕉| 欧美日韩中文字幕一区二区| 国产欧美日韩精品a在线观看| 裸体一区二区三区| 欧美日韩亚洲国产综合| 樱花影视一区二区| 91丝袜美腿高跟国产极品老师 | 极品美女销魂一区二区三区| av电影在线观看不卡| 26uuu成人网一区二区三区| 亚洲bt欧美bt精品777| 99久久精品免费看国产| 国产亚洲欧洲一区高清在线观看| 日韩高清在线不卡| 欧美性xxxxxxxx| 亚洲男女毛片无遮挡| 国产**成人网毛片九色 | 免费在线观看视频一区| 色婷婷精品大视频在线蜜桃视频| 久久久99精品久久| 另类综合日韩欧美亚洲| 91精品啪在线观看国产60岁| 亚洲午夜精品17c| 成人美女在线观看| 久久久久亚洲蜜桃| 国产一区二区在线免费观看| 日韩欧美激情一区| 久久国产精品99久久久久久老狼| 欧美日韩激情一区| 亚洲观看高清完整版在线观看| 日本道色综合久久| 亚洲视频一二三| 欧美日韩亚洲不卡| 视频一区欧美精品| 日韩一级视频免费观看在线| 日本91福利区| 日韩女优av电影在线观看| 日韩激情av在线| 欧美一级欧美三级在线观看 | 成人福利视频在线看| 国产精品私人影院| 91免费版在线看| 亚洲夂夂婷婷色拍ww47| 欧美人伦禁忌dvd放荡欲情| 天堂久久久久va久久久久| 91精品国产免费| 激情偷乱视频一区二区三区| 国产日韩欧美制服另类| 成人av午夜电影| 亚洲国产日日夜夜| 日韩午夜激情视频| 国产美女娇喘av呻吟久久| 国产精品卡一卡二| 欧美在线免费视屏| 捆绑变态av一区二区三区| 国产欧美精品国产国产专区 | 日本免费在线视频不卡一不卡二| 久久久久国产免费免费| 97精品视频在线观看自产线路二| 一区二区激情小说| 欧美成人在线直播| 91在线免费视频观看| 视频一区视频二区中文| 欧美激情一区二区三区全黄| 在线日韩一区二区| 激情综合色综合久久综合| 国产精品超碰97尤物18| 91精品婷婷国产综合久久竹菊| 国产成人a级片| 亚洲成av人综合在线观看| 国产网站一区二区三区| 欧美色窝79yyyycom| 久久不见久久见免费视频7| 亚洲一区二区在线免费看| 2017欧美狠狠色| 91视频在线看| 国产伦精品一区二区三区在线观看| 亚洲精品视频一区二区| 久久伊99综合婷婷久久伊| 在线一区二区三区四区五区| 国产精品亚洲一区二区三区妖精| 亚洲精品videosex极品| 久久久久久久一区| 欧美日韩免费高清一区色橹橹| 99re这里只有精品首页| 国产一区二区三区四区五区美女| 亚洲国产成人porn| 中文av一区特黄| 日韩免费高清视频| 欧美日韩一区二区三区高清| 成人av资源网站| 国产做a爰片久久毛片| 亚洲国产美女搞黄色| 亚洲三级在线播放| 精品成人佐山爱一区二区| 欧美日韩免费在线视频| 92精品国产成人观看免费| 国产91精品一区二区麻豆亚洲| 1区2区3区国产精品| 亚洲视频香蕉人妖| 国产精品嫩草久久久久| 欧美国产精品一区| 欧美激情一区在线| 国产精品乱码妇女bbbb| 欧美一区二区大片| 91麻豆精品国产91久久久| 911精品产国品一二三产区| 欧美三级电影网| 欧美日韩国产中文| 欧美日韩一区二区三区四区五区 | 国产三级精品三级| 久久欧美一区二区| 精品久久一区二区三区| 精品久久久久久久久久久久久久久久久| 欧美一区二区三区啪啪| 欧美一区二区三区白人| 日韩女同互慰一区二区| 精品精品欲导航| 精品裸体舞一区二区三区| 久久新电视剧免费观看| 国产视频一区二区三区在线观看 | 午夜成人免费电影| 日韩高清不卡一区二区三区| 人禽交欧美网站| 久久99精品久久久| 国产乱码精品一区二区三区五月婷| 青青草原综合久久大伊人精品优势| 精品一区二区日韩| 风间由美性色一区二区三区| 99国产精品久久| 欧美亚洲另类激情小说| 91精品欧美综合在线观看最新| 日韩女优电影在线观看| 亚洲精品一区二区三区影院| 国产视频一区二区三区在线观看 | 中文字幕人成不卡一区| 亚洲制服丝袜一区| 理论片日本一区| 成人激情小说网站| 欧洲国内综合视频| 日韩欧美一区在线| 国产精品盗摄一区二区三区| 亚洲综合在线五月| 久久99精品一区二区三区| 成人高清在线视频| 精品视频999| 国产日韩在线不卡| 日本欧美肥老太交大片| www.亚洲精品| 欧美一级视频精品观看| 国产精品沙发午睡系列990531| 一区二区三区免费网站| 激情丁香综合五月| 欧美主播一区二区三区美女| 欧美va亚洲va香蕉在线| 国产区在线观看成人精品| 亚洲成av人在线观看| 国产凹凸在线观看一区二区| 欧美日韩在线三级| 国产精品网站在线播放| 日韩精品五月天| 色综合天天综合网天天狠天天 | 91精品一区二区三区在线观看| 欧美激情中文字幕| 亚洲成人免费影院| 91美女福利视频| 国产亚洲成av人在线观看导航| 午夜成人免费视频| 99视频精品在线| 国产日韩欧美精品综合| 免费亚洲电影在线| 日本高清成人免费播放| 久久亚洲春色中文字幕久久久| 久久精品99国产精品| 欧美久久久久中文字幕| 亚洲精品亚洲人成人网在线播放| 成人在线视频首页| 91精品久久久久久久91蜜桃| 亚洲激情五月婷婷|