狠狠综合久久久久综合网址-a毛片网站-欧美啊v在线观看-中文字幕久久熟女人妻av免费-无码av一区二区三区不卡-亚洲综合av色婷婷五月蜜臀-夜夜操天天摸-a级在线免费观看-三上悠亚91-国产丰满乱子伦无码专区-视频一区中文字幕-黑人大战欲求不满人妻-精品亚洲国产成人蜜臀av-男人你懂得-97超碰人人爽-五月丁香六月综合缴情在线

代寫COP4600 File Systems編程代做

時間:2024-04-10  來源:  作者: 我要糾錯



P3: File Systems
Overview
Your cover in the Lizard Legion was blown, and you’ve been revealed as a double agent and driven out! It was
all very “James Bond”, if you do say so yourself, and what a daring underground helicopter escape it was… but
you feel lucky to have escaped with your skin. (Literally... they would have used you to make a “human suit”!)
Now that you’re back on the “outside”, you’ve been tasked with creating a scheme to allow remaining resistance
fighters still within the Lizard Legion to clandestinely move information back to your organization without raising
suspicion. As of late, members of the Lizard Legion have discovered the PC classic “DOOM”, and it has become
all the rage to build new mods for it at headquarters, so your team has decided to use mods for this title as a
vehicle for exfiltration. By burying encrypted bits within textures and other game data blocks, information can be
hidden within innocuous “WAD” (Where’s All the Data) files.
In this project, you will implement a userspace filesystem daemon using the FUSE (Filesystem in UserSpacE)
API to access data in WAD format, the standard used in a number of classic PC game titles (including DOOM
and Hexen). In this critical early prototype, you have been tasked with implementing read and write access to
files and directories within the WAD files as a proof-of-concept. As such, you will need to implement read and
write functionality for both files and directories within your FUSE-based program. We, as your comrades-inarms battling the Reptilian invasion, will provide sample WAD files to demonstrate the functionality of your
implementation. (The resistance is counting on you!) The resistance uses university courses as cover for
standard operations, so you’ll submit the project via Canvas.
Structure
The project is broken into three main parts:
1) Develop a library to read from and write to WAD files and create a directory and file structure from them.
2) Implement a userspace daemon (via FUSE) to access the directory structure once mounted.
3) Test your implementation by navigating the mounted directory, examining the names and file contents, and
adding directories and files of your own.
While exact implementation may vary, the daemon’s parameters must match those laid out in this document, and
the directory structure, naming, and file contents must be properly presented via the filesystem.
File Format
The WAD file format contains information in three sections: the header, which gives basic layout information,
the descriptors, which describe elements in the file, and the lumps, which contain the data themselves. NOTE:
all numbers are in little-Endian format and, where applicable, are designated in bytes! Since Reptilian stores
its variables in memory in little-Endian format as well, it is not necessary to perform any byte-order inversions
when reading in or writing data, but this is still important information to know.
File Header
The header contains the file magic, descriptor count, and location (offset) of the descriptors in the file:
The magic for a wad file is usually ASCII and always ends in the suffix "WAD" (e.g., "IWAD" or "PWAD").
It is also important to note that the descriptor list, beginning at the position indicated by the descriptor
offset, is always situated at the end of the WAD file.
Descriptors
The file’s descriptors contain information about elements in the WAD file – its file offset, length, and
name:
Some elements will have specific naming conventions that will differentiate them from regular content
files. These “marker” elements will be interpreted by the daemon as directories and should be displayed
accordingly in the filesystem (see below).
Lumps
Elements in the WAD format are stored as “lumps” described by the descriptors. These lumps will be
represented in the filesystem by the daemon as individual files that can be opened, read, and closed.
You cannot write to existing lumps, but you will be creating empty files whose lumps you will have
to write to.
Marker Elements
There are two primary types of marker elements in WAD files, each of which should be interpreted as
directories by our daemon. The type includes map markers and namespace markers.
Map marker names are of the format "E#M#", where # represents a single decimal digit (e.g., "E1M9").
They are followed by ten (10) map element descriptors. The elements for the next 10 descriptors should be
placed inside of a directory with the map’s name. Map marker directories cannot have files or directories
added to them.
Namespace markers come in pairs. A namespace’s beginning is marked with a descriptor whose name has
the suffix "_START" (e.g., "F1_START"), and its ending is marked with a descriptor whose name has the
suffix "_END" (e.g., "F1_END"). Any descriptors for elements falling between the beginning and ending
markers for a namespace should be placed within a directory with the namespace’s name (e.g., "F1").
The namespace marker's name, excluding the suffixes, will never exceed two characters. These will be
the kind of directories you will be responsible for creating.
As an example, the following descriptors, in order, in the descriptor list, should result in this organization:
Library
Your library will contain a class to represent WAD data as described in this section.
Wad Class
The Wad class is used to represent WAD data and should have the following functions. The root of all paths
in the WAD data should be "/", and each directory should be separated by '/' (e.g., "/F/F1/LOLWUT").
public static Wad* loadWad(const string &path)
Object allocator; dynamically creates a Wad object and loads the WAD file data from path into memory.
Caller must deallocate the memory using the delete keyword.
public string getMagic()
Returns the magic for this WAD data.
public bool isContent(const string &path)
Returns true if path represents content (data), and false otherwise.
public bool isDirectory(const string &path)
Returns true if path represents a directory, and false otherwise.
public int getSize(const string &path)
If path represents content, returns the number of bytes in its data; otherwise, returns -1.
public int getContents(const string &path, char *buffer, int length, int offset = 0)
If path represents content, copies as many bytes as are available, up to length, of content's data into the preexisting buffer. If offset is provided, data should be copied starting from that byte in the content. Returns
number of bytes copied into buffer, or -1 if path does not represent content (e.g., if it represents a directory).
public int getDirectory(const string &path, vector<string> *directory)
If path represents a directory, places entries for immediately contained elements in directory. The elements
should be placed in the directory in the same order as they are found in the WAD file. Returns the number of
elements in the directory, or -1 if path does not represent a directory (e.g., if it represents content).
Offset Length Name
0 0 F_START
0 0 F1_START
67500 0 E1M1
67500 1380 THINGS
68880 6650 LINEDEFS
75532 19440 SIDEDEFS
94972 1868 VERTEXES
96840 8784 SEGS
105624 948 SSECTORS
106572 6608 NODES
113180 2210 SECTORS
115392 904 REJECT
116296 6922 BLOCKMAP
42 9001 LOLWUT
0 0 F1_END
0 0 F_END
F
 F1
 E1M1
 THINGS
 LINEDEFS
 SIDEDEFS
 VERTEXES
 SEGS
 SSECTORS
 NODES
 SECTORS
 REJECT
 BLOCKMAP
