Page 1 of 1
					
				I'm having a problem compiling the FunSlower demo...
				Posted: Wed Jun 25, 2008 2:09 am
				by LBGSHI
				I'm able to compile quite a few other examples (everything in the Samples directory included with PS2SDK, all of DreamTime's tutorial source, all the various strains of the Hello World examples, all the source that whatisdot has been so gracious as to share, to name a few), but I'm having an issue compiling the FunSlower demo. If it's just outdated source based on an old SDK or library thereof, that's one thing, but I'd like to ensure I don't have a problem with my build of PS2SDK. Here is the error I get on attempted compilation:
$ make
../ee-bin/bin/mips64r5900-sce-elf-gcc.exe -fshort-double -O6 -c -Werror  main.c
-o main.o
make: ../ee-bin/bin/mips64r5900-sce-elf-gcc.exe: Command not found
make: *** [main.o] Error 127
Could anyone point me in the right direction? Am I missing mips64r5900-sce-elf-gcc.exe, or is this executable no longer included in the PS2SDK?
			 
			
					
				
				Posted: Wed Jun 25, 2008 4:40 am
				by Lukasz
				The makefile for the FunSlower is quite outdated, but this can be easily fixed by replacing the makefile with this one
Makefile
Code: Select all
EE_BIN = main.elf
OBJECTSEKS = eks1.o eks2.o eks3.o vutest.o eks4.o eks5.o eks5vu.o eks6.o eks7.o eks7vu.o
OBJECTSLIB = texture.o math.o dma.o matrix.o gif.o vu.o malloc.o
OBJECTSDATA = logo.o logo_alpha.o dot.o dot2.o font.o font_alpha.o mainbg1.o mainbg1_alpha.o mainbg2.o mainbg2_alpha.o fslogo.o kantlogo.o kantfade.o scroll.o druckluft.o druckluft_a.o gibson.o gibson_a.o
EE_OBJS = main.o initgs.o $(OBJECTSEKS) $(OBJECTSLIB) $(OBJECTSDATA)
EE_CFLAGS = -fshort-double
all: $(EE_BIN)
 
clean:
	rm -f *.elf *.o *.a
%.s: %.pcx
	./rawtoasm $< $@ $@
%.o: %.vsm
	dvp-as $< -o $@
run: all
	ps2client execee host:$(EE_BIN)
reset:
	ps2client reset
rawtoasm: rawtoasm.c
	gcc $< -o $@
include $(PS2SDK)/samples/Makefile.pref
include $(PS2SDK)/samples/Makefile.eeglobal
It's necessary to replace the space indentation for the commands in the makefile with tabs, when copy-pasting to a file, because tabs are converted to spaces on phpBB. 
Eg.
Should be
Code: Select all
clean:
<tab>rm -f *.elf *.o *.a
Also add a file named initgs.s to the source code directory, with the following contents
initgs.s
Code: Select all
	.set noat
	.set noreorder
	.global _start
	.text
	.globl Init_GS
	.align 4
Init_GS:
        lui     $2,0x1fc8
        lb      $2,-0xae($2)
        li      $3,'E'
        li      $6,2                  # 2=NTSC, 3=PAL
        beql    $2,$3,pal_mode
        addiu   $6,1
pal_mode:
		li	$5,1			# 0=NON, 1=INTERLACE
		li	$7,0			# 1=frame, 2=field
		addu	$17,$5,$0
		addu	$18,$6,$0
		addu	$19,$7,$0
		li	$3,0x12001000
		li	$2,0x00000200
		sd	$2,0($3)	# write 0x200 to 0x12001000 (=GS reset)
		li	$4,0x0000FF00
		ld	$2,0($3)
		dsrl	$2,16
		andi	$2,0xFF
		li	$3,0x71		# PutIMR(kernel)
		syscall
		nop
		andi	$4,$17,1
		andi	$5,$18,0xFF
		andi	$6,$19,1
		li	$3,2		# SetGsCrt(kernel)
		syscall
		jr	$31
		nop
The source will now compile with alot of warnings (most of them are missing newline), but the demo runs fine from beginning to end :-)
As a note, mips64r5900-sce-elf-gcc.exe is now called just ee-gcc.exe :-)
 
			
					
				
				Posted: Wed Jun 25, 2008 5:09 am
				by LBGSHI
				The makefile for the FunSlower is quite outdated, but this can be easily fixed by replacing the makefile with this one
