/*
 *    linux/zBoot/piggyback.c
 *
 *    (C) 1993 Hannu Savolainen
 */

/*
 *    This program reads the compressed system image from stdin and
 *    encapsulates it into an object file written to the stdout.
 */
//这个程序读取压缩的system映像文件从标准输入然后压缩后写入标准输出
#include <stdio.h>
#include <unistd.h>
#include <a.out.h>

//主函数
int main(int argc, char *argv[])
{
    int c, n=0, len=0;
    //定义缓冲区
    char tmp_buf[512*1024];
    
    //可执行文件头
    struct exec obj = {0x00640107};    /* object header */
    //输入的数据和输入的长度
    char string_names[] = {"_input_data\0_input_len\0"};

//标号表,变量名
    struct nlist var_names[2] = /* Symbol table */
        {    
            {    /* _input_data    */
                (char *)4, 7, 0, 0, 0
            },
            {    /* _input_len */
                (char *)16, 7, 0, 0, 0
            }
        };

len = 0;
    //从标准输入中读取数据到缓冲区
    while ((n = read(0, &tmp_buf[len], sizeof(tmp_buf)-len+1)) > 0)
          len += n;

//校验读取的长度
    if (n==-1)
    {
        perror("stdin");
        exit(-1);
    }

if (len >= sizeof(tmp_buf))
    {
        fprintf(stderr, "%s: Input too large\n", argv[0]);
        exit(-1);
    }

//输出长度信息
    fprintf(stderr, "Compressed size %d.\n", len);

/*
 *    Output object header
 */
    //输出对象头
    obj.a_data = len + sizeof(long);
    obj.a_syms = sizeof(var_names);
    write(1, (char *)&obj, sizeof(obj));

/*
 *    Output data segment (compressed system & len)
 */
    //输出数据段
    write(1, tmp_buf, len);
    write(1, (char *)&len, sizeof(len));

/*
 *    Output symbol table
 */
    //输出符号表
    var_names[1].n_value = len;
    write(1, (char *)&var_names, sizeof(var_names));

/*
 *    Output string table
 */
    //输出字符表
    len = sizeof(string_names) + sizeof(len);
    write(1, (char *)&len, sizeof(len));
    write(1, string_names, sizeof(string_names));

exit(0);

}

zboot/piggyback.c的更多相关文章

  1. zboot/xtract.c

    /* *  linux/zBoot/xtract.c * *  Copyright (C) 1993  Hannu Savolainen * *    Extracts the system imag ...

  2. zBoot/Makefile

    #上层makefile调用执行make命令,执行的应该是第一个目标allHEAD = head.oSYSTEM = ../tools/zSystem#LD = gcc#TEST = -DTEST_DR ...

  3. (寒假集训) Piggyback(最短路)

    Piggyback 时间限制: 1 Sec  内存限制: 64 MB提交: 3  解决: 3[提交][状态][讨论版] 题目描述 Bessie and her sister Elsie graze i ...

  4. WebSocket - ( 一.概述 )

    说到 WebSocket,不得不提 HTML5,作为近年来Web技术领域最大的改进与变化,包含CSS3.离线与存储.多媒体.连接性( Connectivity )等一系列领域,而即将介绍的 WebSo ...

  5. 【DWR系列02】-DWR逆向Ajax即服务器推送

    .literal { background-color: #f2f2f2; border: 1px solid #cccccc; padding: 1px 3px 0; white-space: no ...

  6. USACO翻译:USACO 2014 DEC Silver三题

    USACO 2014 DEC SILVER 一.题目概览 中文题目名称 回程 马拉松 奶牛慢跑 英文题目名称 piggyback marathon cowjog 可执行文件名 piggyback ma ...

  7. TCP协议

    TCP是一个面向连接的协议,在发送数据之前,必须在双方之间建立一条连接. TCP首部 TCP数据封装在IP数据报中 TCP包首部 下面简单说明部分字段的作用: 端口号:通讯双方由IP地址和端口号标识. ...

  8. 反向Ajax,实现服务器向客户端推送消息

    反向Ajax的基本概念是客户端不必从服务器获取信息,服务器会把相关信息直接推送到客户端.这样做的目的是解决Ajax传统Web模型所带来的一个限制:实时信息很难从技术上解决.原因是,客户端必须联系服务器 ...

  9. DWR的Reverse Ajax技术实现

    DWR的逆向ajax其实主要包括两种模式:主动模式和被动模式.其中主动模式包括Polling和Comet两种,被动模式只有Piggyback这一种. 所谓的Piggyback指的是如果后台有什么内容需 ...

随机推荐

  1. Ubuntu14.10+cuda7.0+caffe配置

    转自:http://blog.csdn.net/lu597203933/article/details/46742199 Ubuntu14.10+cuda7.0+caffe配置 一:linux安装 L ...

  2. 酷狗音乐盒缓存文件夹KuGouCache的设置方法

    1.每次一打开酷狗总能在E盘里找到这个 KuGouCache 文件夹 ,是自动生成的MV缓存文件 .按照常规 ,可以修改这个文件的办法是 找到C盘里的:用户\administrator\AppDate ...

  3. OCR技术

    "起初我写这篇教程是在情人节,OCR可以带给你一整年的爱". 你之前肯定已经见过,OCR技术被应用于在平板电脑上将扫描文件处理成手写字迹,还被应用于谷歌最近添加到他们的Transl ...

  4. SSH(2)-- ssh_config和sshd_config

    假定服务器ip为192.168.1.139,ssh服务的端口号为22,服务器上有个用户为pi,两边都是ubuntu. ssh_config和sshd_config都是ssh服务器的配置文件,二者区别在 ...

  5. MATLAB axes

    本帖由MATLAB技术论坛(http://www.matlabsky.com)原创,更多精彩内容参见http://www.matlabsky.com axes ★★★★★ 功能 创建坐标系图形对象 语 ...

  6. hashmap和hashtable,arraylist和vector的区别

    hashmap线程不安全,hashtable线程安全 hashmap允许使用 null 值和 null 键.(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同. ...

  7. System.Web.HttpRequestBase转HttpWebRequest

    /// <summary> /// Copies all headers and content (except the URL) from an incoming to an outgo ...

  8. MongoDB MapReduce(转)

    MapReduce MapReduce是一种计算模型,简单的说就是将大批量的工作(数据)分解(MAP)执行,然后再将结果合并成最终结果(REDUCE).这样做的好处是可以在任务被分解后,可以通过大量机 ...

  9. mine layer(2008 World Final C)

    类似于扫雷游戏,在一些格子中散布着一些地雷,具体的埋藏位置并不清楚,但知道每个格子及其周围八个格子的地雷总数.请问此时正中间那一行最多可能有多少地雷(题目假定所有的输入都是奇数行的)? 输入: 第一行 ...

  10. stm32启动文件 startup_stm32f10x_hd.s

    ;* 文件名          : startup_stm32f10x_hd.s;* 库版本           : V3.5.0;* 说明:             此文件为STM32F10x高密度 ...