Vampire et Phoenix Core

15 sujets de 901 à 915 (sur un total de 1,122)

  • __sam__

      #254868

      @receptor: Aie j’ai mal aux yeux. Ca piiiiiique! Il faut prévenir quand on poste ca, il pourrait y avoir des morts.


      @seg
      t’as raison 😛

      Samuel.

      Amiga A500 + GVP530 (8Mo/fpu/mmu/scsi) - en panne 🙁
      A500 (+ 1Mo PPS), A1200 (Blizzard-IV/fpu/64Mo)
      A500 Vampire V2+ ^8^ 🙂
      (mais aussi TO8, TO8D, TO9. Groupe PULS.)

      lexomil

        #254883

        @flype : tu pourrais modifier deux trois trucs dans ton code pour voir l’impact de la séparation des bus instruction et data ?

        dans la fonction FireUpdate il suffirait d’alterner les clr.l et les move.b, du genre

        [code]
        .loopX
        clr.l d2
        move.b -1(a0),d2
        clr.l d3
        move.b 1(a0),d3

        [/code]

        tu dois pouvoir faire le même genre de modif dans la fonction FireDraw.

        Tu devrais gagner quelques fps encore.

        Bonne journée

        EDIT : je viens de voir que Gunnar te filait déjà quelques tuyau pour la fonction.

        k1200rs21

          #255070

          le pilote picasso 96 pour la v2 600 est sorti pour les possesseurs de la carte

          pilote picasso 96

          Dans Prefs-> ScreenMode sélectionner Vampire 640×480 16 bits et cliquez UTILISATION, rappelez-vous ne cliquez pas sur Enregistrer puisque vous pourriez avoir des problèmes plus tard et vous serez obligé de le récupérer à l’état précédent de la CLI.

          lien du sujet
          http://www.apollo-core.com/knowledge.php?b=5&note=419

          https://www.youtube.com/channel/UCndcNrLt5Y5SDobFQbjtCaQ?view_as=subscriber

          flype

            #255134

            @lexomil

            Merci pour les conseils.

            J’ai réécris la routine pour avoir un meilleur aspect, c’est plus gourmand mais plus beau, de toutes façons j’ai un peu de marge :). J’ai aussi fusionné les routines FireUpdate et FireDraw en une seule routine afin de calculer le feu directement depuis le buffer de l’écran, en 1×1. Il n’y a plus beaucoup de place pour des optimisations :

            DrawFire:
                  movem.l d0-d4/a0,-(sp)       ; Store registers
                  move.l  _FirePower,d4        ; Get power
                  move.l  _CgxBaseAddress,a0   ; Get screen
                  move.w  #SCRH-1,d0           ; y < height-1
            .loopY                             ; For y
                  move.w  #SCRW-2,d1           ; x < width-2
                  clr.w   d2                   ; Reset Pixel
            .loopX                             ; For x                  ; CLK Pipe 
                  clr.w   d3                   ; Reset Color            ; 1   0    
                  move.b  SCRW*1-0(a0),d2      ; Pixel = Pixel(x+0,y+1) ; 1   1    
                  add.l   d2,d3                ; Color + Pixel          ; 2   0    
                  move.b  SCRW*3-0(a0),d2      ; Pixel = Pixel(x+0,y+3) ; 2   1    
                  add.l   d2,d3                ; Color + Pixel          ; 3   0    
                  move.b  SCRW*2-1(a0),d2      ; Pixel = Pixel(x-1,y+2) ; 3   1    
                  add.l   d2,d3                ; Color + Pixel          ; 4   0    
                  move.b  SCRW*2+1(a0),d2      ; Pixel = Pixel(x+1,y+2) ; 4   1    
                  add.l   d2,d3                ; Color + Pixel          ; 5   0    
                  add.l   d4,d3                ; Color + Power          ; 6   0    
                  lsr.w   #2,d3                ; Color >> 2             ; 7   0    
                  beq.s   .next                ; If Color > 0 {         ; 8   0    
                  subq.b  #1,d3                ;   Color--              ; 8   1    
              .next                            ; }                                 
                  move.b  d3,(a0)+             ; Pixel(x,y) = Color     ; 9   0    
                  dbf     d1,.loopX            ; Next x                 ; 9   1 /10
                  addq.l  #1,a0                ; Screen++
                  dbf     d0,.loopY            ; Next y
                  movem.l (sp)+,d0-d4/a0       ; Restore registers
                  rts                          ; Return
            

            La routine ci-dessus tourne à environ 100 frames par seconde en full screen 320x240x8bits sur ma Vampire, grandement aidé par les accès mémoire très rapides de cette dernière et par l’exécution superscalar (2 pipes).

            A600 Rev 1.5 + Vampire 600 V2-128.
            A1200 Rev 1D4 + Blizzard 1230 III/50Mhz + 68882 + 256MB @ 50ns.

            Jul

              #255196

              @Flype :

              Est-ce que des outils de développement (des assembleurs, lesquels) ont été adaptés aux nouvelles instructions du Core Apollo ? Par exemple aux instructions sur 64 bits ?

              Je crois que quand les versions pour A500 et A1200 seront disponibles, je vais me laisser tenter. 🙂

              Prédateur Chess | Amiga 500 + ACA500 | Amiga 1200 + ACA1233

              flype

                #255218

                @Jul
                Pour le moment non :\ Un candidat serait probablement ASM-One car il est relativement à jour, j’ai une version 1.49-RC2 de 2008, donc c’est pas si vieux que çà. Pour Devpac, c’est mort, source fermé. Ensuite GnuASM est aussi un très bon candidat et sans aucun doute le plus ‘facile’ a adapter pour Gunnar.

                Ceci dit, il est possible, je l’ai testé, d’écrire des macros en assembleur pour exécuter les nouvelles instructions, et de fait, çà marche avec n’importe quel compilateur. Une instruction étant une suite de bits, c’est pas très compliqué. Il faut être bien documenté surtout. Une include de macros bien foutues sera la bienvenue dans un premier temps.

                A part çà, une ch’tite vidéo ? 🙂 allez go…

                (MystiCube, écran RTG 640x480x16bits ==> 40/50fps, écran RTG 640x480x8bits ==> 100/110fps)

                A600 Rev 1.5 + Vampire 600 V2-128.
                A1200 Rev 1D4 + Blizzard 1230 III/50Mhz + 68882 + 256MB @ 50ns.

                Anonyme

                  #255270

                  Driver P96 retiré pour l’instant. Certains points de licencing et choix stratégiques doivent être étudiés sereinement avant de le diffuser largement.

                  ntsc

                    #255296

                    @flype : j’ai vu tes videos de demo aga sur youtube. ca gere l’aga cette carte ? ou j’ai loupé un episode  🙂

                    fhtagn

                      #255299

                      @ntsc Il me semble que ce sont des demos RTG, pas besoin d’aga.

                       

                      L’aga sera pour le GOLD core.

                       

                      Edit : toutes mes confuses, POUET indique que ce sont bien des demos aga !

                       

                      Edit 2 : Par contre A.D.A les listes dans aga/gfx.

                      http://ada.untergrund.net/?p=demo&i=132

                      http://ada.untergrund.net/?p=demo&i=251

                      Edit 3 (le retour dela revanche du fils) : Sinon il y a Machinist d’Elude qui est 060 et RTG proof

                      flype

                        #255611

                        Pouet se trompe, ou du moins ne précise pas assez. Ce sont bien des démos 100% os-friendly, RTG. AGA certes, s’il est présent. Beaucoup de démos propose un mode RTG. Beaucoup moins sont RTG et sans FPU. Mais il y a de quoi s’amuser quand même.

                        Podcast tout frais d’une interview de Gunnar :

                        http://amicast.ppa.pl/podcast/10.jpg

                        http://www.amigapodcast.com/2016/02/amicast-episode-10-biggun-apollo-team.html

                        A600 Rev 1.5 + Vampire 600 V2-128.
                        A1200 Rev 1D4 + Blizzard 1230 III/50Mhz + 68882 + 256MB @ 50ns.

                        flype

                          #255612

                          Machinist d’Elude a besoin d’un FPU :\

                          A600 Rev 1.5 + Vampire 600 V2-128.
                          A1200 Rev 1D4 + Blizzard 1230 III/50Mhz + 68882 + 256MB @ 50ns.

                          fhtagn

                            #255614

                            Je m’en suis douté après.

                            Par contre c’est dommage que les demo makers  ne semblent pas intéressés.

                            flype

                              #255626

                              Il est bien trop tôt pour tirer des conclusions. La carte n’est pas encore assez diffusée pour çà ; et c’est sûr que les demomakers apprécieront avoir un FPU.

                              Je suis curieux de savoir ce que pense @Jul de cette interview ; s’il pense toujours que c’est de la banale émulation. Perso, j’ai trouvé l’interview plutôt intéressante, et il parle même de mon fire effect à un moment.

                              A600 Rev 1.5 + Vampire 600 V2-128.
                              A1200 Rev 1D4 + Blizzard 1230 III/50Mhz + 68882 + 256MB @ 50ns.

                              Jul

                                #255632

                                @Flype :

                                J’avais commencé à écouter, mais comme je suis en pleines corrections de copies de partiels, je ne peux pas passer deux heures sur ce podcast : ça va devoir attendre le week-end prochain.

                                Mais attention, en écrivant « banale émulation » tu mets une nuance péjorative que je n’ai jamais mise. 🙂

                                Je me borne à dire que le fait que le FPGA doive être programmé (que toutes ses portes logiques doivent être « configurées » sur des positions précises, si tu préfères) cela fait du Core Apollo un émulateur, techniquement, le FPGA étant quant à lui la machine hébergeant l’émulateur.

                                PC -> WinUAE -> Amiga émulé
                                FPGA -> Apollo -> Amiga émulé (ou plutôt 68k + autres périphériques)

                                Cela rend, pour moi, l’expérience un peu moins originale qu’avec un vrai 68k gravé. Mais cela est compensé par la vitesse apportée, les modes graphiques, et le fait que cela utilise le vrai matériel de l’Amiga tout autour. On doit vite oublier que c’est un FPGA qui anime tout ça. Comme je l’ai dit plus haut, j’en acquerrai volontiers un pour mon A500 et un autre pour mon A1200. 🙂

                                Prédateur Chess | Amiga 500 + ACA500 | Amiga 1200 + ACA1233

                                __sam__

                                  #255633

                                  Je me demande si la FPU est vraiment nécessaire. En embarqué les fpu ne sont pas souvent présente et on utilise les opérations « fixed point ». En 32bits la précision est suffisante pour pas mal de trucs, et en 64bits le fixed-point devient super efficace.

                                  Je me borne à dire que le fait que le FPGA doive être programmé (que toutes ses portes logiques doivent être « configurées » sur des positions précises, si tu préfères) cela fait du Core Apollo un émulateur, techniquement, le FPGA étant quant à lui la machine hébergeant l’émulateur.

                                  Techniquement un « émulateur »: Non pas du tout! Tout se programme dans l’électronique de nos jours. On utilise plus des cpu à brancher sur une carte mère. Par exemple, sais tu que ARM ne fournit aucun chip à plugger sur une carte mère de telephone, de raspberry ou autre. Non il fournit un code source qui programme les portes logiques pour avoir les fonctions armv7 ou armv8. Tout marche comme ca en electronique et personne ne parle d’émulation armv7 ou v8. Il n’y a que toi qui persiste à appeler émulation ce qui est de l’électronique moderne.

                                  Samuel.

                                  Amiga A500 + GVP530 (8Mo/fpu/mmu/scsi) - en panne 🙁
                                  A500 (+ 1Mo PPS), A1200 (Blizzard-IV/fpu/64Mo)
                                  A500 Vampire V2+ ^8^ 🙂
                                  (mais aussi TO8, TO8D, TO9. Groupe PULS.)

                                15 sujets de 901 à 915 (sur un total de 1,122)

                                • Vous devez être connecté pour répondre à ce sujet.

                                Forums AmigaOS, MorphOS et AROS Matériel Vampire et Phoenix Core

                                Amiga Impact