函数逻辑报告 | 
Source Code:lib\842\842_compress.c | 
Create Date:2022-07-27 07:54:39 | 
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick | 
| 首页 | 函数Tree | 
| 注解内核,赢得工具 | 下载SCCT | English | 
函数名称:sw842_compress* Compress the uncompressed buffer of length @ilen at @in to the output buffer*@out, using no more than @olen bytes, using the 842 compression format
函数原型:int sw842_compress(const u8 *in, unsigned int ilen, u8 *out, unsigned int *olen, void *wmem)
返回类型:int
参数:
| 类型 | 参数 | 名称 | 
|---|---|---|
| const u8 * | in | |
| unsigned int | ilen | |
| u8 * | out | |
| unsigned int * | olen | |
| void * | wmem | 
| 483 | repeat_count等于0 | 
| 488 | init_hashtable_nodes(p, 8) | 
| 489 | init_hashtable_nodes(p, 4) | 
| 490 | init_hashtable_nodes(p, 2) | 
| 497 | bit等于0 | 
| 501 | olen等于0 | 
| 510 | 如果此条件成立可能性小(为编译器优化)(ilen < 8)则转到:skip_comp | 
| 514 | last等于get_unaligned((u64 * )in)的反 | 
| 517 | next等于get_unaligned((u64 * )in) | 
| 522 | get_next_data(p) | 
| 530 | 如果repeat_count先自加小于等于REPEAT_BITS_MAX则转到:repeat | 
| 533 | 如果repeat_count则 | 
| 540 | 如果next恒等于0则ret等于add_zeros_template(p) | 
| 542 | 否则ret等于d the next template to use, and add it* the p->dataN fields must already be set for the current 8 byte block | 
| 548 | repeat : | 
| 551 | in加等于8 | 
| 552 | ilen减等于8 | 
| 555 | 如果repeat_count则 | 
| 556 | ret等于add_repeat_template(p, repeat_count) | 
| 561 | skip_comp : | 
| 562 | 如果ilen大于0则 | 
| 571 | ret等于add_end_template(p) | 
| 587 | 如果bit则 | 
| 595 | 如果pad则 | 
| 603 | 如果此条件成立可能性小(为编译器优化)((total - olen) > UINT_MAX)则返回:负ENOSPC | 
| 608 | 返回:0 | 
| 源代码转换工具 开放的插件接口  | X | 
|---|---|
| 支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码  |