LOLWUT
Directory Structure

public void createDirectory(const string &path)
path includes the name of the new directory to be created. If given a valid path, creates a new directory
using namespace markers at path. The two new namespace markers will be added just before the “_END”
marker of its parent directory. New directories cannot be created inside map markers.
public void createFile(const string &path)
path includes the name of the new file to be created. If given a valid path, creates an empty file at path,
with an offset and length of 0. The file will be added to the descriptor list just before the “_END” marker
of its parent directory. New files cannot be created inside map markers.
public int writeToFile(const string &path, const char *buffer, int length, int offset = 0)
If given a valid path to an empty file, augments file size and generates a lump offset, then writes length amount
of bytes from the buffer into the file’s lump data. If offset is provided, data should be written starting from that
byte in the lump content. Returns number of bytes copied from buffer, or -1 if path does not represent content
(e.g., if it represents a directory).
Daemon Command & Parameters
Your daemon should have name wadfs and should accept at a minimum three parameters – the single-threaded
flag "-s", the target WAD file, and the mount directory. For example, this command should mount TINY.WAD
in /home/reptilian/mountdir…
$ ./wadfs -s TINY.WAD /home/reptilian/mountdir
$
…and this should result from executing the ls command to show part of its contents:
$ ls /home/reptilian/mountdir/F/F1 -al
total 0
drwxrwxrwx. 2 root root 0 Jan 1 1970 .
drwxrwxrwx. 2 root root
drwxrwxrwx. 2 root root
 0 Jan 1 1970 ..
 0 Jan 1 1970 E1M1