Thanks very much; I'll give that a shot. You'd think the FunSlower demo page on the main PS2Dev site would have an addendum noting that, for new PS2 developers...perhaps we can suggest that.
It's necessary to replace the space indentation for the commands in the makefile with tabs, when copy-pasting to a file, because tabs are converted to spaces on phpBB. 
Yes, I'm aware of this (and I think Crimson Editor, using the settings you outlined in your MinGW guide, does this for me, though I could have simply forgotten having to do this manually each time I copy and paste some posted source).
As a note, mips64r5900-sce-elf-gcc.exe is now called just ee-gcc.exe
Ah, I thought that might be the case! Thanks again; I'll let you know if everything goes off without a hitch :)
 
			
					
				
				Posted: Wed Jun 25, 2008 7:10 am
				by LBGSHI
				Unfortunately, that failed. There was too much output to even grab from msys (I can only scroll up so far before it cuts off), but here is what I could copy:
Code: Select all
In file included from eks1.c:6:
dma.h:47:7: warning: no newline at end of file
In file included from eks1.c:7:
texture.h:28:7: warning: no newline at end of file
In file included from eks1.c:8:
math.h:113:7: warning: no newline at end of file
eks1.c: In function `puttexture':
eks1.c:50: warning: implicit declaration of function `texture_TEX0'
eks1.c: In function `eks1_frame3':
eks1.c:240: warning: unused variable `y1'
eks1.c:241: warning: unused variable `y2'
eks1.c:288:2: warning: no newline at end of file
math.h: At top level:
types.h:30: warning: `new_fvec' defined but not used
math.h:108: warning: `atan2' defined but not used
eks1.c:26: warning: `list' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c eks2.c -o eks2.o
In file included from eks2.c:4:
eks2.h:10:7: warning: no newline at end of file
In file included from hwreg.h:4,
                 from gif.h:4,
                 from eks2.c:5:
types.h:41:7: warning: no newline at end of file
In file included from gif.h:4,
                 from eks2.c:5:
hwreg.h:29:7: warning: no newline at end of file
In file included from eks2.c:5:
gif.h:87:7: warning: no newline at end of file
In file included from eks2.c:6:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from eks2.c:6:
dma.h:47:7: warning: no newline at end of file
In file included from eks2.c:7:
texture.h:28:7: warning: no newline at end of file
In file included from eks2.c:8:
math.h:113:7: warning: no newline at end of file
In file included from eks2.c:9:
matrix.h:34:7: warning: no newline at end of file
eks2.c: In function `puttexture2':
eks2.c:57: warning: implicit declaration of function `texture_TEX0'
eks2.c: In function `eks2_frame':
eks2.c:111: warning: unused variable `thorsten'
math.h: At top level:
types.h:30: warning: `new_fvec' defined but not used
math.h:48: warning: `cos' defined but not used
math.h:78: warning: `sin' defined but not used
math.h:108: warning: `atan2' defined but not used
eks2.c:14: warning: `list' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c eks3.c -o eks3.o
In file included from eks3.c:4:
eks3.h:9:7: warning: no newline at end of file
In file included from hwreg.h:4,
                 from gif.h:4,
                 from eks3.c:5:
types.h:41:7: warning: no newline at end of file
In file included from gif.h:4,
                 from eks3.c:5:
hwreg.h:29:7: warning: no newline at end of file
In file included from eks3.c:5:
gif.h:87:7: warning: no newline at end of file
In file included from eks3.c:6:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from eks3.c:6:
dma.h:47:7: warning: no newline at end of file
In file included from eks3.c:7:
texture.h:28:7: warning: no newline at end of file
In file included from eks3.c:8:
math.h:113:7: warning: no newline at end of file
In file included from eks3.c:9:
vu.h:11:7: warning: no newline at end of file
In file included from eks3.c:10:
matrix.h:34:7: warning: no newline at end of file
eks3.c: In function `vutest':
eks3.c:67: warning: unused variable `GIF_i'
eks3.c:67: warning: unused variable `GIF_p'
eks3.c:67: warning: unused variable `GIF_beg'
eks3.c:67: warning: unused variable `GIF_nreg'
eks3.c:67: warning: unused variable `GIF_flg'
eks3.c:67: warning: unused variable `GIF_prim'
eks3.c:67: warning: unused variable `GIF_pre'
math.h: At top level:
types.h:30: warning: `new_fvec' defined but not used
math.h:108: warning: `atan2' defined but not used
eks3.c:12: warning: `list' defined but not used
dvp-as vutest.vsm -o vutest.o
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c eks4.c -o eks4.o
In file included from eks4.c:4:
eks4.h:9:7: warning: no newline at end of file
In file included from hwreg.h:4,
                 from gif.h:4,
                 from eks4.c:5:
types.h:41:7: warning: no newline at end of file
In file included from gif.h:4,
                 from eks4.c:5:
hwreg.h:29:7: warning: no newline at end of file
In file included from eks4.c:5:
gif.h:87:7: warning: no newline at end of file
In file included from eks4.c:6:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from eks4.c:6:
dma.h:47:7: warning: no newline at end of file
In file included from eks4.c:7:
texture.h:28:7: warning: no newline at end of file
In file included from eks4.c:8:
math.h:113:7: warning: no newline at end of file
eks4.c: In function `findletters':
eks4.c:99: warning: array subscript has type `char'
eks4.c:100: warning: array subscript has type `char'
eks4.c:101: warning: array subscript has type `char'
eks4.c:102: warning: array subscript has type `char'
eks4.c: In function `putletter2':
eks4.c:131: warning: implicit declaration of function `texture_TEX0'
math.h: At top level:
types.h:30: warning: `new_fvec' defined but not used
math.h:48: warning: `cos' defined but not used
math.h:78: warning: `sin' defined but not used
math.h:108: warning: `atan2' defined but not used
eks4.c:22: warning: `list' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c eks5.c -o eks5.o
In file included from eks5.c:4:
eks3.h:9:7: warning: no newline at end of file
In file included from hwreg.h:4,
                 from gif.h:4,
                 from eks5.c:5:
types.h:41:7: warning: no newline at end of file
In file included from gif.h:4,
                 from eks5.c:5:
hwreg.h:29:7: warning: no newline at end of file
In file included from eks5.c:5:
gif.h:87:7: warning: no newline at end of file
In file included from eks5.c:6:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from eks5.c:6:
dma.h:47:7: warning: no newline at end of file
In file included from eks5.c:7:
texture.h:28:7: warning: no newline at end of file
In file included from eks5.c:8:
math.h:113:7: warning: no newline at end of file
In file included from eks5.c:9:
vu.h:11:7: warning: no newline at end of file
In file included from eks5.c:10:
matrix.h:34:7: warning: no newline at end of file
eks5.c: In function `vutest':
eks5.c:57: warning: unused variable `GIF_i'
eks5.c:57: warning: unused variable `GIF_p'
eks5.c:57: warning: unused variable `GIF_beg'
eks5.c:57: warning: unused variable `GIF_nreg'
eks5.c:57: warning: unused variable `GIF_flg'
eks5.c:57: warning: unused variable `GIF_prim'
eks5.c:57: warning: unused variable `GIF_pre'
math.h: At top level:
types.h:30: warning: `new_fvec' defined but not used
math.h:108: warning: `atan2' defined but not used
dvp-as eks5vu.vsm -o eks5vu.o
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c eks6.c -o eks6.o
eks6.c:3:16: warning: no newline at end of file
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c eks7.c -o eks7.o
In file included from eks7.c:4:
eks7.h:9:7: warning: no newline at end of file
In file included from hwreg.h:4,
                 from gif.h:4,
                 from eks7.c:5:
types.h:41:7: warning: no newline at end of file
In file included from gif.h:4,
                 from eks7.c:5:
hwreg.h:29:7: warning: no newline at end of file
In file included from eks7.c:5:
gif.h:87:7: warning: no newline at end of file
In file included from eks7.c:6:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from eks7.c:6:
dma.h:47:7: warning: no newline at end of file
In file included from eks7.c:7:
texture.h:28:7: warning: no newline at end of file
In file included from eks7.c:8:
math.h:113:7: warning: no newline at end of file
In file included from eks7.c:9:
vu.h:11:7: warning: no newline at end of file
In file included from eks7.c:10:
matrix.h:34:7: warning: no newline at end of file
eks7.c: In function `vutest':
eks7.c:68: warning: unused variable `GIF_i'
eks7.c:68: warning: unused variable `GIF_p'
eks7.c:68: warning: unused variable `GIF_beg'
eks7.c:68: warning: unused variable `GIF_nreg'
eks7.c:68: warning: unused variable `GIF_flg'
eks7.c:68: warning: unused variable `GIF_prim'
eks7.c:68: warning: unused variable `GIF_pre'
math.h: At top level:
math.h:108: warning: `atan2' defined but not used
dvp-as eks7vu.vsm -o eks7vu.o
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c texture.c -o texture.o
In file included from texture.h:4,
                 from texture.c:4:
types.h:41:7: warning: no newline at end of file
In file included from texture.c:4:
texture.h:28:7: warning: no newline at end of file
In file included from texture.c:5:
malloc.h:8:7: warning: no newline at end of file
In file included from gif.h:4,
                 from texture.c:6:
hwreg.h:29:7: warning: no newline at end of file
In file included from texture.c:6:
gif.h:87:7: warning: no newline at end of file
In file included from texture.c:7:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from texture.c:7:
dma.h:47:7: warning: no newline at end of file
texture.c: In function `texture_allocinit':
texture.c:397: warning: control reaches end of non-void function
texture.c:410:2: warning: no newline at end of file
dma.h: At top level:
types.h:30: warning: `new_fvec' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c math.c -o math.o
In file included from math.c:1:
math.h:113:7: warning: no newline at end of file
math.h:108: warning: `atan2' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c dma.c -o dma.o
In file included from hwreg.h:4,
                 from dma.h:4,
                 from dma.c:1:
types.h:41:7: warning: no newline at end of file
In file included from dma.h:4,
                 from dma.c:1:
hwreg.h:29:7: warning: no newline at end of file
In file included from dma.c:1:
dma.h:11: warning: return type defaults to `int'
dma.h:36: warning: return type defaults to `int'
In file included from dma.c:1:
dma.h:47:7: warning: no newline at end of file
types.h:30: warning: `new_fvec' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c matrix.c -o matrix.o
In file included from matrix.c:1:
math.h:113:7: warning: no newline at end of file
In file included from matrix.h:4,
                 from matrix.c:2:
types.h:41:7: warning: no newline at end of file
In file included from matrix.c:2:
matrix.h:34:7: warning: no newline at end of file
matrix.c:274:24: warning: multi-line string literals are deprecated
matrix.c:285:24: warning: multi-line string literals are deprecated
matrix.c: In function `transformf2':
matrix.c:272: warning: `t' might be used uninitialized in this function
math.h: At top level:
math.h:48: warning: `cos' defined but not used
math.h:78: warning: `sin' defined but not used
types.h:30: warning: `new_fvec' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c gif.c -o gif.o
In file included from hwreg.h:4,
                 from gif.h:4,
                 from gif.c:1:
types.h:41:7: warning: no newline at end of file
In file included from gif.h:4,
                 from gif.c:1:
hwreg.h:29:7: warning: no newline at end of file
In file included from gif.c:1:
gif.h:87:7: warning: no newline at end of file
types.h:30: warning: `new_fvec' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c vu.c -o vu.o
In file included from vu.c:1:
vu.h:11:7: warning: no newline at end of file
In file included from hwreg.h:4,
                 from vu.c:2:
types.h:41:7: warning: no newline at end of file
In file included from vu.c:2:
hwreg.h:29:7: warning: no newline at end of file
vu.c:62:9: warning: multi-line string literals are deprecated
types.h:30: warning: `new_fvec' defined but not used
ee-gcc -D_EE -O2 -G0 -Wall -fshort-double -I/usr/local/ps2dev/ps2sdk/ee/include
-I/usr/local/ps2dev/ps2sdk/common/include -I.  -c malloc.c -o malloc.o
In file included from malloc.h:4,
                 from malloc.c:1:
types.h:41:7: warning: no newline at end of file
In file included from malloc.c:1:
malloc.h:8:7: warning: no newline at end of file
types.h:30: warning: `new_fvec' defined but not used
./rawtoasm logo.pcx logo.s logo.s
make: ./rawtoasm: Command not found
make: *** [logo.s] Error 127
I'm guessing the last two lines are the only ones that matter, but have you any idea what's going wrong here? Again, thanks very much for your efforts.
 
			
					
				
				Posted: Wed Jun 25, 2008 7:41 am
				by Lukasz
				Just type 
 
to compile the rawtoasm program and then run make again.
 
			
					
				
				Posted: Wed Jun 25, 2008 7:50 am
				by LBGSHI
				That yields the error, 
Code: Select all
make: *** No rule to make target `rawtoasm'.  Stop.
However, apologies for not reading the ReadMe, and knowing that I needed to compile the rawtoasm source before compiling the rest of the source. Might the issue have something to do with the makefile's reference to "./rawtoasm"?
 
			
					
				
				Posted: Wed Jun 25, 2008 8:53 am
				by J.F.
				If you're using the makefile he posted above, there is a rule.
Code: Select all
rawtoasm: rawtoasm.c
   gcc $< -o $@ 
See? Right there. Just "make rawtoasm" - be sure to spell it correctly.
 
			
					
				
				Posted: Wed Jun 25, 2008 1:20 pm
				by LBGSHI
				Actually, I think I must have made a simple typo, though I can't imagine how. I tried again, and everything compiled fine :)
Thanks quite a bit.