Linux系统getopt使用示例
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <stdint.h> void usage()
{
fprintf(stderr,
"\nUsage: mcu_dload [OPTIONS] *.bin\n"
" -a Specify device I2C slave address(7Bit), eg: -a 5E, default is 0x58\n"
" -d Download binary code for MCU only\n"
" -h This Page.\n\n"
);
exit();
} uint8_t asc2hex(char asccode)
{
uint8_t ret;
if('' <= asccode && asccode <= '')
ret = asccode - '';
else if('a' <= asccode && asccode <= 'f')
ret = asccode -'a' + ;
else if('A' <= asccode && asccode <= 'F')
ret = asccode - 'A' + ;
else ret = ;
return ret;
} int main(int argc, char **argv)
{
int opt;
uint32_t i = ;
uint8_t i2c_adr = 0x58, i2c_reg;
FILE *fp; // Parse Command Line Options
while((opt = getopt(argc, argv, "a:h?")) != EOF) {
switch(opt) {
case 'a':
i2c_adr = (asc2hex(optarg[]) << ) | asc2hex(optarg[]);
printf("I2C Device Address(7Bit) is 0x%2X.\n", i2c_adr);
break;
case 'h':
case '?':
default:
usage();
break;
}
} // Last One is the input file
if(optind + != argc) {
printf("Input file not found!\n");
usage();
exit();
} // Open *.bin file and download it to MCU
fp = fopen(argv[optind], "r");
if(fp == NULL) {
printf("Input file can not open!\n");
usage();
exit();
} // Get file size
fseek(fp, 0L, SEEK_SET);
fseek(fp, 0L, SEEK_END);
uint32_t binsize = ftell(fp);
printf("Inpuf file size is %d Bytes.\n", binsize); uint8_t *bincode = (uint8_t *)malloc(binsize);
fseek(fp, 0L, SEEK_SET);
fread(bincode, 1L, binsize, fp);
fclose(fp); // Download
printf("Reset MCU ...\n");
printf("Dowloading bin ...\n"); uint32_t dpos = binsize >> ;
for(i = ; i < binsize; ++i) {
if(i % dpos == ) printf("#");
usleep();
//CH341WriteI2C(0, i2c_adr, i2c_reg, bincode[i]);
fflush(stdout);
}
printf("\nFile download succeed, %d Bytes transfered!\n", binsize); free(bincode);
return ;
}
Linux系统getopt使用示例的更多相关文章
- Linux系统常用命令示例
1.在跟下创建一个目录,目录的名字为data # mkdir /data2.在data目录里创建一个文件,文件名为yunjisuan.txt # touch /data/yunjisuan.txt3. ...
- Linux 系统安全相关
本篇关于Linux的一些安全知识,主要就是与账号相关的安全. 账户文件锁定 当服务器中的用户账号已经固定,不在进行更改,可锁定账户文件.锁定后,无法添加.删除账号,也无法更改密码等. 锁定账户文件 c ...
- Linux实战教学笔记06:Linux系统基础优化
第六节 Linux系统基础优化 标签(空格分隔):Linux实战教学笔记-陈思齐 第1章 基础环境 第2章 使用网易163镜像做yum源 默认国外的yum源速度很慢,所以换成国内的. 第一步:先备份 ...
- 探索 Linux 系统的启动过程
引言 之所以想到写这些东西,那是因为我确实想让大家也和我一样,把 Linux 桌面系统打造成真真正正日常使用的工具,而不是安装之后试用几把再删掉.我是真的在日常生活和工作中都使用 Linux,比如在 ...
- 如何重置硬盘遭到“损坏”的Linux系统root用户密码
传统印象下Linux是非常坚不可摧的,具有千年不更新,万年不重启的美名.而随着虚拟化的推进,很多跑在虚拟化上的Linux由于先前基础架构的脆弱,变得适应性“越来越不好”,体现在IP存储如果出现节点故障 ...
- Linux系统编程:基本I/O系统调用
文件描述符 进程每打开一个文件的时候,会获得该文件的文件描述符,而后续的读写操作都把文件描述符作为参数.在用户空间或者内核空间,都是通过文件描述符来唯一地索引一个打开的文件.文件描述符使用int类型表 ...
- Linux系统硬链接和软链接介绍
1.链接的概念 在Linux系统中链接分为硬链接和软连接两种,一种为硬链接,另一种为软连接或符号链接(symbolic Link).ln命令就是创建链接文件的,在默认不带参数的情况下,执行ln命令创建 ...
- Linux 系统中僵尸进程
Linux 系统中僵尸进程和现实中僵尸(虽然我也没见过)类似,虽然已经死了,但是由于没人给它们收尸,还能四处走动.僵尸进程指的是那些虽然已经终止的进程,但仍然保留一些信息,等待其父进程为其收尸.配图源 ...
- Linux系统1.md
计算机 介绍 电子计算机(英语:computer),亦称电脑,是一种利用电子学原理,根据一系列指令对数据进行处理的工具. 在现代,机械计算机的应用已经完全被电子计算机所替换,其所相关的技术研究叫计算机 ...
随机推荐
- sed实践
后来也找到一篇文章讲的很详细: http://www.cnblogs.com/ctaixw/p/5860221.html --------------------------------------- ...
- js屏蔽手机的物理返回键
$(document).ready(function() { if (window.history && window.history.pushState) { $(window).o ...
- spring+atomikos+mybatis 多数据源事务(动态切换)
注:自动切换,是为不同的数据源,却要对应相同的dao层: 1.与无事务版的一样,创建DynamicDataSource类,继承AbstractRoutingDataSource package com ...
- poj1606 Jugs(BFS)
题目链接 http://poj.org/problem?id=1606 题意 有两个容量分别为ca,cb的杯子,可以向杯子里倒水,将杯子里的水倒空,将一个杯子里的水倒到另一个杯子里,求怎样倒才能使其中 ...
- Spring中@Transactional事务回滚
转载: Spring中@Transactional事务回滚 一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部 ...
- HDU 6029 Graph Theory
贪心. 每次找到后面最近的一个能连边的连边. #include <bits/stdc++.h> using namespace std; ; int T,n,k; ],b[],u[]; i ...
- Python之路【第一篇】:介绍、基本语法、流程控制
一.python 简介 python 特点 Python是一种计算机程序设计语言.你可能已经听说过很多种流行的编程语言,比如非常难学的C语言,非常流行的Java语言,适合初学者的Basic语言,适合网 ...
- 获取token
获取token 提示:openstack 这个是获取N版的方法 ,主要区别在于这个路径上(http://192.168.0.228:35357/v3/auth/tokens ),以前版本可能会是v2 ...
- C和指针之学习笔记(2)
第6章 指针 1.在一组字符串中查找字符: #include<stdio.h> #include<assert.h> #include<stdlib.h> #def ...
- [HihoCoder1169]猜单词
题目大意: 给你一个数列,问区间[l,r]内与k最接近的数与k的差是多少. 思路: 将数列中的数和询问的数先从小到大排序, 从小到大枚举每个数,如果是数列上的,就加到线段树中, 如果是询问中的,就在线 ...