changeset 11:d8adf04b9f63

organized repository.
author kent <kent@cr.ie.u-ryukyu.ac.jp>
date Tue, 16 Feb 2010 14:40:12 +0900 (2010-02-16)
parents 3d9addf62d0b
children 0f9a0ecc6afb
files quicksort_for_ppc/Makefile quicksort_for_ppc/benchmark.sh quicksort_for_ppc/mc/Makefile quicksort_for_ppc/mc/benchmark.sh quicksort_for_ppc/mc/quicksort_cbc.cbc quicksort_for_ppc/mc/quicksort_cbc.h quicksort_for_ppc/mc/quicksort_test.cbc quicksort_for_ppc/mc/quicksort_test.h quicksort_for_ppc/quicksort_c.c quicksort_for_ppc/quicksort_cbc.cbc quicksort_for_ppc/quicksort_cbc.h quicksort_for_ppc/quicksort_cbc2.cbc quicksort_for_ppc/quicksort_cbc2.h quicksort_for_ppc/quicksort_cbc_inter.cbc quicksort_for_ppc/quicksort_test.cbc quicksort_for_ppc/quicksort_test.h
diffstat 16 files changed, 0 insertions(+), 1470 deletions(-) [+]
line wrap: on
line diff
--- a/quicksort_for_ppc/Makefile	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,38 +0,0 @@
-
-CbCC=/usr/local/cbc/bin/cbc-gcc
-
-#CC=gcc
-CC=/usr/local/cbc/bin/cbc-gcc
-
-HEADERMAKER=../../CbC-scripts/make_headers.py2
-
-# fastcall版では-O0,-O2は動作確認、-O3以上はだめ
-CFLAGS=-g -O2 -fomit-frame-pointer
-#CFLAGS=-g -O2
-#CFLAGS=-g -O0
-#CFLAGS=-g -Os # an error occurred.
-
-.SUFFIXES: .cbc .o
-
-all: quicksort_cbc quicksort_c quicksort_cbc2
-
-.cbc.o:
-	$(CbCC) $(CFLAGS) -c -o $@ $<
-.cbc.h:
-	$(HEADERMAKER) $^ > $@
-
-quicksort_cbc.o: quicksort_cbc.h
-quicksort_cbc2.o: quicksort_cbc2.h
-quicksort_test.o: quicksort_test.h
-
-quicksort_cbc: quicksort_cbc.o quicksort_test.o quicksort_cbc_inter.o
-	$(CC) $(CFLAGS) -o $@ $^
-quicksort_cbc2: quicksort_cbc2.o quicksort_test.o
-	$(CC) $(CFLAGS) -o $@ $^
-
-quicksort_c: quicksort_c.o
-	$(CC) $(CFLAGS) -o $@ $^
-
-
-clean: 
-	rm -rf *.o *.s quicksort_c quicksort_cbc quicksort_cbc2 
--- a/quicksort_for_ppc/benchmark.sh	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,44 +0,0 @@
-#!/usr/bin/env zsh
-
-time=/usr/bin/time
-QS=./quicksort_c
-size=10000000
-seed=123456789
-num=10
-
-
-max=0
-min=99999
-count=0
-amount=0
-
-echo "size of array = $size"
-while [[ $count -lt $num ]]; do
-	usertime=$( $time -p $QS -n $size -s $seed 2>&1 >& - |grep '^user'|tr -s " "|cut -f2 -d" ")
-	#usertime=$(printf "%d" $usertime)
-	echo $usertime
-
-	amount=$(($usertime+$amount))
-	if [[ $usertime -lt $min ]]; then
-	    min=$usertime
-	fi
-	if [[ $usertime -gt $max ]]; then
-	    max=$usertime
-	fi
-	#seed=$seed[1,-2]
-	seed=$(($seed+10))
-	count=$(($count+1))
-done
-
-echo "amount time = $amount"
-echo "maxtime = $max"
-echo "mintime = $min"
-
-amount=$(($amount - $max - $min))
-echo "amount time - mintime - maxtime = $amount"
-count=$(($count-2))
-echo "count = $count"
-averagetime=$(($amount/($count)))
-echo "average time = $averagetime"
-
-
--- a/quicksort_for_ppc/mc/Makefile	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,39 +0,0 @@
-
-CbCC=~/WorkSpace/Mercurial/device/mc
-
-#CC=gcc
-CC=gcc
-
-HEADERMAKER=~/WorkSpace/Mercurial/GCC/CbC-scripts/make_headers.py2
-
-CFLAGS=-g -Wall
-
-.SUFFIXES: .cbc .o .s .c
-
-all: quicksort_cbc quicksort_c quicksort_cbc2
-
-quicksort_c.c quicksort_cbc.cbc quicksort_cbc2.cbc quicksort_test.cbc benchmark.sh:
-	ln -s ../$@
-
-.s.o:
-	$(CC) -c -o $@ $<
-.cbc.s:
-	$(CbCC) $<
-.cbc.h:
-	$(HEADERMAKER) $^ > $@
-
-quicksort_cbc.o: quicksort_cbc.h
-quicksort_cbc2.o: quicksort_cbc2.h
-quicksort_test.o: quicksort_test.h
-
-quicksort_cbc: quicksort_cbc.o quicksort_test.o quicksort_cbc_inter.o
-	$(CC) $(CFLAGS) -o $@ $^
-quicksort_cbc2: quicksort_cbc2.o quicksort_test.o
-	$(CC) $(CFLAGS) -o $@ $^
-
-quicksort_c: quicksort_c.o
-	$(CC) $(CFLAGS) -o $@ $^
-
-
-clean: 
-	rm -rf *.o *.s quicksort_c quicksort_cbc quicksort_cbc2 
--- a/quicksort_for_ppc/mc/benchmark.sh	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,44 +0,0 @@
-#!/usr/bin/env zsh
-
-time=/usr/bin/time
-QS=./quicksort_cbc
-size=10000000
-seed=123456789
-num=10
-
-
-max=0
-min=99999
-count=0
-amount=0
-
-echo "size of array = $size"
-while [[ $count -lt $num ]]; do
-	usertime=$( $time -p $QS -n $size -s $seed 2>&1 >& - |grep '^user'|tr -s " "|cut -f2 -d" ")
-	#usertime=$(printf "%d" $usertime)
-	echo $usertime
-
-	amount=$(($usertime+$amount))
-	if [[ $usertime -lt $min ]]; then
-	    min=$usertime
-	fi
-	if [[ $usertime -gt $max ]]; then
-	    max=$usertime
-	fi
-	#seed=$seed[1,-2]
-	seed=$(($seed+10))
-	count=$(($count+1))
-done
-
-echo "amount time = $amount"
-echo "maxtime = $max"
-echo "mintime = $min"
-
-amount=$(($amount - $max - $min))
-echo "amount time - mintime - maxtime = $amount"
-count=$(($count-2))
-echo "count = $count"
-averagetime=$(($amount/($count)))
-echo "average time = $averagetime"
-
-
--- a/quicksort_for_ppc/mc/quicksort_cbc.cbc	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,244 +0,0 @@
-#include<stdio.h>
-#include<stdlib.h>
-#include<assert.h>
-
-typedef void *stack;
-typedef struct {
-	int size;
-	void *interface;
-	__code  (*ret)(void*, stack) ;
-} frame, *framep;
-
-/* quickstart main routine. */
-typedef struct {
-	int *v;
-	int s;
-	int e;
-} QS_IF ;
-typedef __code  (*RET)(void*);
-
-#include"quicksort_cbc.h"
-
-/* for check. */
-void *mustbefreed;
-
-__code  returner(stack sp)
-{
-	framep fp = (framep)sp;
-	sp += fp->size;
-	goto fp->ret(fp->interface, sp);
-}
-
-__code  quicksort_start(void *arg, stack sp)
-{
-	QS_IF *recvif = arg;
-	int a,b,c,p;
-	a = recvif->v[recvif->s];
-	b = recvif->v[recvif->e];
-	c = recvif->v[(recvif->s+recvif->e)/2];
-
-	//printf("quicksort_start: s=%d,e=%d", recvif->s, recvif->e);
-	if (recvif->e <= recvif->s) goto returner(sp);
-
-	if (a < b) {
-		if (b < c)
-			p = b;
-		else if (a < c)
-			p = c;
-		else 
-			p = a;
-	} else {
-		if (a < c)
-			p = a;
-		else if (b < c)
-			p = c;
-		else 
-			p = b;
-	}
-
-	goto quicksort_divider (recvif, recvif->s, recvif->e, p, sp);
-}
-/* main routine end. */
-
-/* divide routine. */
-__code  quicksort_divider(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	goto quicksort_divider_s(recvif, s, e, p, sp);
-}
-__code  quicksort_divider_s(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	if (recvif->v[s]<p) {
-		goto quicksort_divider_s(recvif, s+1, e, p, sp);
-	} else
-		goto quicksort_divider_e(recvif, s, e, p, sp);
-}
-__code  quicksort_divider_e(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	if (p<recvif->v[e]) {
-		e--;
-		goto quicksort_divider_e(recvif, s, e, p, sp);
-	} else
-		goto quicksort_swapper(recvif, s, e, p, sp);
-}
-__code  quicksort_swapper(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	if (s<e) {
-		int tmp;
-		tmp = recvif->v[s];
-		recvif->v[s] = recvif->v[e];
-		recvif->v[e] = tmp;
-		goto quicksort_divider(recvif, s+1, e-1, p, sp);
-	} else {
-		goto quicksort_treecall(recvif, s, e, sp);
-	}
-}
-/* divide routin end. */
-
-
-/* recursive call routine. */
-__code  quicksort_treecall(QS_IF *recvif, int s, int e, stack sp)
-{
-	framep fp;
-	QS_IF *outif;
-
-	/* interface for first quicksort_start this segment directly jump to.  */
-	outif = (sp-=sizeof(QS_IF));
-	outif->v = recvif->v;
-	outif->s = recvif->s;
-	outif->e = e;
-	fp = (sp-=sizeof(frame));
-	fp->ret = quicksort_start;
-	fp->interface = recvif;
-	fp->size = sizeof(frame)+sizeof(QS_IF);
-
-	/* recvif is used by second quicksort_start.  */
-	recvif->s = e+1;
-	goto quicksort_start(outif, sp);
-}
-/* recursive call routine end. */
-
-#define STACK_SIZE 10240
-
-typedef struct {
-	__code  (*ret)(void*);
-	void *ret_arg;
-	stack *sp;
-} QS_FINISH;
-__code 
-quicksort(int *v, int s, int e,  RET ret, void *arg )
-{
-	framep fp;
-	stack sp0, sp;
-	sp0 = mustbefreed = malloc(STACK_SIZE);
-	sp = sp0 + STACK_SIZE;
-	QS_FINISH *finish_if;
-	QS_IF *outif;
-	
-	/* interface for quicksort_finish.  */
-	finish_if = (sp -= sizeof(QS_FINISH));
-	finish_if->ret = ret;
-	finish_if->ret_arg = arg;
-	finish_if->sp = sp0;
-
-	/* interface for quicksort_start.  */
-	outif = (sp -= sizeof(QS_IF));
-	outif->v = v;
-	outif->s = s;
-	outif->e = e;
-	/* frame for quicksort_finish.  */
-	fp = (sp -= sizeof(frame));
-	fp->ret = quicksort_finish;
-	fp->interface = finish_if;
-	fp->size = sizeof(frame)+sizeof(QS_IF);
-
-	goto quicksort_start(outif, sp);
-}
-__code 
-quicksort_finish(void *arg, stack sp)
-{
-	QS_FINISH interface;
-	interface = *(QS_FINISH*)arg;
-	//assert((void*)interface.sp==(void*)mustbefreed);
-	free(interface.sp);
-	goto interface.ret(interface.ret_arg);
-}
-
-
-
-#if 0
-void
-quicksort_c(int *v, int s0, int e0, stack sp)
-{
-	int p;
-	int s=s0, e=e0;
-	if (e<=s) return;
-
-	//p = (v[s]+v[(s+e)/2]+v[e])/3;
-	p = mid_point(v[s],v[e],v[(s+e)/2]);
-
-	while (1) {
-		 while (v[s]<p) s++;
-		 while (p<v[e]) e--;
-
-		 if (!(s<e)) break;
-		 SWAP(&v[s], &v[e]);
-		 s++; e--;
-	}
-	assert(e+1==s || s==e);
-
-	quicksort(v, s0, e);
-	quicksort(v, e+1, e0);
-	return;
-}
-
-
-
-/*  --------------------
- *     | args |fp| 
- *  --------------------
- *  +            ↑     -
- *               sp
- */ 
-/* ret segmentへgotoしたときのstack spの状態
- *
- * sp が直接さすのは frame 構造体
- * frame.size:
- * frame.ret: そのret segmentが終了した時にgotoすべきret segment.
- * frame.interface: frame.retへgotoするときのinterface.
- *                  このポインタが指すメモリ領域は stack
- *                  中にあっても良いしなくても良い。
- *                  ただしframe.retを登録した側で解放すべき。
- * sp+sizeof(frame)が指すのは実行中のret segmentのinterface(引数)
- * これは実行中のret segmentがメモリ管理する
- * 通常はこのret segmentが終了する際に sp+=frame.size とすればよい
- */
-__code caller0(void *arg, stack sp)
-{
-	/* interface for caller_finish0.  */
-	double *finish_arg = (sp -= sizeof(double));
-
-	/* arg for quicksort_start.  */
-	outif = (sp -= sizeof(*outif));
-	framep fp = (sp -= sizeof(frame));
-	fp->ret = caller_finish;
-	fp->interface = NULL;
-	fp->size = sizeof(*outif)+sizeof(frame);
-
-	goto quicksort_start(outif, sp);
-}
-__code caller_finish0(void *arg, stack sp)
-{
-}
-
-__code __returner0(void *arg , stack sp)
-{
-	framep fp = sp;
-	sp += fp->size;
-	goto fp->ret(fp->interface, sp);
-}
-
-#endif
-
-
-
-
--- a/quicksort_for_ppc/mc/quicksort_cbc.h	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,26 +0,0 @@
-/* defined in file quicksort_cbc.cbc at offset 354  */
-__code  returner (stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 462  */
-__code  quicksort_start (void *arg, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1031  */
-__code  quicksort_divider (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1155  */
-__code  quicksort_divider_s (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1364  */
-__code  quicksort_divider_e (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1576  */
-__code  quicksort_swapper (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1916  */
-__code  quicksort_treecall (QS_IF *recvif, int s, int e, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 2547  */
-__code  quicksort (int *v, int s, int e,  RET ret, void *arg );
-
-/* defined in file quicksort_cbc.cbc at offset 3213  */
-__code  quicksort_finish (void *arg, stack sp);
--- a/quicksort_for_ppc/mc/quicksort_test.cbc	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,129 +0,0 @@
-#include<stdio.h>
-#include<stdlib.h>
-#include<assert.h>
-#include<unistd.h>
-
-#include"quicksort_test.h"
-
-#define STACK_SIZE 10240
-
-extern void quicksort_IF();
-
-
-void
-random_initialize(int *v, int size, int min, int max)
-{
-	int i;
-	int diff = max-min+1;
-
-	for (i=0; i<size; i++) {
-		v[i] = min+random()%diff;
-	}
-	return;
-}
-
-static void
-print_array(int *v, int size)
-{
-	int i;
-	printf("[");
-	for (i=0; i<size; i++) {
-		printf("%s%4d", (i%10==0)? "\n  ":" ", v[i]);
-	}
-	printf(" ]\n");
-}
-
-int *IFv;
-int IFs;
-int IFe;
-void* IFret;
-void *IFarg;
-void* IFsp;
-int IFsize;
-
-void
-starter(int size)
-{
-	int *target;
-	void *sp;
-
-	target = (int*)malloc(sizeof(int)*size);
-	if (!target) {
-		perror("malloc");
-		exit(1);
-	}
-
-	random_initialize(target, size, 0, 90);
-
-	sp = malloc(STACK_SIZE);
-	if (!sp) {
-		perror("malloc");
-		exit(1);
-	}
-	//print_array(target, size);
-	//goto quicksort(target, 0, size-1, exit0, (void*)target);
-	IFv=   target;
-	IFs=    0;
-	IFe=    size-1;
-	IFret=  exit0;
-	IFarg=(void*)target;
-	IFsp= sp;
-	IFsize= STACK_SIZE;
-	quicksort_IF();
-
-	printf("bad region\n");
-}
-
-static int size=100;
-
-int
-main(int argc, char **argv)
-{
-	unsigned int seed=0;
-	int opt;
-
-	while ((opt = getopt(argc, argv, "s:n:")) != -1) {
-		switch (opt) {
-			case 's':
-				seed = atoi(optarg);
-				break;
-			case 'n':
-				size = atoi(optarg);
-				break;
-			default:
-				fprintf(stderr, "Usage: %s [-t times] [-n sizeofarray] [-s seed]\n", argv[0]);
-				exit(1);
-		}
-	}
-
-	srandom(seed);
-	starter(size);
-	return 0;
-}
-
-static int
-check_sort(int *v, int size)
-{
-	int i;
-	for (i=0; i<size-1; i++) {
-		if (v[i] > v[i+1])
-			return 0;
-	}
-	return 1;
-}
-
-void
-exit0(void *arg)
-{
-	int b;
-	//print_array(arg, size);
-	b = check_sort(arg, size);
-	if (b) {
-		printf("sorting successful!\n");
-		exit(EXIT_SUCCESS);
-	} else {
-		printf("sorting failure! \n");
-		exit(EXIT_FAILURE);
-	}
-}
-
--- a/quicksort_for_ppc/mc/quicksort_test.h	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,18 +0,0 @@
-/* defined in file quicksort_test.cbc at offset 160  */
-void random_initialize (int *v, int size, int min, int max);
-
-/* defined in file quicksort_test.cbc at offset 322  */
-static void print_array (int *v, int size);
-
-/* defined in file quicksort_test.cbc at offset 564  */
-void starter (int size);
-
-/* defined in file quicksort_test.cbc at offset 1095  */
-int main (int argc, char **argv);
-
-/* defined in file quicksort_test.cbc at offset 1491  */
-static int check_sort (int *v, int size);
-
-/* defined in file quicksort_test.cbc at offset 1620  */
-void exit0 (void *arg);
-
--- a/quicksort_for_ppc/quicksort_c.c	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,183 +0,0 @@
-#include<stdio.h>
-#include<stdlib.h>
-#include<unistd.h>
-#include<assert.h>
-
-static inline void
-SWAP (int *a, int *b)
-{
-	int tmp;
-	tmp = *a;
-	*a = *b;
-	*b = tmp;
-}
-
-static inline int
-mid_point(int a, int b, int c)
-{
-	if (a < b) {
-		if (b < c)
-			return b;
-		else if (a < c)
-			return c;
-		else 
-			return a;
-	} else {
-		if (a < c)
-			return a;
-		else if (b < c)
-			return c;
-		else 
-			return b;
-	}
-}
-
-void
-selectsort(int *v, int s0, int e0)
-{
-	int i,j;
-	int m;
-	int size = e0-s0+1;
-	v += s0;
-	for (i=0; i<size; i++) {
-		m = i;
-		for (j=i+1; j<size; j++) {
-			if (v[m] > v[j])
-				m = j;
-		}
-		if (m!=i)
-			SWAP(&v[i],&v[m]);
-	}
-	return;
-}
-
-void
-quicksort(int *v, int s0, int e0)
-{
-	int p;
-	int s=s0, e=e0;
-#if 0
-	if (e<=s) return;
-	if (e-s<5) {
-		selectsort(v,s0,e0);
-		return;
-	}
-#else
-	if (e<=s) return;
-#endif
-
-	//p = (v[s]+v[(s+e)/2]+v[e])/3;
-	p = mid_point(v[s],v[e],v[(s+e)/2]);
-
-	while (1) {
-		 while (v[s]<p) s++;
-		 while (p<v[e]) e--;
-
-		 if (!(s<e)) break;
-		 SWAP(&v[s], &v[e]);
-		 s++; e--;
-	}
-	assert(e+1==s || s==e);
-
-	quicksort(v, s0, e);
-	quicksort(v, e+1, e0);
-	return;
-}
-
-static void
-print_array(int *v, int size)
-{
-	int i;
-	printf("[");
-	for (i=0; i<size; i++) {
-		printf("%s%4d", (i%10==0)? "\n  ":" ", v[i]);
-	}
-	printf("]\n");
-}
-
-static int
-check_sort(int *v, int size)
-{
-	int i;
-	for (i=0; i<size-1; i++) {
-		if (v[i] > v[i+1])
-			return 0;
-	}
-	return 1;
-}
-
-void
-random_initialize(int *v, int size, int min, int max)
-{
-	int i;
-	int diff = max-min+1;
-
-	for (i=0; i<size; i++) {
-		v[i] = min+random()%diff;
-	}
-	return;
-}
-
-int
-start_sort(int size)
-{
-	int *target;
-
-	target = (int*)malloc(sizeof(int)*size);
-	if (!target) {
-		perror("malloc");
-		exit(1);
-	}
-
-	random_initialize(target, size, 0, 1);
-
-	//print_array(target, size);
-	quicksort(target, 0, size-1);
-	//selectsort(target, 0, size-1);
-	//print_array(target, size);
-	return check_sort(target, size);
-}
-
-int
-main(int argc, char **argv)
-{
-	//unsigned int seed= -1074072728;
-	unsigned int seed;
-	int size=101;
-	int loop=1;
-	int opt, i;
-
-	while ((opt = getopt(argc, argv, "t:s:n:")) != -1) {
-		switch (opt) {
-			case 'n':
-				size = atoi(optarg);
-				break;
-			case 't':
-				loop = atoi(optarg);
-				break;
-			case 's':
-				seed = atoi(optarg);
-				break;
-			default:
-				fprintf(stderr, "Usage: %s [-t times] [-n sizeofarray] [-s seed]\n", argv[0]);
-				exit(1);
-		}
-	}
-
-	printf("start seed = %u\n", seed);
-	printf("sort size = %d\n", size);
-	for (i=0; i<loop; i++) {
-		srandom(seed+i);
-		int b = start_sort(size);
-		if (b) {
-			printf("seed = %d+%u, success\n", i, seed);
-		} else {
-			fprintf(stderr, "sorting failure!  seed=%u+%d\n", seed,i);
-			exit(1);
-		}
-	}
-	exit(0);
-}
-
-
-
--- a/quicksort_for_ppc/quicksort_cbc.cbc	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,244 +0,0 @@
-#include<stdio.h>
-#include<stdlib.h>
-#include<assert.h>
-
-typedef void *stack;
-typedef struct {
-	int size;
-	void *interface;
-	__code  (*ret)(void*, stack) ;
-} frame, *framep;
-
-/* quickstart main routine. */
-typedef struct {
-	int *v;
-	int s;
-	int e;
-} QS_IF ;
-typedef __code  (*RET)(void*);
-
-#include"quicksort_cbc.h"
-
-/* for check. */
-void *mustbefreed;
-
-__code  returner(stack sp)
-{
-	framep fp = (framep)sp;
-	sp += fp->size;
-	goto fp->ret(fp->interface, sp);
-}
-
-__code  quicksort_start(void *arg, stack sp)
-{
-	QS_IF *recvif = arg;
-	int a,b,c,p;
-	a = recvif->v[recvif->s];
-	b = recvif->v[recvif->e];
-	c = recvif->v[(recvif->s+recvif->e)/2];
-
-	//printf("quicksort_start: s=%d,e=%d", recvif->s, recvif->e);
-	if (recvif->e <= recvif->s) goto returner(sp);
-
-	if (a < b) {
-		if (b < c)
-			p = b;
-		else if (a < c)
-			p = c;
-		else 
-			p = a;
-	} else {
-		if (a < c)
-			p = a;
-		else if (b < c)
-			p = c;
-		else 
-			p = b;
-	}
-
-	goto quicksort_divider (recvif, recvif->s, recvif->e, p, sp);
-}
-/* main routine end. */
-
-/* divide routine. */
-__code  quicksort_divider(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	goto quicksort_divider_s(recvif, s, e, p, sp);
-}
-__code  quicksort_divider_s(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	if (recvif->v[s]<p) {
-		goto quicksort_divider_s(recvif, s+1, e, p, sp);
-	} else
-		goto quicksort_divider_e(recvif, s, e, p, sp);
-}
-__code  quicksort_divider_e(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	if (p<recvif->v[e]) {
-		e--;
-		goto quicksort_divider_e(recvif, s, e, p, sp);
-	} else
-		goto quicksort_swapper(recvif, s, e, p, sp);
-}
-__code  quicksort_swapper(QS_IF *recvif, int s, int e, int p, stack sp)
-{
-	if (s<e) {
-		int tmp;
-		tmp = recvif->v[s];
-		recvif->v[s] = recvif->v[e];
-		recvif->v[e] = tmp;
-		goto quicksort_divider(recvif, s+1, e-1, p, sp);
-	} else {
-		goto quicksort_treecall(recvif, s, e, sp);
-	}
-}
-/* divide routin end. */
-
-
-/* recursive call routine. */
-__code  quicksort_treecall(QS_IF *recvif, int s, int e, stack sp)
-{
-	framep fp;
-	QS_IF *outif;
-
-	/* interface for first quicksort_start this segment directly jump to.  */
-	outif = (sp-=sizeof(QS_IF));
-	outif->v = recvif->v;
-	outif->s = recvif->s;
-	outif->e = e;
-	fp = (sp-=sizeof(frame));
-	fp->ret = quicksort_start;
-	fp->interface = recvif;
-	fp->size = sizeof(frame)+sizeof(QS_IF);
-
-	/* recvif is used by second quicksort_start.  */
-	recvif->s = e+1;
-	goto quicksort_start(outif, sp);
-}
-/* recursive call routine end. */
-
-#define STACK_SIZE 10240
-
-typedef struct {
-	__code  (*ret)(void*);
-	void *ret_arg;
-	stack *sp;
-} QS_FINISH;
-__code 
-quicksort(int *v, int s, int e,  RET ret, void *arg )
-{
-	framep fp;
-	stack sp0, sp;
-	sp0 = mustbefreed = malloc(STACK_SIZE);
-	sp = sp0 + STACK_SIZE;
-	QS_FINISH *finish_if;
-	QS_IF *outif;
-	
-	/* interface for quicksort_finish.  */
-	finish_if = (sp -= sizeof(QS_FINISH));
-	finish_if->ret = ret;
-	finish_if->ret_arg = arg;
-	finish_if->sp = sp0;
-
-	/* interface for quicksort_start.  */
-	outif = (sp -= sizeof(QS_IF));
-	outif->v = v;
-	outif->s = s;
-	outif->e = e;
-	/* frame for quicksort_finish.  */
-	fp = (sp -= sizeof(frame));
-	fp->ret = quicksort_finish;
-	fp->interface = finish_if;
-	fp->size = sizeof(frame)+sizeof(QS_IF);
-
-	goto quicksort_start(outif, sp);
-}
-__code 
-quicksort_finish(void *arg, stack sp)
-{
-	QS_FINISH interface;
-	interface = *(QS_FINISH*)arg;
-	//assert((void*)interface.sp==(void*)mustbefreed);
-	free(interface.sp);
-	goto interface.ret(interface.ret_arg);
-}
-
-
-
-#if 0
-void
-quicksort_c(int *v, int s0, int e0, stack sp)
-{
-	int p;
-	int s=s0, e=e0;
-	if (e<=s) return;
-
-	//p = (v[s]+v[(s+e)/2]+v[e])/3;
-	p = mid_point(v[s],v[e],v[(s+e)/2]);
-
-	while (1) {
-		 while (v[s]<p) s++;
-		 while (p<v[e]) e--;
-
-		 if (!(s<e)) break;
-		 SWAP(&v[s], &v[e]);
-		 s++; e--;
-	}
-	assert(e+1==s || s==e);
-
-	quicksort(v, s0, e);
-	quicksort(v, e+1, e0);
-	return;
-}
-
-
-
-/*  --------------------
- *     | args |fp| 
- *  --------------------
- *  +            ↑     -
- *               sp
- */ 
-/* ret segmentへgotoしたときのstack spの状態
- *
- * sp が直接さすのは frame 構造体
- * frame.size:
- * frame.ret: そのret segmentが終了した時にgotoすべきret segment.
- * frame.interface: frame.retへgotoするときのinterface.
- *                  このポインタが指すメモリ領域は stack
- *                  中にあっても良いしなくても良い。
- *                  ただしframe.retを登録した側で解放すべき。
- * sp+sizeof(frame)が指すのは実行中のret segmentのinterface(引数)
- * これは実行中のret segmentがメモリ管理する
- * 通常はこのret segmentが終了する際に sp+=frame.size とすればよい
- */
-__code caller0(void *arg, stack sp)
-{
-	/* interface for caller_finish0.  */
-	double *finish_arg = (sp -= sizeof(double));
-
-	/* arg for quicksort_start.  */
-	outif = (sp -= sizeof(*outif));
-	framep fp = (sp -= sizeof(frame));
-	fp->ret = caller_finish;
-	fp->interface = NULL;
-	fp->size = sizeof(*outif)+sizeof(frame);
-
-	goto quicksort_start(outif, sp);
-}
-__code caller_finish0(void *arg, stack sp)
-{
-}
-
-__code __returner0(void *arg , stack sp)
-{
-	framep fp = sp;
-	sp += fp->size;
-	goto fp->ret(fp->interface, sp);
-}
-
-#endif
-
-
-
-
--- a/quicksort_for_ppc/quicksort_cbc.h	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,26 +0,0 @@
-/* defined in file quicksort_cbc.cbc at offset 354  */
-__code  returner (stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 462  */
-__code  quicksort_start (void *arg, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1031  */
-__code  quicksort_divider (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1155  */
-__code  quicksort_divider_s (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1364  */
-__code  quicksort_divider_e (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1576  */
-__code  quicksort_swapper (QS_IF *recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 1916  */
-__code  quicksort_treecall (QS_IF *recvif, int s, int e, stack sp);
-
-/* defined in file quicksort_cbc.cbc at offset 2547  */
-__code  quicksort (int *v, int s, int e,  RET ret, void *arg );
-
-/* defined in file quicksort_cbc.cbc at offset 3213  */
-__code  quicksort_finish (void *arg, stack sp);
--- a/quicksort_for_ppc/quicksort_cbc2.cbc	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,159 +0,0 @@
-#include<stdio.h>
-#include<stdlib.h>
-#include<assert.h>
-
-typedef struct {
-	int *v;
-	int s;
-	int e;
-} QS_IF;
-
-typedef void *stack;
-typedef __code (*RET)(QS_IF, stack);
-typedef struct {
-	int size;
-	QS_IF interface;
-	RET ret;
-} frame, *framep;
-
-typedef __code (*RETTYPE)(void*);
-typedef struct {
-	RETTYPE ret;
-	void *ret_arg;
-	stack *sp;
-} QS_FINISH;
-#define STACK_SIZE 10240
-
-#include"quicksort_cbc2.h"
-
-__code returner(stack sp)
-{
-	framep fp = (framep)sp;
-	sp += fp->size;
-	goto fp->ret(fp->interface, sp);
-}
-
-__code quicksort_start(QS_IF recvif, stack sp)
-{
-	int a,b,c,p;
-	a = recvif.v[recvif.s];
-	b = recvif.v[recvif.e];
-	c = recvif.v[(recvif.s+recvif.e)/2];
-
-	//printf("quicksort_start: s=%d,e=%d", recvif->s, recvif->e);
-	if (recvif.e <= recvif.s) goto returner(sp);
-
-	if (a < b) {
-		if (b < c)
-			p = b;
-		else if (a < c)
-			p = c;
-		else 
-			p = a;
-	} else {
-		if (a < c)
-			p = a;
-		else if (b < c)
-			p = c;
-		else 
-			p = b;
-	}
-
-	goto quicksort_divider (recvif, recvif.s, recvif.e, p, sp);
-}
-/* main routine end. */
-
-/* divide routine. */
-__code quicksort_divider(QS_IF recvif, int s, int e, int p, stack sp)
-{
-	goto quicksort_divider_s(recvif, s, e, p, sp);
-}
-__code quicksort_divider_s(QS_IF recvif, int s, int e, int p, stack sp)
-{
-	if (recvif.v[s]<p) {
-		s++;
-		goto quicksort_divider_s(recvif, s, e, p, sp);
-	} else
-		goto quicksort_divider_e(recvif, s, e, p, sp);
-}
-__code quicksort_divider_e(QS_IF recvif, int s, int e, int p, stack sp)
-{
-	if (p<recvif.v[e]) {
-		e--;
-		goto quicksort_divider_e(recvif, s, e, p, sp);
-	} else
-		goto quicksort_swapper(recvif, s, e, p, sp);
-}
-__code quicksort_swapper(QS_IF recvif, int s, int e, int p, stack sp)
-{
-	if (s<e) {
-		int tmp;
-		tmp = recvif.v[s];
-		recvif.v[s] = recvif.v[e];
-		recvif.v[e] = tmp;
-		s++;
-		e--;
-		goto quicksort_divider(recvif, s, e, p, sp);
-	} else {
-		//assert(e+1==s || s==e);
-		goto quicksort_treecall(recvif, s, e, sp);
-	}
-}
-/* divide routin end. */
-
-
-/* recursive call routine. */
-__code quicksort_treecall(QS_IF recvif, int s, int e, stack sp)
-{
-	framep fp;
-
-	/* interface for first quicksort_start this segment directly jump to.  */
-	fp = (sp-=sizeof(frame));
-	fp->ret = quicksort_start;
-	fp->size = sizeof(frame);
-	fp->interface.v = recvif.v;
-	fp->interface.s = e+1;
-	fp->interface.e = recvif.e;
-
-	/* recvif is used by second quicksort_start.  */
-	recvif.e = e;
-	goto quicksort_start(recvif, sp);
-}
-/* recursive call routine end. */
-
-__code
-quicksort(int *v, int s, int e,  RETTYPE ret, void *arg )
-{
-	framep fp;
-	stack sp0, sp;
-	sp0 = malloc(STACK_SIZE);
-	printf("allocate a stack %p\n", sp0);
-	sp = sp0 + STACK_SIZE;
-	QS_FINISH *finish_if;
-	
-	/* interface for quicksort_finish.  */
-	finish_if = (sp -= sizeof(*finish_if));
-	finish_if->ret = ret;
-	finish_if->ret_arg = arg;
-	finish_if->sp = sp0;
-
-	/* interface for quicksort_start.  */
-	/* frame for quicksort_finish.  */
-	fp = (sp -= sizeof(frame));
-	fp->ret = quicksort_finish;
-	fp->size = sizeof(frame);
-	fp->interface.v = v;
-	fp->interface.s = s;
-	fp->interface.e = e;
-
-	goto quicksort_start(fp->interface, sp);
-}
-__code
-quicksort_finish(QS_IF recvif, stack sp)
-{
-	QS_FINISH *interface = (QS_FINISH*)sp;
-	free(interface->sp);
-	printf("free the stack %p\n", interface->sp);
-	goto interface->ret(interface->ret_arg);
-}
-
--- a/quicksort_for_ppc/quicksort_cbc2.h	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,27 +0,0 @@
-/* defined in file quicksort_cbc2.cbc at offset 402  */
-__code returner (stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 509  */
-__code quicksort_start (QS_IF recvif, stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 1047  */
-__code quicksort_divider (QS_IF recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 1169  */
-__code quicksort_divider_s (QS_IF recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 1380  */
-__code quicksort_divider_e (QS_IF recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 1589  */
-__code quicksort_swapper (QS_IF recvif, int s, int e, int p, stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 1961  */
-__code quicksort_treecall (QS_IF recvif, int s, int e, stack sp);
-
-/* defined in file quicksort_cbc2.cbc at offset 2417  */
-__code quicksort (int *v, int s, int e,  RETTYPE ret, void *arg );
-
-/* defined in file quicksort_cbc2.cbc at offset 3052  */
-__code quicksort_finish (QS_IF recvif, stack sp);
-
--- a/quicksort_for_ppc/quicksort_cbc_inter.cbc	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,102 +0,0 @@
-
-#include<stdlib.h>
-typedef void *stack;
-typedef struct {
-	int size;
-	void *interface;
-	__code  (*ret)(void*, stack) ;
-} frame, *framep;
-
-/* quickstart main routine. */
-typedef struct {
-	int *v;
-	int s;
-	int e;
-} QS_IF ;
-typedef __code  (*RET)(void*);
-
-#include"quicksort_cbc.h"
-
-
-typedef struct {
-	__code  (*ret)(void*);
-	void *ret_arg;
-	stack *sp;
-} QS_FINISH;
-
-extern int *IFv;
-extern int IFs;
-extern int IFe;
-extern RET IFret;
-extern void *IFarg;
-extern stack IFsp;
-extern int IFsize;
-
-static void(*exitfunc)(void*);
-__code exitter(void *arg) {
-	exitfunc(arg);
-}
-
-__code quicksort_finish_IF(void *arg, stack sp);
-
-void
-quicksort_IF()
-{
-	printf("v=%p\n", IFv);
-	printf("s=%d\n", IFs);
-	printf("e=%d\n", IFe);
-	printf("ret=%p\n", IFret);
-	printf("arg=%p\n", IFarg);
-	printf("sp=%p\n", IFsp);
-	printf("size=%d\n", IFsize);
-	exitfunc = IFret;
-
-	goto quicksort_IF0(IFv, IFs, IFe, exitter, IFarg, IFsp, IFsize);
-}
-
-__code 
-quicksort_IF0(int *v, int s, int e,  RET ret, void *arg, stack sp0,int size)
-{
-	framep fp;
-	stack sp;
-	sp = sp0 + size;
-	QS_FINISH *finish_if;
-	QS_IF *outif;
-
-	printf("v=%p\n", v);
-	printf("s=%d\n", s);
-	printf("e=%d\n", e);
-	printf("ret=%p\n", ret);
-	printf("arg=%p\n", arg);
-	printf("sp=%p\n", sp0);
-	printf("size=%d\n", size);
-	
-	/* interface for quicksort_finish.  */
-	finish_if = (sp -= sizeof(QS_FINISH));
-	finish_if->ret = ret;
-	finish_if->ret_arg = arg;
-	finish_if->sp = sp0;
-
-	/* interface for quicksort_start.  */
-	outif = (sp -= sizeof(QS_IF));
-	outif->v = v;
-	outif->s = s;
-	outif->e = e;
-	/* frame for quicksort_finish.  */
-	fp = (sp -= sizeof(frame));
-	fp->ret = quicksort_finish_IF;
-	fp->interface = finish_if;
-	fp->size = sizeof(frame)+sizeof(QS_IF);
-
-	goto quicksort_start(outif, sp);
-}
-
-__code 
-quicksort_finish_IF(void *arg, stack sp)
-{
-	QS_FINISH interface;
-	interface = *(QS_FINISH*)arg;
-	//assert((void*)interface.sp==(void*)mustbefreed);
-	goto interface.ret(interface.ret_arg);
-}
-
--- a/quicksort_for_ppc/quicksort_test.cbc	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,129 +0,0 @@
-#include<stdio.h>
-#include<stdlib.h>
-#include<assert.h>
-#include<unistd.h>
-
-#include"quicksort_test.h"
-
-#define STACK_SIZE 10240
-
-extern void quicksort_IF();
-
-
-void
-random_initialize(int *v, int size, int min, int max)
-{
-	int i;
-	int diff = max-min+1;
-
-	for (i=0; i<size; i++) {
-		v[i] = min+random()%diff;
-	}
-	return;
-}
-
-static void
-print_array(int *v, int size)
-{
-	int i;
-	printf("[");
-	for (i=0; i<size; i++) {
-		printf("%s%4d", (i%10==0)? "\n  ":" ", v[i]);
-	}
-	printf(" ]\n");
-}
-
-int *IFv;
-int IFs;
-int IFe;
-void* IFret;
-void *IFarg;
-void* IFsp;
-int IFsize;
-
-void
-starter(int size)
-{
-	int *target;
-	void *sp;
-
-	target = (int*)malloc(sizeof(int)*size);
-	if (!target) {
-		perror("malloc");
-		exit(1);
-	}
-
-	random_initialize(target, size, 0, 90);
-
-	sp = malloc(STACK_SIZE);
-	if (!sp) {
-		perror("malloc");
-		exit(1);
-	}
-	//print_array(target, size);
-	//goto quicksort(target, 0, size-1, exit0, (void*)target);
-	IFv=   target;
-	IFs=    0;
-	IFe=    size-1;
-	IFret=  exit0;
-	IFarg=(void*)target;
-	IFsp= sp;
-	IFsize= STACK_SIZE;
-	quicksort_IF();
-
-	printf("bad region\n");
-}
-
-static int size=100;
-
-int
-main(int argc, char **argv)
-{
-	unsigned int seed=0;
-	int opt;
-
-	while ((opt = getopt(argc, argv, "s:n:")) != -1) {
-		switch (opt) {
-			case 's':
-				seed = atoi(optarg);
-				break;
-			case 'n':
-				size = atoi(optarg);
-				break;
-			default:
-				fprintf(stderr, "Usage: %s [-t times] [-n sizeofarray] [-s seed]\n", argv[0]);
-				exit(1);
-		}
-	}
-
-	srandom(seed);
-	starter(size);
-	return 0;
-}
-
-static int
-check_sort(int *v, int size)
-{
-	int i;
-	for (i=0; i<size-1; i++) {
-		if (v[i] > v[i+1])
-			return 0;
-	}
-	return 1;
-}
-
-void
-exit0(void *arg)
-{
-	int b;
-	//print_array(arg, size);
-	b = check_sort(arg, size);
-	if (b) {
-		printf("sorting successful!\n");
-		exit(EXIT_SUCCESS);
-	} else {
-		printf("sorting failure! \n");
-		exit(EXIT_FAILURE);
-	}
-}
-
--- a/quicksort_for_ppc/quicksort_test.h	Tue Feb 16 14:35:36 2010 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,18 +0,0 @@
-/* defined in file quicksort_test.cbc at offset 160  */
-void random_initialize (int *v, int size, int min, int max);
-
-/* defined in file quicksort_test.cbc at offset 322  */
-static void print_array (int *v, int size);
-
-/* defined in file quicksort_test.cbc at offset 564  */
-void starter (int size);
-
-/* defined in file quicksort_test.cbc at offset 1095  */
-int main (int argc, char **argv);
-
-/* defined in file quicksort_test.cbc at offset 1491  */
-static int check_sort (int *v, int size);
-
-/* defined in file quicksort_test.cbc at offset 1620  */
-void exit0 (void *arg);
-