SPI sending function The 2019 Stack Overflow Developer Survey Results Are InSPI to soft UARTMonitor/Debug SPI using another GPIO Pin?SPI sclk no outputHelp understanding + hacking spi-bcm2708.cCan Raspberry PI function as SPI slave?SPI device errorfilenotfounderror with SPI functionConnect SPI display to raspberry pi zeroWhat's wrong with my SPI interface?How could I write a C function using the wiringPi SPI library to read the X and Y measurements from this 2-axis inclinometer?

The phrase "to the numbers born"?

Did Scotland spend $250,000 for the slogan "Welcome to Scotland"?

Does a dangling wire really electrocute me if I'm standing in water?

Why are there uneven bright areas in this photo of black hole?

Outer glow on 3 sides of a rectangular shape

What does Linus Torvalds mean when he says that Git "never ever" tracks a file?

Loose spokes after only a few rides

When should I buy a clipper card after flying to Oakland?

Are spiders unable to hurt humans, especially very small spiders?

Is an up-to-date browser secure on an out-of-date OS?

Time travel alters history but people keep saying nothing's changed

Can a flute soloist sit?

Why doesn't shell automatically fix "useless use of cat"?

Why doesn't mkfifo with a mode of 1755 grant read permissions and sticky bit to the user?

Right tool to dig six foot holes?

Ubuntu Server install with full GUI

What to expect from an e-bike service?

How to type a long/em dash `—`

Can there be female White Walkers?

Is it okay to consider publishing in my first year of PhD?

How can I refresh a custom data tab in the contact summary?

Why is the Constellation's nose gear so long?

How can I define good in a religion that claims no moral authority?

Why isn't the circumferential light around the M87 black hole's event horizon symmetric?



SPI sending function



The 2019 Stack Overflow Developer Survey Results Are InSPI to soft UARTMonitor/Debug SPI using another GPIO Pin?SPI sclk no outputHelp understanding + hacking spi-bcm2708.cCan Raspberry PI function as SPI slave?SPI device errorfilenotfounderror with SPI functionConnect SPI display to raspberry pi zeroWhat's wrong with my SPI interface?How could I write a C function using the wiringPi SPI library to read the X and Y measurements from this 2-axis inclinometer?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








1















I'm currently reworking a project from someone who graduated a few years back and I'm supposed to change the function of his work for a bit.



I have trouble understanding these few lines from SPI communication, how does this work? :



 *ptr = (3<<4) | (1<<7); //clear
*(ptr +SPI_FIFO) = udata2>>8;
*(ptr +SPI_FIFO) = udata2;
while (!(*ptr & (1 << 16))); // Transfer DONE

*ptr &= ~(1<<7);

*ptr = (3<<4) | (1<<7) | (1<<0); //clear
*(ptr +SPI_FIFO) = udata1>>8;
*(ptr +SPI_FIFO) = udata1;
while (!(*ptr & (1<<16))); // Transfer DONE
*ptr &= ~(1<<7);


To explain what I know: The function 'send' expects 2 float values in interval <-1;1> and through circuits it changes output voltage from minimum of -12.5V to maximum of 12.5V.
When I tried to send various values to function from interval it got stuck on:



 while (!(*ptr & (1 << 16)));


As I investigated the code more I realized that either I'm dumb or the person who wrote this is dumb because how does this work ?



 *(ptr +SPI_FIFO) = udata2>>8;
*(ptr +SPI_FIFO) = udata2;


Any help is appreciated.
Thank you.



If needed the whole code is below.



SPI.h:



#include <sys/mman.h>
#include <fcntl.h>
#include <unistd.h>


#ifndef _SPI
#define _SPI

#define IOBASE 0x20000000
#define GPIO_BASE (IOBASE + 0x200000)
#define SPI0_BASE (IOBASE + 0x204000)
#define TIMER_BASE (IOBASE + 0x3000)

//SPI
#define SPI_CS 0
#define SPI_FIFO 1
#define SPI_CLK 2
#define SPI_DLEN 3
#define SPI_LTOH 4
#define SPI_DC 5



class SPI

int fd;
volatile unsigned int* ptr;
volatile unsigned int* uk_GPIO;
public:
SPI();
~SPI();
void inline send(float, float);
int connected(void);
;

#endif


SPI.cpp:



#include "SPI.h"
#include <cstdlib>

SPI::SPI()
O_SYNC) ) < 0)

ptr = 0;
printf("SPI ERROR");
return;

ptr = (volatile unsigned int *)mmap(NULL,4096,PROT_READ

void inline SPI::send(float data1, float data2)
(1<<7)
SPI::~SPI()

munmap((void*)ptr,4096);
close(fd);


int SPI::connected(void)
uk_GPIO == 0)
return -1;
else
return 1;











share|improve this question






























    1















    I'm currently reworking a project from someone who graduated a few years back and I'm supposed to change the function of his work for a bit.



    I have trouble understanding these few lines from SPI communication, how does this work? :



     *ptr = (3<<4) | (1<<7); //clear
    *(ptr +SPI_FIFO) = udata2>>8;
    *(ptr +SPI_FIFO) = udata2;
    while (!(*ptr & (1 << 16))); // Transfer DONE

    *ptr &= ~(1<<7);

    *ptr = (3<<4) | (1<<7) | (1<<0); //clear
    *(ptr +SPI_FIFO) = udata1>>8;
    *(ptr +SPI_FIFO) = udata1;
    while (!(*ptr & (1<<16))); // Transfer DONE
    *ptr &= ~(1<<7);


    To explain what I know: The function 'send' expects 2 float values in interval <-1;1> and through circuits it changes output voltage from minimum of -12.5V to maximum of 12.5V.
    When I tried to send various values to function from interval it got stuck on:



     while (!(*ptr & (1 << 16)));


    As I investigated the code more I realized that either I'm dumb or the person who wrote this is dumb because how does this work ?



     *(ptr +SPI_FIFO) = udata2>>8;
    *(ptr +SPI_FIFO) = udata2;


    Any help is appreciated.
    Thank you.



    If needed the whole code is below.



    SPI.h:



    #include <sys/mman.h>
    #include <fcntl.h>
    #include <unistd.h>


    #ifndef _SPI
    #define _SPI

    #define IOBASE 0x20000000
    #define GPIO_BASE (IOBASE + 0x200000)
    #define SPI0_BASE (IOBASE + 0x204000)
    #define TIMER_BASE (IOBASE + 0x3000)

    //SPI
    #define SPI_CS 0
    #define SPI_FIFO 1
    #define SPI_CLK 2
    #define SPI_DLEN 3
    #define SPI_LTOH 4
    #define SPI_DC 5



    class SPI

    int fd;
    volatile unsigned int* ptr;
    volatile unsigned int* uk_GPIO;
    public:
    SPI();
    ~SPI();
    void inline send(float, float);
    int connected(void);
    ;

    #endif


    SPI.cpp:



    #include "SPI.h"
    #include <cstdlib>

    SPI::SPI()
    O_SYNC) ) < 0)

    ptr = 0;
    printf("SPI ERROR");
    return;

    ptr = (volatile unsigned int *)mmap(NULL,4096,PROT_READ

    void inline SPI::send(float data1, float data2)
    (1<<7)
    SPI::~SPI()

    munmap((void*)ptr,4096);
    close(fd);


    int SPI::connected(void)
    uk_GPIO == 0)
    return -1;
    else
    return 1;











    share|improve this question


























      1












      1








      1








      I'm currently reworking a project from someone who graduated a few years back and I'm supposed to change the function of his work for a bit.



      I have trouble understanding these few lines from SPI communication, how does this work? :



       *ptr = (3<<4) | (1<<7); //clear
      *(ptr +SPI_FIFO) = udata2>>8;
      *(ptr +SPI_FIFO) = udata2;
      while (!(*ptr & (1 << 16))); // Transfer DONE

      *ptr &= ~(1<<7);

      *ptr = (3<<4) | (1<<7) | (1<<0); //clear
      *(ptr +SPI_FIFO) = udata1>>8;
      *(ptr +SPI_FIFO) = udata1;
      while (!(*ptr & (1<<16))); // Transfer DONE
      *ptr &= ~(1<<7);


      To explain what I know: The function 'send' expects 2 float values in interval <-1;1> and through circuits it changes output voltage from minimum of -12.5V to maximum of 12.5V.
      When I tried to send various values to function from interval it got stuck on:



       while (!(*ptr & (1 << 16)));


      As I investigated the code more I realized that either I'm dumb or the person who wrote this is dumb because how does this work ?



       *(ptr +SPI_FIFO) = udata2>>8;
      *(ptr +SPI_FIFO) = udata2;


      Any help is appreciated.
      Thank you.



      If needed the whole code is below.



      SPI.h:



      #include <sys/mman.h>
      #include <fcntl.h>
      #include <unistd.h>


      #ifndef _SPI
      #define _SPI

      #define IOBASE 0x20000000
      #define GPIO_BASE (IOBASE + 0x200000)
      #define SPI0_BASE (IOBASE + 0x204000)
      #define TIMER_BASE (IOBASE + 0x3000)

      //SPI
      #define SPI_CS 0
      #define SPI_FIFO 1
      #define SPI_CLK 2
      #define SPI_DLEN 3
      #define SPI_LTOH 4
      #define SPI_DC 5



      class SPI

      int fd;
      volatile unsigned int* ptr;
      volatile unsigned int* uk_GPIO;
      public:
      SPI();
      ~SPI();
      void inline send(float, float);
      int connected(void);
      ;

      #endif


      SPI.cpp:



      #include "SPI.h"
      #include <cstdlib>

      SPI::SPI()
      O_SYNC) ) < 0)

      ptr = 0;
      printf("SPI ERROR");
      return;

      ptr = (volatile unsigned int *)mmap(NULL,4096,PROT_READ

      void inline SPI::send(float data1, float data2)
      (1<<7)
      SPI::~SPI()

      munmap((void*)ptr,4096);
      close(fd);


      int SPI::connected(void)
      uk_GPIO == 0)
      return -1;
      else
      return 1;











      share|improve this question
















      I'm currently reworking a project from someone who graduated a few years back and I'm supposed to change the function of his work for a bit.



      I have trouble understanding these few lines from SPI communication, how does this work? :



       *ptr = (3<<4) | (1<<7); //clear
      *(ptr +SPI_FIFO) = udata2>>8;
      *(ptr +SPI_FIFO) = udata2;
      while (!(*ptr & (1 << 16))); // Transfer DONE

      *ptr &= ~(1<<7);

      *ptr = (3<<4) | (1<<7) | (1<<0); //clear
      *(ptr +SPI_FIFO) = udata1>>8;
      *(ptr +SPI_FIFO) = udata1;
      while (!(*ptr & (1<<16))); // Transfer DONE
      *ptr &= ~(1<<7);


      To explain what I know: The function 'send' expects 2 float values in interval <-1;1> and through circuits it changes output voltage from minimum of -12.5V to maximum of 12.5V.
      When I tried to send various values to function from interval it got stuck on:



       while (!(*ptr & (1 << 16)));


      As I investigated the code more I realized that either I'm dumb or the person who wrote this is dumb because how does this work ?



       *(ptr +SPI_FIFO) = udata2>>8;
      *(ptr +SPI_FIFO) = udata2;


      Any help is appreciated.
      Thank you.



      If needed the whole code is below.



      SPI.h:



      #include <sys/mman.h>
      #include <fcntl.h>
      #include <unistd.h>


      #ifndef _SPI
      #define _SPI

      #define IOBASE 0x20000000
      #define GPIO_BASE (IOBASE + 0x200000)
      #define SPI0_BASE (IOBASE + 0x204000)
      #define TIMER_BASE (IOBASE + 0x3000)

      //SPI
      #define SPI_CS 0
      #define SPI_FIFO 1
      #define SPI_CLK 2
      #define SPI_DLEN 3
      #define SPI_LTOH 4
      #define SPI_DC 5



      class SPI

      int fd;
      volatile unsigned int* ptr;
      volatile unsigned int* uk_GPIO;
      public:
      SPI();
      ~SPI();
      void inline send(float, float);
      int connected(void);
      ;

      #endif


      SPI.cpp:



      #include "SPI.h"
      #include <cstdlib>

      SPI::SPI()
      O_SYNC) ) < 0)

      ptr = 0;
      printf("SPI ERROR");
      return;

      ptr = (volatile unsigned int *)mmap(NULL,4096,PROT_READ

      void inline SPI::send(float data1, float data2)
      (1<<7)
      SPI::~SPI()

      munmap((void*)ptr,4096);
      close(fd);


      int SPI::connected(void)
      uk_GPIO == 0)
      return -1;
      else
      return 1;








      gpio spi c++ c






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Mar 30 at 9:39







      Dominik Ficek

















      asked Mar 30 at 9:11









      Dominik FicekDominik Ficek

      83




      83




















          1 Answer
          1






          active

          oldest

          votes


















          2














          You need to refer to the BCM2835 ARM Peripherals document.



          It specifies many of the Pi's hardware interfaces.



          In this case SPI appears to be the main SPI device documented from page 148.



          *ptr = (3<<4) | (1<<7); // 1
          *(ptr +SPI_FIFO) = udata2>>8; // 2
          *(ptr +SPI_FIFO) = udata2; // 3
          while (!(*ptr & (1 << 16))); // 4


          ptr is a word pointer(32 bits) to the base of the SPI registers (the CS register).



          1. clears the FIFOs and starts SPI.

          2. writes the MSB of udata2 to the hardware FIFO.

          3. writes the LSB of udata2 to the hardware FIFO.

          4. spins until the CS register indicates the transfer is complete.

          Note that writing to the hardware FIFO address adds a byte to the transmit FIFO, reading from the hardware FIFO address removes a byte from the receive FIFO.



          It may be worthwhile to point out that this code may have been written before the availability of the Pi Linux SPI driver. I would suggest you now use the Linux SPI driver.






          share|improve this answer























          • Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

            – Dominik Ficek
            Mar 30 at 11:21











          • Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

            – joan
            Mar 30 at 11:25











          • I would highly recommend switching to the available linux driver if possible

            – crasic
            Mar 31 at 6:44











          Your Answer






          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("schematics", function ()
          StackExchange.schematics.init();
          );
          , "cicuitlab");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "447"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fraspberrypi.stackexchange.com%2fquestions%2f95968%2fspi-sending-function%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          2














          You need to refer to the BCM2835 ARM Peripherals document.



          It specifies many of the Pi's hardware interfaces.



          In this case SPI appears to be the main SPI device documented from page 148.



          *ptr = (3<<4) | (1<<7); // 1
          *(ptr +SPI_FIFO) = udata2>>8; // 2
          *(ptr +SPI_FIFO) = udata2; // 3
          while (!(*ptr & (1 << 16))); // 4


          ptr is a word pointer(32 bits) to the base of the SPI registers (the CS register).



          1. clears the FIFOs and starts SPI.

          2. writes the MSB of udata2 to the hardware FIFO.

          3. writes the LSB of udata2 to the hardware FIFO.

          4. spins until the CS register indicates the transfer is complete.

          Note that writing to the hardware FIFO address adds a byte to the transmit FIFO, reading from the hardware FIFO address removes a byte from the receive FIFO.



          It may be worthwhile to point out that this code may have been written before the availability of the Pi Linux SPI driver. I would suggest you now use the Linux SPI driver.






          share|improve this answer























          • Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

            – Dominik Ficek
            Mar 30 at 11:21











          • Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

            – joan
            Mar 30 at 11:25











          • I would highly recommend switching to the available linux driver if possible

            – crasic
            Mar 31 at 6:44















          2














          You need to refer to the BCM2835 ARM Peripherals document.



          It specifies many of the Pi's hardware interfaces.



          In this case SPI appears to be the main SPI device documented from page 148.



          *ptr = (3<<4) | (1<<7); // 1
          *(ptr +SPI_FIFO) = udata2>>8; // 2
          *(ptr +SPI_FIFO) = udata2; // 3
          while (!(*ptr & (1 << 16))); // 4


          ptr is a word pointer(32 bits) to the base of the SPI registers (the CS register).



          1. clears the FIFOs and starts SPI.

          2. writes the MSB of udata2 to the hardware FIFO.

          3. writes the LSB of udata2 to the hardware FIFO.

          4. spins until the CS register indicates the transfer is complete.

          Note that writing to the hardware FIFO address adds a byte to the transmit FIFO, reading from the hardware FIFO address removes a byte from the receive FIFO.



          It may be worthwhile to point out that this code may have been written before the availability of the Pi Linux SPI driver. I would suggest you now use the Linux SPI driver.






          share|improve this answer























          • Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

            – Dominik Ficek
            Mar 30 at 11:21











          • Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

            – joan
            Mar 30 at 11:25











          • I would highly recommend switching to the available linux driver if possible

            – crasic
            Mar 31 at 6:44













          2












          2








          2







          You need to refer to the BCM2835 ARM Peripherals document.



          It specifies many of the Pi's hardware interfaces.



          In this case SPI appears to be the main SPI device documented from page 148.



          *ptr = (3<<4) | (1<<7); // 1
          *(ptr +SPI_FIFO) = udata2>>8; // 2
          *(ptr +SPI_FIFO) = udata2; // 3
          while (!(*ptr & (1 << 16))); // 4


          ptr is a word pointer(32 bits) to the base of the SPI registers (the CS register).



          1. clears the FIFOs and starts SPI.

          2. writes the MSB of udata2 to the hardware FIFO.

          3. writes the LSB of udata2 to the hardware FIFO.

          4. spins until the CS register indicates the transfer is complete.

          Note that writing to the hardware FIFO address adds a byte to the transmit FIFO, reading from the hardware FIFO address removes a byte from the receive FIFO.



          It may be worthwhile to point out that this code may have been written before the availability of the Pi Linux SPI driver. I would suggest you now use the Linux SPI driver.






          share|improve this answer













          You need to refer to the BCM2835 ARM Peripherals document.



          It specifies many of the Pi's hardware interfaces.



          In this case SPI appears to be the main SPI device documented from page 148.



          *ptr = (3<<4) | (1<<7); // 1
          *(ptr +SPI_FIFO) = udata2>>8; // 2
          *(ptr +SPI_FIFO) = udata2; // 3
          while (!(*ptr & (1 << 16))); // 4


          ptr is a word pointer(32 bits) to the base of the SPI registers (the CS register).



          1. clears the FIFOs and starts SPI.

          2. writes the MSB of udata2 to the hardware FIFO.

          3. writes the LSB of udata2 to the hardware FIFO.

          4. spins until the CS register indicates the transfer is complete.

          Note that writing to the hardware FIFO address adds a byte to the transmit FIFO, reading from the hardware FIFO address removes a byte from the receive FIFO.



          It may be worthwhile to point out that this code may have been written before the availability of the Pi Linux SPI driver. I would suggest you now use the Linux SPI driver.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Mar 30 at 10:12









          joanjoan

          50.5k35183




          50.5k35183












          • Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

            – Dominik Ficek
            Mar 30 at 11:21











          • Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

            – joan
            Mar 30 at 11:25











          • I would highly recommend switching to the available linux driver if possible

            – crasic
            Mar 31 at 6:44

















          • Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

            – Dominik Ficek
            Mar 30 at 11:21











          • Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

            – joan
            Mar 30 at 11:25











          • I would highly recommend switching to the available linux driver if possible

            – crasic
            Mar 31 at 6:44
















          Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

          – Dominik Ficek
          Mar 30 at 11:21





          Thank you this is certainly helpful. I have one more question, what is it that changes the value of CS register so it indicates the completion of transfer? I'm clearly stuck at that, I never leave the 4th point.

          – Dominik Ficek
          Mar 30 at 11:21













          Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

          – joan
          Mar 30 at 11:25





          Bit 16 being set in the CS register indicates the transfer is complete. See page 154. The hardware sets it.

          – joan
          Mar 30 at 11:25













          I would highly recommend switching to the available linux driver if possible

          – crasic
          Mar 31 at 6:44





          I would highly recommend switching to the available linux driver if possible

          – crasic
          Mar 31 at 6:44

















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Raspberry Pi Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fraspberrypi.stackexchange.com%2fquestions%2f95968%2fspi-sending-function%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Adding axes to figuresAdding axes labels to LaTeX figuresLaTeX equivalent of ConTeXt buffersRotate a node but not its content: the case of the ellipse decorationHow to define the default vertical distance between nodes?TikZ scaling graphic and adjust node position and keep font sizeNumerical conditional within tikz keys?adding axes to shapesAlign axes across subfiguresAdding figures with a certain orderLine up nested tikz enviroments or how to get rid of themAdding axes labels to LaTeX figures

          Luettelo Yhdysvaltain laivaston lentotukialuksista Lähteet | Navigointivalikko

          Gary (muusikko) Sisällysluettelo Historia | Rockin' High | Lähteet | Aiheesta muualla | NavigointivalikkoInfobox OKTuomas "Gary" Keskinen Ancaran kitaristiksiProjekti Rockin' High