summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYuichiro MASUI <[email protected]>2013-03-08 07:55:54 -0800
committerYuichiro MASUI <[email protected]>2013-03-08 07:55:54 -0800
commit974febd315a6520184f95cb50a7c2b46e4582002 (patch)
tree45468abc1e663bf841dff67cfb819ed0d5e6b475 /src
parentd1a4958bfc9685a41379557a752ebf901ebe419d (diff)
parent065494887d92c085a78ca3624e26659acc2bfdfc (diff)
downloadmruby-974febd315a6520184f95cb50a7c2b46e4582002.tar.gz
mruby-974febd315a6520184f95cb50a7c2b46e4582002.zip
Merge pull request #1 from monaka/pr-new-mrb_format
Patches to new_mrb_format
Diffstat (limited to 'src')
-rw-r--r--src/codegen.c2
-rw-r--r--src/crc.c5
-rw-r--r--src/dump.c40
-rw-r--r--src/load.c67
4 files changed, 72 insertions, 42 deletions
diff --git a/src/codegen.c b/src/codegen.c
index 33df7fbf5..d71c0bbd2 100644
--- a/src/codegen.c
+++ b/src/codegen.c
@@ -2409,7 +2409,7 @@ codedump(mrb_state *mrb, int n)
if (!irep) return;
printf("irep %d nregs=%d nlocals=%d pools=%d syms=%d\n", n,
- irep->nregs, irep->nlocals, irep->plen, irep->slen);
+ irep->nregs, irep->nlocals, (int)irep->plen, (int)irep->slen);
for (i=0; i<irep->ilen; i++) {
ai = mrb_gc_arena_save(mrb);
printf("%03d ", i);
diff --git a/src/crc.c b/src/crc.c
index 70fa60dfb..db852f6cb 100644
--- a/src/crc.c
+++ b/src/crc.c
@@ -18,9 +18,10 @@
#define CRC_CARRY_BIT (1 << 24)
uint16_t
-calc_crc_16_ccitt(const uint8_t *src, uint32_t nbytes, uint16_t crc)
+calc_crc_16_ccitt(const uint8_t *src, size_t nbytes, uint16_t crc)
{
- uint32_t ibyte, ibit;
+ size_t ibyte;
+ uint32_t ibit;
uint32_t crcwk = crc << 8;
for (ibyte = 0; ibyte < nbytes; ibyte++) {
diff --git a/src/dump.c b/src/dump.c
index bf5a9b6f4..fb5bb5e7c 100644
--- a/src/dump.c
+++ b/src/dump.c
@@ -53,7 +53,7 @@ static int
write_iseq_block(mrb_state *mrb, mrb_irep *irep, uint8_t *buf)
{
uint8_t *cur = buf;
- int iseq_no;
+ size_t iseq_no;
cur += uint32_to_bin(irep->ilen, cur); /* number of opcode */
for (iseq_no = 0; iseq_no < irep->ilen; iseq_no++) {
@@ -68,7 +68,8 @@ static size_t
get_pool_block_size(mrb_state *mrb, mrb_irep *irep)
{
size_t size = 0;
- int pool_no, len;
+ size_t pool_no;
+ int len;
mrb_value str;
char buf[32];
@@ -103,7 +104,8 @@ get_pool_block_size(mrb_state *mrb, mrb_irep *irep)
static int
write_pool_block(mrb_state *mrb, mrb_irep *irep, uint8_t *buf)
{
- int result, pool_no;
+ int result;
+ size_t pool_no;
uint8_t *cur = buf;
size_t buf_size, len;
mrb_value str;
@@ -169,7 +171,8 @@ static size_t
get_syms_block_size(mrb_state *mrb, mrb_irep *irep)
{
size_t size = 0;
- int sym_no, len;
+ size_t sym_no;
+ int len;
size += sizeof(uint32_t); /* slen */
for (sym_no = 0; sym_no < irep->slen; sym_no++) {
@@ -186,7 +189,9 @@ get_syms_block_size(mrb_state *mrb, mrb_irep *irep)
static int
write_syms_block(mrb_state *mrb, mrb_irep *irep, uint8_t *buf)
{
- int result, sym_no, len, buf_size;
+ int result, len;
+ size_t sym_no;
+ size_t buf_size;
uint8_t *cur = buf;
uint16_t nlen;
char *char_buf = NULL;
@@ -298,13 +303,14 @@ mrb_write_section_irep_header(mrb_state *mrb, uint32_t section_size, uint16_t ni
}
static int
-mrb_write_section_irep(mrb_state *mrb, int start_index, uint8_t *bin)
+mrb_write_section_irep(mrb_state *mrb, size_t start_index, uint8_t *bin)
{
- int result, irep_no;
+ int result;
+ size_t irep_no;
uint32_t section_size = 0, rlen = 0; /* size of irep record */
uint8_t *cur = bin;
- if (mrb == NULL || start_index < 0 || start_index >= mrb->irep_len || bin == NULL) {
+ if (mrb == NULL || start_index >= mrb->irep_len || bin == NULL) {
return MRB_DUMP_INVALID_ARGUMENT;
}
@@ -326,7 +332,7 @@ mrb_write_section_irep(mrb_state *mrb, int start_index, uint8_t *bin)
}
static int
-write_rite_binary_header(mrb_state *mrb, uint32_t binary_size, uint8_t* bin)
+write_rite_binary_header(mrb_state *mrb, size_t binary_size, uint8_t* bin)
{
struct rite_binary_header *header = (struct rite_binary_header*)bin;
uint16_t crc;
@@ -346,12 +352,14 @@ write_rite_binary_header(mrb_state *mrb, uint32_t binary_size, uint8_t* bin)
}
static int
-mrb_dump_irep(mrb_state *mrb, int start_index, uint8_t **bin, uint32_t *bin_size)
+mrb_dump_irep(mrb_state *mrb, size_t start_index, uint8_t **bin, size_t *bin_size)
{
- int result = MRB_DUMP_OK, irep_no, section_irep_size;
+ int result;
+ size_t section_irep_size;
+ size_t irep_no;
uint8_t *cur = NULL;
- if (mrb == NULL || start_index < 0 || start_index >= mrb->irep_len) {
+ if (mrb == NULL || start_index >= mrb->irep_len) {
*bin = NULL;
goto error_exit;
}
@@ -391,10 +399,10 @@ error_exit:
#ifdef ENABLE_STDIO
int
-mrb_dump_irep_binary(mrb_state *mrb, int start_index, FILE* fp)
+mrb_dump_irep_binary(mrb_state *mrb, size_t start_index, FILE* fp)
{
uint8_t *bin = NULL;
- uint32_t bin_size = 0;
+ size_t bin_size = 0;
int result;
if (fp == NULL) {
@@ -411,10 +419,10 @@ mrb_dump_irep_binary(mrb_state *mrb, int start_index, FILE* fp)
}
int
-mrb_dump_irep_cfunc(mrb_state *mrb, int start_index, FILE *fp, const char *initname)
+mrb_dump_irep_cfunc(mrb_state *mrb, size_t start_index, FILE *fp, const char *initname)
{
uint8_t *bin = NULL;
- uint32_t bin_size = 0, bin_idx = 0;
+ size_t bin_size = 0, bin_idx = 0;
int result;
if (fp == NULL || initname == NULL) {
diff --git a/src/load.c b/src/load.c
index 30a987492..92799eb49 100644
--- a/src/load.c
+++ b/src/load.c
@@ -12,23 +12,30 @@
#include "mruby/irep.h"
+#ifndef _WIN32
+# if SIZE_MAX < UINT32_MAX
+# error "It can't be run this code on this environment (SIZE_MAX < UINT32_MAX)"
+# endif
+#endif
+
static size_t
offset_crc_body()
{
struct rite_binary_header header;
- return ((void*)header.binary_crc - (void*)&header) + sizeof(header.binary_crc);
+ return ((char *)header.binary_crc - (char *)&header) + sizeof(header.binary_crc);
}
static int
read_rite_irep_record(mrb_state *mrb, const uint8_t *bin, uint32_t *len)
{
- int i, ret = MRB_DUMP_OK;
+ int ret;
+ size_t i;
char *char_buf;
const uint8_t *src = bin;
uint16_t tt, pool_data_len, snl, buf_size = MRB_DUMP_DEFAULT_STR_LEN;
mrb_int fix_num;
mrb_float f;
- int plen;
+ size_t plen;
int ai = mrb_gc_arena_save(mrb);
mrb_irep *irep = mrb_add_irep(mrb);
@@ -155,6 +162,7 @@ read_rite_irep_record(mrb_state *mrb, const uint8_t *bin, uint32_t *len)
}
*len = src - bin;
+ ret = MRB_DUMP_OK;
error_exit:
mrb_free(mrb, char_buf);
return ret;
@@ -163,9 +171,12 @@ error_exit:
static int
read_rite_section_irep(mrb_state *mrb, const uint8_t *bin)
{
- int n, i, result = MRB_DUMP_OK;
- uint32_t len, sirep;
+ int result;
+ size_t sirep;
+ size_t i;
+ uint32_t len;
uint16_t nirep;
+ uint16_t n;
const struct rite_section_irep_header *header;
header = (const struct rite_section_irep_header*)bin;
@@ -182,9 +193,10 @@ read_rite_section_irep(mrb_state *mrb, const uint8_t *bin)
bin += len;
}
+ result = MRB_DUMP_OK;
error_exit:
if (result != MRB_DUMP_OK) {
- for (n = 0, i = sirep; i < mrb->irep_len; n++, i++) {
+ for (i = sirep; i < mrb->irep_len; i++) {
if (mrb->irep[i]) {
if (mrb->irep[i]->iseq)
mrb_free(mrb, mrb->irep[i]->iseq);
@@ -204,7 +216,7 @@ error_exit:
}
static int
-read_rite_binary_header(const uint8_t *bin, uint32_t *bin_size, uint16_t *crc)
+read_rite_binary_header(const uint8_t *bin, size_t *bin_size, uint16_t *crc)
{
const struct rite_binary_header *header = (const struct rite_binary_header *)bin;
@@ -217,18 +229,22 @@ read_rite_binary_header(const uint8_t *bin, uint32_t *bin_size, uint16_t *crc)
}
*crc = bin_to_uint16(header->binary_crc);
- *bin_size = bin_to_uint32(header->binary_size);
+ if (bin_size) {
+ *bin_size = bin_to_uint32(header->binary_size);
+ }
return MRB_DUMP_OK;
}
-int
+int32_t
mrb_read_irep(mrb_state *mrb, const uint8_t *bin)
{
- int total_nirep = 0, result = MRB_DUMP_OK;
+ int result;
+ int32_t total_nirep = 0;
const struct rite_section_header *section_header;
uint16_t crc;
- uint32_t bin_size = 0, n;
+ size_t bin_size = 0;
+ size_t n;
if ((mrb == NULL) || (bin == NULL)) {
return MRB_DUMP_INVALID_ARGUMENT;
@@ -270,7 +286,7 @@ irep_error(mrb_state *mrb, const char *msg)
mrb_value
mrb_load_irep(mrb_state *mrb, const uint8_t *bin)
{
- int n;
+ int32_t n;
n = mrb_read_irep(mrb, bin);
if (n < 0) {
@@ -282,14 +298,17 @@ mrb_load_irep(mrb_state *mrb, const uint8_t *bin)
#ifdef ENABLE_STDIO
-static int
+static int32_t
read_rite_section_irep_file(mrb_state *mrb, FILE *fp)
{
- int n, i, result = MRB_DUMP_OK;
- uint16_t sirep, nirep;
+ int32_t result;
+ size_t sirep;
+ size_t i;
+ uint16_t nirep;
+ uint16_t n;
uint32_t len, buf_size;
uint8_t *buf = NULL;
- const int record_header_size = 1 + 4;
+ const size_t record_header_size = 1 + 4;
struct rite_section_irep_header header;
fread(&header, sizeof(struct rite_section_irep_header), 1, fp);
@@ -311,10 +330,11 @@ read_rite_section_irep_file(mrb_state *mrb, FILE *fp)
goto error_exit;
}
+ result = MRB_DUMP_OK;
error_exit:
mrb_free(mrb, buf);
if (result != MRB_DUMP_OK) {
- for (n = 0, i = sirep; i < mrb->irep_len; n++, i++) {
+ for (i = sirep; i < mrb->irep_len; i++) {
if (mrb->irep[i]) {
if (mrb->irep[i]->iseq)
mrb_free(mrb, mrb->irep[i]->iseq);
@@ -333,26 +353,27 @@ error_exit:
return sirep + bin_to_uint16(header.sirep);
}
-int
+int32_t
mrb_read_irep_file(mrb_state *mrb, FILE* fp)
{
- int total_nirep = 0, result = MRB_DUMP_OK;
+ int result;
+ int32_t total_nirep = 0;
uint8_t *buf;
uint16_t crc, crcwk = 0;
- uint32_t bin_size = 0, buf_size = 0, section_size = 0;
+ uint32_t section_size = 0;
size_t nbytes;
struct rite_section_header section_header;
long fpos;
const size_t block_size = 1 << 14;
+ const size_t buf_size = sizeof(struct rite_binary_header);
if ((mrb == NULL) || (fp == NULL)) {
return MRB_DUMP_INVALID_ARGUMENT;
}
- buf_size = sizeof(struct rite_binary_header);
buf = mrb_malloc(mrb, buf_size);
- fread(buf, sizeof(struct rite_binary_header), 1, fp);
- result = read_rite_binary_header(buf, &bin_size, &crc);
+ fread(buf, buf_size, 1, fp);
+ result = read_rite_binary_header(buf, NULL, &crc);
mrb_free(mrb, buf);
if(result != MRB_DUMP_OK) {
return result;