7. PISA+ - FRA FORSKNINGSSPØRSMÅL TIL FYSISK UTSTYR
7.8 T ILGJENGELIGHET OG ANALYSE AV FORSKNINGSDATAENE
customizar a lógica de controle interno do sistema de referência, ou seja, o projeto embutido de fábrica.
A customização do hardware descrito em (ALTERA2, 2003) é necessária pois o mesmo apenas efetua transações de escrita e leitura na memória DDR do kit FPGA, nada mais que isso. Para a aplicação proposta, além de efetuar as transações descritas, é necessário o processamento dos dados que chegam na memória do kit.
Dessa forma, foi necessário o desenvolvimento de uma lógica interna para o controle do processamento dos dados da memória do kit, cujo o fluxo é o seguinte: ‐ Os dados serão enviados via software para a memória DDR do kit;
‐ Após o dado estar completamente na memória, a lógica customizada deverá acessá-lo, efetuar seu devido processamento e retornar seu resultado novamente na memória;
‐ Por fim, o trecho de memória com os resultados é passado para o barramento PCI. A Figura 4.2 mostra o diagrama de blocos da idealização do sistema customizado.
Figura 4.2. Diagrama de blocos da customização projeto de referência do kit FPGA.
Inicialmente, o dado será inserido no sistema por meio dos sinais do barramento
PCI através da lógica de controle da interface PCI e, em seguida, será tratado pela
Inserido na lógica de controle interno, o dado é passado à lógica de controle preexistente do projeto de referência. Essa lógica efetua o controle das operações de E/S de dados da memória DDR do kit de prototipação, pois atua diretamente sobre os sinais da lógica de controle da memória. Assim, conclui-se o ciclo completo do sistema original do kit, representado pelos blocos azuis e suas interconexões, onde as operações efetuadas pelo sistema são simples transações de E/S de dados da memória DDR do kit. Contudo, deseja-se efetuar o cálculo, já amplamente discutido em todo este texto, da
Distância L2 e para tanto se fazem necessárias novas lógicas a serem inseridas no
sistema, que são aquelas representadas em laranja e suas interconexões.
O bloco Registrador de Controle fará a interceptação dos sinais da lógica de controle preexistente que estão à caminho da memória. Nessa interceptação verificará se houve a inserção, no módulo DDR, dos dados necessários para o cálculo da Distância
L2: a janela de busca e o vetor NxNi. Caso seja verificada a inserção dos dados
pretendidos, o Registrador de Controle ativa o bloco de Controle de Dados e este, por sua vez, fará o controle da informação da memória que será enviada para efetuar o cálculo no bloco Distância L2. Concluído o cálculo desejado, o Controle de Dados envia os valores calculados para a memória do kit para que sejam resgatados pelo software através da lógica de controle preexistente, finalizando o processo desempenhado pelo hardware pretendido.
Para que o Registrador de Controle tenha conhecimento de um dado pronto para ser processado em memória, antes de tudo ele necessita verificar o valor do código da variável compartilhada com o software.
No hardware, o espaço determinado para a variável compartilhada foi o endereço zero da memória DDR. Portanto, quando o software alterar o valor da variável compartilhada, este valor será inserido no endereço zero da memória do kit. Após inserir o dado a ser processado na memória do hardware, o software irá lançar no endereço zero o código (0x00000000 00000001) para que o bloco Distancia L2 inicie seu cálculo através do desvio do fluxo do sistema para o processamento interno do bloco Controle de Dados. Após o término do processamento, será lançado para o endereço zero o código de permissão de leitura da memória do kit (0x00000000 00000000).
Sendo assim, o trabalho desempenhado pelo Registrador de Controle é verificar o valor que está sendo lançado no espaço reservado para a variável compartilhada, responsável pelo desvio do fluxo do hardware para o processamento do dado em
memória, através da ativação e desativação de circuitos multiplexadores desenvolvidos, e pelo retorno ao fluxo original do sistema em hardware, através da finalização do processamento do bloco Controle de Dados. Tal lógica foi condensada no módulo
Registrador de Controle representado na Figura 4.3.
Figura 4.3. Bloco Registrador de Controle.
Na Figura 4.3 observamos sinais de entrada azuis e vermelhos. Os sinais em azul representam sinais interceptados da arquitetura interna do projeto de referencia (ALTERA2, 2003). Os sinais vermelhos foram criados para o controle do processamento do bloco Controle de Dados.
O módulo Registrador de Controle desempenha a execução da máquina de estados que obedece à descrição da Figura 4.4. A figura obedece à descrição de uma
Máquina de Mealy onde a entrada S refere-se ao estado de entrada e a saída SP indica o
Figura 4.4. Máquina de estados do módulo Registrador de Controle. Os estados da máquina descrita na Figura 4.4 são brevemente descritos abaixo: ‐ S0: Verifica Transação de Memória. Neste estado a máquina verifica a ativação dos sinais necessários para se haver um pedido de escrita no endereço zero da memória do kit, espaço da variável compartilhada. Caso haja a ativação dos sinais, vai para o estado S1. Caso contrário, continua na espera da ativação dos sinais;
‐ S1: Espera Escrita na Variável Compartilhada. Neste momento a máquina espera apenas que o valor da variável compartilhada seja escrito. Terminada a escrita, a máquina migra para o estado S2;
‐ S2: Verifica Conteúdo da Variável Compartilhada. Neste estado a máquina trata o valor presente na variável compartilhada. Caso haja o código de processamento dos dados da memória (código 0x00000000 00000001), ativa os circuitos multiplexadores que altera o fluxo do sistema para o bloco Controle de Dados e espera o fim do processamento do mesmo indo para o estado S3. Caso contrário, vai para o estado S0 e espera uma nova transação de escrita no endereço zero;
‐ S3: Espera Processamento. Neste momento a máquina aguarda a finalização do bloco Controle de Dados. Finalizado o processamento, a máquina desativa os circuitos multiplexadores e retorna para o estado inicial esperando uma nova escrita na variável compartilhada.
Para o sistema em hardware pretendido concluir suas atividades, é necessário o auxílio do bloco Controle de Dados, que efetua a transferência dos dados da memória
DDR do kit para o bloco Distância L2 efetuar o seu processamento. O módulo Controle de Dados é representado pelo diagrama de bloco da Figura 4.5.
Figura 4.5. Bloco Controle de Dados.
Na Figura 4.5 observamos sinais de entrada azuis e vermelhos. Os sinais em azul representam sinais interceptados da arquitetura interna do projeto de referencia (ALTERA2, 2003). Os sinais vermelhos foram criados para o controle de seu processamento por meio do bloco Registrador de Controle.
O módulo Controle de Dados desempenha a execução da máquina de estados que obedece à descrição da Figura 4.6. A figura obedece à descrição de uma Máquina de
Mealy onde a entrada S refere-se ao estado de entrada e a saída SP indica o próximo
Figura 4.6. Máquina de estados do processamento do módulo Controle de Dados.
Os estados da máquina descrita na Figura 4.6 são brevemente descritos abaixo: ‐ S0: Verifica Permissão. Verifica se o Registrador de Controle liberou a permissão de processamento. Lembrando que o Registrador de Controle se baseia no valor da variável compartilhada. Caso haja permissão de processamento, a máquina vai para o próximo estado, se não continua no estado atual até haver permissão de processamento em hardware;
‐ S1: Verifica Dado. Neste estado a máquina inicia o procedimento de pegar os dados da memória e processá-los caso ainda haja dados a serem processados em memória;
‐ S2: Verifica Sinal local_ready. O estado verifica se ainda há dado a ser processado na memória, aguarda o sinal local_ready estar ativado e vai para o estado
S3. Enquanto o sinal local_ready não é ativado, a máquina permanece neste estado a
cada ciclo;
handshake de escrita dos valores requisitados pelo bloco Distancia L2 (vetor NxNi e
janela de busca). Caso ainda haja dados a serem enviados para o bloco Distancia L2, a máquina retorna para o estado S1. Caso não haja mais dados para efetuar o handshake de escrita, a máquina vai para o estado S4 para aguardar os resultados do bloco
Distância L2;
‐ S4: Inicia Handshake de Leitura. Aqui a máquina inicia o processo de handshake de leitura com o bloco Distância L2 (resultados do cálculo da Distância L2). Após cada
rajada do processo de handshake efetuada, a máquina vai para o estado S5 para iniciar o processo de escrita dos valores na memória;
‐ S5: Verifica Permissão de Escrita de Dado. Espera o sinal de permissão de escrita de dado estar ativado para iniciar a escrita no ciclo posterior. Tendo inserido os valores provenientes do cálculo da Distância L2 na memória DDR do kit, a máquina se
direciona novamente para o estado S4 caso haja valores ainda por serem recebidos do bloco Distancia L2. Caso tenha finalmente cessado o fluxo de dados vindos do
Distancia L2, vai ao estado S6;
‐ S6: Finaliza Processamento. Prepara os sinais da arquitetura para finalizar a atividade da máquina para o processamento atual, prepara o código de finalização do processamento em hardware (0x00000000 00000000) para escrevê-lo na variável e vai para o estado S0 para aguardar o próximo processamento.
Antes da implementação do sistema proposto e para garantir que as modificações do hardware original na placa de desenvolvimento não alteraria o desempenho, principalmente com as mudanças de controles críticos, foi precedida uma simples implementação de inversão na imagem através de circuitos inversores.
No contexto de imagens digitais, o negativo de uma imagem nada mais é do que os valores invertidos dos pixels que a constituem. O cálculo do negativo se caracteriza através da Equação 4.1.
Equação 4.1. Cálculo do negativo em uma imagem digital. Onde:
‐ n(i): Valor do negativo no pixel i;
‐ L: Valor máximo estabelecido pela resolução da imagem. Para imagens de 8 bits, semelhantes às que usamos, esse valor será de 255;
‐ v(i): Valor observado no pixel i da imagem original.
Sendo assim, ao enviar uma imagem para o kit e recuperar o valor de seu processamento, se obtém o negativo da imagem enviada. O teste foi efetuado com sucesso e o resultado é demonstrado na Figura 4.7, validando o circuito dos blocos customizados desenvolvidos.
(a) (b)
Figura 4.7 Resultado da inversão efetuada em hardware. (a) Imagem original, (b) Imagem resultante do processamento em hardware.
Com este exemplo finaliza-se o esclarecimento sobre as atividades do trabalho efetuadas sobre os módulos Registrador de Controle e Controle de Dados.