-rwxrwxrwx. 2 root root 9001 Jan 1 1970 LOLWUT
Your daemon should run in the background. Do not hard-code the debug (-d) or foreground (-f) flags!
We will use the following command below to unmount your filesystem:
$ fusermount -u /home/reptilian/mountdir
Extra Credit
You may notice when testing with your daemon that there is an upper limit to how large files you create in
your filesystem can be. Your task is to configure your library and daemon such that you are able to create
large files in your filesystem (using "cp" to copy in a 200KB image file, for example). Running your
daemon in debug mode (-d) may give you hints as to how certain calls are expected to behave.
NOTE: If a file or directory is created inside the root directory, it will be placed at the very end of the
descriptor list, instead of before an "_END" namespace marker.
Building with FUSE
FUSE is a userspace filesystem API that is supported directly by the Linux kernel. It allows userspace programs
to provide information to the kernel about filesystems the kernel cannot interpret on its own.
Installation & Setup
To use the FUSE library, you will need to install it within Reptilian and change the FUSE permissions:
$ sudo apt install libfuse-dev fuse
$ sudo chmod 666 /dev/fuse
NOTE: if you reboot the virtual machine, you will need to re-add the FUSE permissions, as they will be reset!
Build Directives
In order to build programs using the FUSE library system, you will need to specify the file offset bits as 64 and
identify the FUSE version. We recommend specifying FUSE version 26 (though this is optional):
$ g++ -D_FILE_OFFSET_BITS=64 -DFUSE_USE_VERSION=26 myproggy.cpp -o myproggy -lfuse
Submissions
You will submit the following at the end of this project:
 Report (p3.txt) in man page format on Canvas, including link to unlisted screencast video
 Compressed tar archive (wad.tar.gz) for libWad library and wadfs daemon on Canvas
Report
Your report will explain how you implemented the daemon, including your general architecture / program
structure. It must include an explanation of how you represent the WAD file elements as a directory structure
in memory, as well as how this structure was utilized in the daemon when running. It will include a
description of how testing was performed along with any known bugs. The report should be no more than 600
words, cover all relevant aspects of the project, and be organized and formatted professionally – this is not a
memo!
File and Directory Requirements
Your daemon must implement, at a minimum, the following filesystem functions to provide read and write
access:
1) Retrieving file and directory attributes
2) Reading from existing files, and writing to new ones
3) Reading from existing directories, and writing to new ones
Files and directories should be given full read, write, and execute permissions.
The above requirements will be achieved using, at a minimum, the following six fuse callback functions:
get_attr, mknod, mkdir, read, write, and readdir
It is highly recommended to closely follow the linked resources at the bottom of this pdf to assist with your
FUSE implementation. All changes to the filesystem, such as directory and file creation, must survive between
mounting and unmounting.
To build the library and daemon, we will execute these commands:
$ tar zxvf wad.tar.gz
$ cd libWad
$ make
$ cd ..
$ cd wadfs
$ make
$ cd ..
To run your daemon, we will execute this command:
$ ./wadfs/wadfs -s somewadfile.wad /some/mount/directory
To build another program using your library, we will execute this command:
$ c++ -o program_name sourcefile.cpp -L ./libWad -lWad
Helpful Links
You may find the following resources helpful when reading about how to implement a FUSE daemon:
https://www.cs.nmsu.edu/~pfeiffer/fuse-tutorial/html/
https://engineering.facile.it/blog/eng/write-filesystem-fuse/
https://maastaar.net/fuse/linux/filesystem/c/2019/09/28/writing-less-simple-yet-stupid-filesystem-using-FUSE-in-C/
https://www.cs.hmc.edu/~geoff/classes/hmc.cs137.201601/homework/fuse/fuse_doc.html
http://slade.mancubus.net/index.php?page=about
Screencast
In addition to the written text report, you should submit a screencast (with audio) walking through your library
and the daemon you wrote to provide the filesystem interface, describing your primary functions and
structures (~5:30).
Compressed Archive (wad.tar.gz)
Your compressed tar file should have the following directory/file structure:
wad.tar.gz
wad.tar
libWad (directory)
Makefile
Wad.h
(Various source files)
wadfs (directory)
Makefile
(Various source files) 

請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp
















 

標(biāo)簽:

掃一掃在手機(jī)打開當(dāng)前頁
  • 上一篇:代寫EECS 493、代做Java設(shè)計編程
  • 下一篇:代做EECE 6083、c/c++設(shè)計程序代寫
  • 無相關(guān)信息
    昆明生活資訊

    昆明圖文信息
    蝴蝶泉(4A)-大理旅游
    蝴蝶泉(4A)-大理旅游
    油炸竹蟲
    油炸竹蟲
    酸筍煮魚(雞)
    酸筍煮魚(雞)
    竹筒飯
    竹筒飯
    香茅草烤魚
    香茅草烤魚
    檸檬烤魚
    檸檬烤魚
    昆明西山國家級風(fēng)景名勝區(qū)
    昆明西山國家級風(fēng)景名勝區(qū)
    昆明旅游索道攻略
    昆明旅游索道攻略
  • NBA直播 短信驗證碼平臺 幣安官網(wǎng)下載 歐冠直播 WPS下載

    關(guān)于我們 | 打賞支持 | 廣告服務(wù) | 聯(lián)系我們 | 網(wǎng)站地圖 | 免責(zé)聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 kmw.cc Inc. All Rights Reserved. 昆明網(wǎng) 版權(quán)所有
    ICP備06013414號-3 公安備 42010502001045

    狠狠综合久久久久综合网址-a毛片网站-欧美啊v在线观看-中文字幕久久熟女人妻av免费-无码av一区二区三区不卡-亚洲综合av色婷婷五月蜜臀-夜夜操天天摸-a级在线免费观看-三上悠亚91-国产丰满乱子伦无码专区-视频一区中文字幕-黑人大战欲求不满人妻-精品亚洲国产成人蜜臀av-男人你懂得-97超碰人人爽-五月丁香六月综合缴情在线
  • <dl id="akume"></dl>
  • <noscript id="akume"><object id="akume"></object></noscript>
  • <nav id="akume"><dl id="akume"></dl></nav>
  • <rt id="akume"></rt>
    <dl id="akume"><acronym id="akume"></acronym></dl><dl id="akume"><xmp id="akume"></xmp></dl>
    蜜臀av.com| 自拍偷拍一区二区三区四区| 日韩在线一区视频| 成人午夜视频免费在线观看| 国产91视频一区| 在线观看日本www| 制服丝袜综合网| 成人在线观看黄| 成人中文字幕在线播放| 欧美乱做爰xxxⅹ久久久| 午夜xxxxx| 手机在线国产视频| 婷婷激情5月天| 少妇一级淫免费播放 | 成年人视频网站免费观看| 日本人妻伦在线中文字幕| 日韩欧美中文在线视频| 特级黄色片视频| 懂色av粉嫩av蜜臀av| 特黄特黄一级片| 日韩高清在线一区二区| 91精品视频国产| 欧美三级午夜理伦三级老人| 久久精品国产99久久99久久久| 天天干天天综合| 中文字幕一区二区三区四| 四虎1515hh.com| 91国在线高清视频| 欧美图片激情小说| 欧美色图另类小说| 国产超碰在线播放| 成人日韩在线视频| 国产精品jizz在线观看老狼| 国内精品国产三级国产aⅴ久| 男女啪啪的视频| 黄色一级片在线看| 无码人妻丰满熟妇区毛片| 亚洲另类第一页| 9l视频自拍9l视频自拍| 女人被男人躁得好爽免费视频| 人人妻人人做人人爽| 动漫av免费观看| 亚洲欧美日韩三级| 成人在线免费观看网址| 99精品在线免费视频| 国产av人人夜夜澡人人爽| 在线播放免费视频| 成人毛片一区二区| 亚洲精品怡红院| 米仓穗香在线观看| 可以免费在线看黄的网站| 爱豆国产剧免费观看大全剧苏畅| 国产又粗又猛又爽又黄的网站| 99色精品视频| 交换做爰国语对白| 国产精品秘入口18禁麻豆免会员 | 国产野外作爱视频播放| 亚洲免费在线播放视频| 欧美日韩精品在线一区二区| 午夜免费高清视频| 久草视频这里只有精品| 少妇一级淫免费播放| av免费看网址| 亚洲综合123| 久久综合久久色| 狠狠干视频网站| 国产又黄又猛又粗| 欧美视频免费看欧美视频| 久久国产激情视频| 农村妇女精品一二区| 黄色特一级视频| 久久久久久久久久毛片| 少妇人妻互换不带套| 香港三级日本三级a视频| 超碰在线公开97| 日韩av在线综合| 久久久亚洲国产精品| 1314成人网| caoporm在线视频| 亚洲精品一二三四五区| 9久久9毛片又大又硬又粗| 300部国产真实乱| 粉色视频免费看| 日本爱爱免费视频| 欧美国产亚洲一区| 成人午夜视频在线观看免费| 男女啪啪免费观看| 三年中文高清在线观看第6集| www.涩涩涩| 美女黄色片视频| www黄色在线| 99视频精品免费| 欧美成人精品欧美一级乱| 奇米精品一区二区三区| 夜夜添无码一区二区三区| 毛片在线视频观看| 国产人妻人伦精品| 青青青在线观看视频| 波多野结衣网页| 天堂av免费看| 久久人妻无码一区二区| 日韩专区第三页| 欧美中文字幕在线观看视频| 99久久久精品视频| 99久久免费观看| 日本a视频在线观看| 中文字幕无码精品亚洲资源网久久| 国产激情在线看| 欧洲精品一区二区三区久久| 免费超爽大片黄| 免费在线观看毛片网站| 亚洲第一中文av| 色网站在线视频| a级片一区二区| 91国视频在线| 久久久精品麻豆| 日韩a一级欧美一级| 大桥未久一区二区| 日韩视频免费播放| 无码无遮挡又大又爽又黄的视频| 毛葺葺老太做受视频| 男人添女人下面免费视频| 天天操狠狠操夜夜操| 四虎4hu永久免费入口| 欧美午夜小视频| 91插插插插插插插插| 国产成人生活片| av动漫免费看| 日韩av影视大全| 国产人妻777人伦精品hd| 免费看a级黄色片| 熟妇熟女乱妇乱女网站| 免费高清在线观看免费| 日本成人xxx| 亚洲色成人一区二区三区小说| 日本xxxx黄色| 国产爆乳无码一区二区麻豆| 爱情岛论坛vip永久入口| 中文字幕色呦呦| 色婷婷综合久久久久中文字幕| 日本一二三区在线| 国产成人无码一二三区视频| 天天干天天操天天干天天操| 欧美日韩在线视频一区二区三区| 久久久久久综合网| 国产黄页在线观看| 国产av不卡一区二区| 日韩在线第三页| 18黄暴禁片在线观看| 亚洲高清免费在线观看| 波多野结衣家庭教师在线播放| 911av视频| 欧美精品成人网| av无码久久久久久不卡网站| 男生操女生视频在线观看| 久久成人免费观看| 欧美少妇一区二区三区| 潘金莲激情呻吟欲求不满视频| 大肉大捧一进一出好爽视频| 男人草女人视频| 午夜xxxxx| 亚洲精品手机在线观看| 黄色国产精品视频| 久久99久久99精品| 黄色片免费网址| 日本不卡一区二区在线观看| 日本999视频| 中文字幕乱码人妻综合二区三区 | 日韩中文字幕组| 熟女少妇在线视频播放| 少妇一晚三次一区二区三区| 午夜视频在线网站| 亚洲一级免费在线观看| 无码人妻丰满熟妇区毛片| 日本wwww视频| 国产精品无码人妻一区二区在线| 欧美 国产 精品| 亚洲色婷婷久久精品av蜜桃| 天堂v在线视频| 欧美性受xxxx黒人xyx性爽| 国产欧美一区二| 日日夜夜精品视频免费观看 | 久久国产午夜精品理论片最新版本| 手机看片日韩国产| 国产免费一区二区三区四在线播放| 天堂在线中文在线| 国产高清999| 三年中文高清在线观看第6集| 日日噜噜噜夜夜爽爽| 国产精品88久久久久久妇女| 国产免费内射又粗又爽密桃视频| 四虎永久免费网站| 久久99久久久久久| 欧美成人xxxxx| 无码日韩人妻精品久久蜜桃| 超碰在线97免费| 成人免费黄色av| 肉大捧一出免费观看网站在线播放 | 中文字幕66页| 国产免费xxx|