⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 c64-fs-write.c

📁 伟大的Contiki工程, 短小精悍 的操作系统, 学习编程不可不看
💻 C
字号:
/** * \addtogroup c64fs * @{ *//** * \file * Implementation of C64 file writes. * \author Adam Dunkels <adam@dunkels.com> * * The functions in this file are not included in the core Contiki * code, but must be explicitly linked by an application that that * wishes to be able to write to files. *//* * Copyright (c) 2003, Adam Dunkels. * All rights reserved.  * * Redistribution and use in source and binary forms, with or without  * modification, are permitted provided that the following conditions  * are met:  * 1. Redistributions of source code must retain the above copyright  *    notice, this list of conditions and the following disclaimer.  * 2. Redistributions in binary form must reproduce the above *    copyright notice, this list of conditions and the following *    disclaimer in the documentation and/or other materials provided *    with the distribution.  * 3. The name of the author may not be used to endorse or promote *    products derived from this software without specific prior *    written permission.   * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.   * * This file is part of the Contiki desktop environment  * * $Id: c64-fs-write.c,v 1.1 2007/05/23 23:11:28 oliverschmidt Exp $ * */#include "c64-dio.h"#include "c64-fs.h"#include <string.h>/* An *UGLY* implementation of c64_fs_write that only can be used to   overwrite a single block file. */extern unsigned char _c64_fs_filebuf[256];extern unsigned char _c64_fs_filebuftrack,  _c64_fs_filebufsect;/*-----------------------------------------------------------------------------------*//** * Write data to an open file. * * \note This function currently does not support writing to other than a single block file (cannot be more than 254 bytes long). * * \param f A pointer to a file descriptor previously opened with c64_fs_open(). * * \param buf A pointer to a buffer with data that should be written * to the file. * * \param len The length of the data that should be written. * * \return The number of bytes actually written. * *//*-----------------------------------------------------------------------------------*/int __fastcall__c64_fs_write(register struct c64_fs_file *f, char *buf, int len){  int i;  if(len <= 0) {    return 0;  }  /* Check if current block is already in buffer, and if not read it     from disk. */  if(_c64_fs_filebuftrack != f->track ||     _c64_fs_filebufsect != f->sect) {    _c64_fs_filebuftrack = f->track;    _c64_fs_filebufsect = f->sect;    c64_dio_read_block(_c64_fs_filebuftrack,		       _c64_fs_filebufsect,		       _c64_fs_filebuf);  }  i = 256 - f->ptr;  if(len < i) {    i = len;  }  memcpy(&_c64_fs_filebuf[f->ptr], buf, i);  f->ptr += i;  if(_c64_fs_filebuf[0] == 0 &&     f->ptr > _c64_fs_filebuf[1]) {    _c64_fs_filebuf[1] = f->ptr;      }  c64_dio_write_block(_c64_fs_filebuftrack,		      _c64_fs_filebufsect,		      _c64_fs_filebuf);    return i;}/*-----------------------------------------------------------------------------------*//** @} */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -