a

原创 2006年05月18日 20:04:00

// 解码后的长度一般比原文少用占1/4的存储空间,请保证buf有足够的空间
inline int Base64Decode(char * buf, const char * base64code, int src_len)
{

 if (src_len == 0)
  src_len = strlen(base64code);

 int len = 0;
 unsigned char* psrc = (unsigned char*)base64code;
 char * pbuf = buf;

 unsigned long ulTmp = 0;

 for (int j = 0; j < src_len - 4; ++j)
 {
  *(((unsigned char*)&ulTmp) + j) = *psrc++;
 }
 for (int i = 0; i < src_len - 4; i += 4)
 {
  //unsigned long ulTmp = (unsigned long )psrc;

  //*((unsigned char*)&ulTmp + 3) = *psrc++;
  register int b0 = (GetB64Index((char)B0(ulTmp)) << 2 | GetB64Index((char)B1(ulTmp)) << 2 >> 6) & 0xFF;
  *pbuf++ = b0 ;
  len ++;

  //*((unsigned char*)&ulTmp + 2) = *psrc++ ;
  register int b1 = (GetB64Index((char)B1(ulTmp)) << 4 | GetB64Index((char)B2(ulTmp)) << 2 >> 4) & 0xFF;
  *pbuf++ = b1;
  len ++;

  //*((unsigned char*)&ulTmp + 1) = *psrc++ ;
  register int b2 = (GetB64Index((char)B2(ulTmp)) << 6 | GetB64Index((char)B3(ulTmp)) << 2 >> 2) & 0xFF;
  *pbuf++ = b2;
  len ++;
  //*((unsigned char*)&ulTmp + 3) = *psrc++ ;
 }

 // 处理最后余下的不足4字节的饿数据
 if (i < src_len)
 {
  int rest = src_len - i;
  unsigned long ulTmp = 0;
  for (int j = 0; j < rest; ++j)
  {
   *(((unsigned char*)&ulTmp) + j) = *psrc++;
  }
 
  register int b0 = (GetB64Index((char)B0(ulTmp)) << 2 | GetB64Index((char)B1(ulTmp)) << 2 >> 6) & 0xFF;
  *pbuf++ = b0;
  len  ++;
 
  if ('=' != B1(ulTmp) && '=' != B2(ulTmp))
  {
   register int b1 = (GetB64Index((char)B1(ulTmp)) << 4 | GetB64Index((char)B2(ulTmp)) << 2 >> 4) & 0xFF;
   *pbuf++ = b1;
   len  ++;
  }
  
  if ('=' != B2(ulTmp) && '=' != B3(ulTmp))
  {
   register int b2 = (GetB64Index((char)B2(ulTmp)) << 6 | GetB64Index((char)B3(ulTmp)) << 2 >> 2) & 0xFF;
   *pbuf++ = b2;
   len  ++;
  }

 }
  
 *pbuf = '/0';
 
 return len;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

uboot 命令分析(一) — bootm

bootm 用于将内核镜像加载到内存的指定地址处,如果有需要还要解压镜像,然后根据操作系统和体系结构的不同给内核传递不同的启动参数,最后启动内核。 一、arm 架构处理器对 linux 内核启动之前...

bootm引导内核过程详解之一-cmd_bootm

//文件名:u-boot-1.3.1/common/cmd_bootm.c//bootm引导内核过程详解之一-cmd_bootm//Thomas.Yang 2010.05.25 /*do_bootm(...

我对mkimage工具的掌握

uboot工具mkimage的功能:制作不压缩或者压缩的多种可启动映象文件。据说,使用bootm命令加载的内核和根文件系统都是要使用这个工具加上个头, 记录参数所指定的信息,因此uboot能识别这个...

do_bootm 分析

ChinaUnix.net 首页 | 论坛 | 博客 | Linux | 人才 | 培训 | 精华 | Wiki | 读书 | 资料 | 手册 | 下载...

bootm命令中地址参数,内核加载地址以及内核入口地址

bootm命令只能用来引导经过mkimage构建了镜像头的内核镜像文件以及根文件镜像,对于没有用mkimage对内核进行处理的话,那直接把内核下载到连接脚本中指定的加载地址0x30008000再运行就...

uboot终极目标:启动内核

uboot总的启动linux内核的流程:启动文件start.S基本软硬件初始化好之后,调用arm_lib/board.c下的startarm_boot()函数,这个函数最终调用main_loop()函...

do_bootm()函数个人注释

int do_bootm (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) { ulong iflag; ulong addr; ulon...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)