- 12V Akku mit 280 Ah bauen         
Ergebnis 1 bis 1 von 1

Thema: Kann keine Daten vom Controller empfangen

  1. #1
    Erfahrener Benutzer Fleißiges Mitglied
    Registriert seit
    22.09.2009
    Beiträge
    164

    Kann keine Daten vom Controller empfangen

    Anzeige

    LiFePo4 Akku selber bauen - Video
    Hallo,

    ich habe das Problem, dass ich mit HTerm 0.8.1 beta keine Daten von meinem Controller empfangen kann.

    Folgendes Programm von ATMEL AVR32-UC3-SoftwareFramework-1.6.0 ist auf dem Controller installiert (Laut Beschreibung am Anfang des Programms, sollen empfangene Daten zurück gesendet werden):

    Code:
    /* This source file is part of the ATMEL AVR32-UC3-SoftwareFramework-1.6.0 Release */
    
    /*This file is prepared for Doxygen automatic documentation generation.*/
    /*! \file *********************************************************************
     *
     * \brief USART example application for AVR32 USART driver.
     *
     * - Compiler:           IAR EWAVR32 and GNU GCC for AVR32
     * - Supported devices:  All AVR32 devices with a USART module can be used.
     * - AppNote:
     *
     * \author               Atmel Corporation: http://www.atmel.com \n
     *                       Support and FAQ: http://support.atmel.no/
     *
     ******************************************************************************/
    
    /*! \page License
     * Copyright (c) 2009 Atmel Corporation. All rights reserved.
     *
     * Redistribution and use in source and binary forms, with or without
     * modification, are permitted provided that the following conditions are met:
     *
     * 1. Redistributions of source code must retain the above copyright notice, this
     * list of conditions and the following disclaimer.
     *
     * 2. Redistributions in binary form must reproduce the above copyright notice,
     * this list of conditions and the following disclaimer in the documentation
     * and/or other materials provided with the distribution.
     *
     * 3. The name of Atmel may not be used to endorse or promote products derived
     * from this software without specific prior written permission.
     *
     * 4. This software may only be redistributed and used in connection with an Atmel
     * AVR product.
     *
     * THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED
     * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
     * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
     * EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR
     * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
     * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
     * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
     * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
     * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
     *
     */
    
    /*! \mainpage
     * \section intro Introduction
     * This is the documentation for the data structures, functions, variables,
     * defines, enums, and typedefs for the USART software driver.\n It also comes
     * bundled with an example. This example is a basic Hello-World example.\n
     * Example's operating mode: 
     * -# A message is displayed on the PC terminal ("Hello, this is AT32UC3 saying hello! (press enter)")
     * -# You may then type any character other than CR(Carriage Return) and it will
     * be echoed back to the PC terminal.
     * -# If you type a CR, "'CRLF'Goodbye." is echoed back to the PC terminal and
     * the application ends.
     *
     * \section files Main Files
     * - usart.c: USART driver;
     * - usart.h: USART driver header file;
     * - usart_example.c: USART example application.
     *
     * \section compilinfo Compilation Information
     * This software is written for GNU GCC for AVR32 and for IAR Embedded Workbench
     * for Atmel AVR32. Other compilers may or may not work.
     *
     * \section deviceinfo Device Information
     * All AVR32 devices with a USART module can be used.
     *
     * \section configinfo Configuration Information
     * This example has been tested with the following configuration:
     * - EVK1100, EVK1101, UC3C_EK, EVK1104, EVK1105 evaluation kits; STK600+RCUC3L routing card; AT32UC3L-EK
     * - CPU clock: 
     *        -- 12 MHz : EVK1100, EVK1101, EVK1104, EVK1105, AT32UC3L-EK evaluation kits; STK600+RCUC3L routing card
     *        -- 16 Mhz : AT32UC3C-EK
     * - USART1 (on EVK1100 or EVK1101) connected to a PC serial port via a standard
     *   RS232 DB9 cable, or USART0 (on EVK1105) or USART2 (on AT32UC3C-EK) or USART1 (on EVK1104)
     *   or USART3 (on AT32UC3L-EK) abstracted with a USB CDC connection to a PC;
     *   STK600 usart port for the STK600+RCUC3L setup (connect STK600.PE2 to STK600.RS232 SPARE.TXD
     *   and STK600.PE3 to STK600.RS232 SPARE.RXD)
     * - PC terminal settings:
     *   - 57600 bps,
     *   - 8 data bits,
     *   - no parity bit,
     *   - 1 stop bit,
     *   - no flow control.
     *
     * \section contactinfo Contact Information
     * For further information, visit
     * Atmel AVR32.\n
     * Support and FAQ: http://support.atmel.no/
     */
    
    
    #include <avr32/io.h>
    #include "compiler.h"
    #include "board.h"
    #include "power_clocks_lib.h"
    #include "gpio.h"
    #include "usart.h"
    
    
    /*! \name USART Settings
     */
    //! @{
    
    #  define EXAMPLE_TARGET_PBACLK_FREQ_HZ FOSC0  // PBA clock target frequency, in Hz
    
    #if BOARD == EVK1100
    #  define EXAMPLE_USART               (&AVR32_USART1)
    #  define EXAMPLE_USART_RX_PIN        AVR32_USART1_RXD_0_0_PIN
    #  define EXAMPLE_USART_RX_FUNCTION   AVR32_USART1_RXD_0_0_FUNCTION
    #  define EXAMPLE_USART_TX_PIN        AVR32_USART1_TXD_0_0_PIN
    #  define EXAMPLE_USART_TX_FUNCTION   AVR32_USART1_TXD_0_0_FUNCTION
    #  define EXAMPLE_USART_CLOCK_MASK    AVR32_USART1_CLK_PBA
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBA
    #elif BOARD == EVK1101
    #  define EXAMPLE_USART               (&AVR32_USART1)
    #  define EXAMPLE_USART_RX_PIN        AVR32_USART1_RXD_0_0_PIN
    #  define EXAMPLE_USART_RX_FUNCTION   AVR32_USART1_RXD_0_0_FUNCTION
    #  define EXAMPLE_USART_TX_PIN        AVR32_USART1_TXD_0_0_PIN
    #  define EXAMPLE_USART_TX_FUNCTION   AVR32_USART1_TXD_0_0_FUNCTION
    #  define EXAMPLE_USART_CLOCK_MASK    AVR32_USART1_CLK_PBA
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBA
    #elif BOARD == UC3C_EK
    #  define EXAMPLE_USART               (&AVR32_USART2)
    #  define EXAMPLE_USART_RX_PIN        AVR32_USART2_RXD_0_1_PIN
    #  define EXAMPLE_USART_RX_FUNCTION   AVR32_USART2_RXD_0_1_FUNCTION
    #  define EXAMPLE_USART_TX_PIN        AVR32_USART2_TXD_0_1_PIN
    #  define EXAMPLE_USART_TX_FUNCTION   AVR32_USART2_TXD_0_1_FUNCTION
    #  define EXAMPLE_USART_CLOCK_MASK    AVR32_USART2_CLK_PBA
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBB
    #elif BOARD == EVK1104
    #  define EXAMPLE_USART               (&AVR32_USART1)
    #  define EXAMPLE_USART_RX_PIN        AVR32_USART1_RXD_0_0_PIN
    #  define EXAMPLE_USART_RX_FUNCTION   AVR32_USART1_RXD_0_0_FUNCTION
    #  define EXAMPLE_USART_TX_PIN        AVR32_USART1_TXD_0_0_PIN
    #  define EXAMPLE_USART_TX_FUNCTION   AVR32_USART1_TXD_0_0_FUNCTION
    #  define EXAMPLE_USART_CLOCK_MASK    AVR32_USART1_CLK_PBA
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBA
    #elif BOARD == EVK1105
    #  define EXAMPLE_USART               (&AVR32_USART0)
    #  define EXAMPLE_USART_RX_PIN        AVR32_USART0_RXD_0_0_PIN
    #  define EXAMPLE_USART_RX_FUNCTION   AVR32_USART0_RXD_0_0_FUNCTION
    #  define EXAMPLE_USART_TX_PIN        AVR32_USART0_TXD_0_0_PIN
    #  define EXAMPLE_USART_TX_FUNCTION   AVR32_USART0_TXD_0_0_FUNCTION
    #  define EXAMPLE_USART_CLOCK_MASK    AVR32_USART0_CLK_PBA
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBA
    #elif BOARD == STK600_RCUC3L0
    #  define EXAMPLE_USART               (&AVR32_USART1)
    #  define EXAMPLE_USART_RX_PIN        AVR32_USART1_RXD_0_1_PIN
    #  define EXAMPLE_USART_RX_FUNCTION   AVR32_USART1_RXD_0_1_FUNCTION
    // For the RX pin, connect STK600.PORTE.PE3 to STK600.RS232 SPARE.RXD
    #  define EXAMPLE_USART_TX_PIN        AVR32_USART1_TXD_0_1_PIN
    #  define EXAMPLE_USART_TX_FUNCTION   AVR32_USART1_TXD_0_1_FUNCTION
    // For the TX pin, connect STK600.PORTE.PE2 to STK600.RS232 SPARE.TXD
    #  define EXAMPLE_USART_CLOCK_MASK    AVR32_USART1_CLK_PBA
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBA
    #elif BOARD == UC3L_EK
    #  define EXAMPLE_USART                 (&AVR32_USART3)
    #  define EXAMPLE_USART_RX_PIN          AVR32_USART3_RXD_0_0_PIN
    #  define EXAMPLE_USART_RX_FUNCTION     AVR32_USART3_RXD_0_0_FUNCTION
    #  define EXAMPLE_USART_TX_PIN          AVR32_USART3_TXD_0_0_PIN
    #  define EXAMPLE_USART_TX_FUNCTION     AVR32_USART3_TXD_0_0_FUNCTION
    #  define EXAMPLE_USART_CLOCK_MASK      AVR32_USART3_CLK_PBA
    #  define EXAMPLE_TARGET_DFLL_FREQ_HZ   96000000  // DFLL target frequency, in Hz
    #  define EXAMPLE_TARGET_MCUCLK_FREQ_HZ 12000000  // MCU clock target frequency, in Hz
    #  undef  EXAMPLE_TARGET_PBACLK_FREQ_HZ
    #  define EXAMPLE_TARGET_PBACLK_FREQ_HZ 12000000  // PBA clock target frequency, in Hz
    #  define EXAMPLE_PDCA_CLOCK_HSB      AVR32_PDCA_CLK_HSB
    #  define EXAMPLE_PDCA_CLOCK_PB       AVR32_PDCA_CLK_PBA
    #endif
    
    #if !defined(EXAMPLE_USART)             || \
        !defined(EXAMPLE_USART_RX_PIN)      || \
        !defined(EXAMPLE_USART_RX_FUNCTION) || \
        !defined(EXAMPLE_USART_TX_PIN)      || \
        !defined(EXAMPLE_USART_TX_FUNCTION)
    #  error The USART configuration to use in this example is missing.
    #endif
    
    //! @}
    
    
    #if BOARD == UC3L_EK
    /*! \name Parameters to pcl_configure_clocks().
     */
    //! @{
    static scif_gclk_opt_t gc_dfllif_ref_opt = { SCIF_GCCTRL_SLOWCLOCK, 0, OFF };
    static pcl_freq_param_t pcl_dfll_freq_param =
    {
      .main_clk_src = PCL_MC_DFLL0,
      .cpu_f        = EXAMPLE_TARGET_MCUCLK_FREQ_HZ,
      .pba_f        = EXAMPLE_TARGET_PBACLK_FREQ_HZ,
      .pbb_f        = EXAMPLE_TARGET_PBACLK_FREQ_HZ,
      .dfll_f       = EXAMPLE_TARGET_DFLL_FREQ_HZ,
      .pextra_params = &gc_dfllif_ref_opt
    };
    //! @}
    #endif
    
    /*! \brief This is an example demonstrating the USART RS232 TX and RX
     *         functionalities using the USART driver.
     */
    int main(void)
    {
      static const gpio_map_t USART_GPIO_MAP =
      {
        {EXAMPLE_USART_RX_PIN, EXAMPLE_USART_RX_FUNCTION},
        {EXAMPLE_USART_TX_PIN, EXAMPLE_USART_TX_FUNCTION}
      };
    
      // USART options.
      static const usart_options_t USART_OPTIONS =
      {
        .baudrate     = 57600,
        .charlength   = 8,
        .paritytype   = USART_NO_PARITY,
        .stopbits     = USART_1_STOPBIT,
        .channelmode  = USART_NORMAL_CHMODE
      };
    
      
    #if BOARD == UC3L_EK
      // Note: on the AT32UC3L-EK board, there is no crystal/external clock connected
      // to the OSC0 pinout XIN0/XOUT0. We shall then program the DFLL and switch the
      // main clock source to the DFLL.
      pcl_configure_clocks(&pcl_dfll_freq_param);
      // Note: since it is dynamically computing the appropriate field values of the
      // configuration registers from the parameters structure, this function is not
      // optimal in terms of code size. For a code size optimal solution, it is better
      // to create a new function from pcl_configure_clocks_dfll0() and modify it
      // to use preprocessor computation from pre-defined target frequencies.
    #else
      // Configure Osc0 in crystal mode (i.e. use of an external crystal source, with
      // frequency FOSC0) with an appropriate startup time then switch the main clock
      // source to Osc0.
      pcl_switch_to_osc(PCL_OSC0, FOSC0, OSC0_STARTUP);
    #endif
      
      // Assign GPIO to USART.
      gpio_enable_module(USART_GPIO_MAP,
                         sizeof(USART_GPIO_MAP) / sizeof(USART_GPIO_MAP[0]));
    
      // Initialize USART in RS232 mode.
      usart_init_rs232(EXAMPLE_USART, &USART_OPTIONS, EXAMPLE_TARGET_PBACLK_FREQ_HZ);
    
      // Hello world!
      usart_write_line(EXAMPLE_USART, "Hello, this is AT32UC3 saying hello! (press enter)\n");
    
      // Press enter to continue.
      while (usart_get_echo_line(EXAMPLE_USART) == USART_FAILURE);  // Get and echo characters until end of line.
    
      usart_write_line(EXAMPLE_USART, "Goodbye.\n");
    
      //*** Sleep mode
      // This program won't be doing anything else from now on, so it might as well
      // sleep.
      // Modules communicating with external circuits should normally be disabled
      // before entering a sleep mode that will stop the module operation.
      // Make sure the USART dumps the last message completely before turning it off.
      while(!usart_tx_empty(EXAMPLE_USART));
      pcl_disable_module(EXAMPLE_USART_CLOCK_MASK);
    
      // Since we're going into a sleep mode deeper than IDLE, all HSB masters must
      // be stopped before entering the sleep mode.
      pcl_disable_module(EXAMPLE_PDCA_CLOCK_HSB);
      pcl_disable_module(EXAMPLE_PDCA_CLOCK_PB);
    
      // If there is a chance that any PB write operations are incomplete, the CPU
      // should perform a read operation from any register on the PB bus before
      // executing the sleep instruction.
      AVR32_INTC.ipr[0];  // Dummy read
      
      // Go to STATIC sleep mode.
      SLEEP(AVR32_PM_SMODE_STATIC);
    
      while (TRUE);
    }
    Ich habe folgendes Board: http://alvidi.de/avr32_modul_bmb.html

    Das Board ist mit einem USB-Adapter (Hersteller: ATEN Model: UC-232A) am PC angeschlossen. Das LED am Adapter blinkt während des Sendens.

    Zum Senden und Empfangen habe ich am Board die PIN´s 232IN0 und 232OUT0 angeschlossen und GND_1.
    Das Board wird mit 12 V betrieben. PIN´s GND_2 und 5-12V.
    Der PIN 232IN0 hat in Warteposition -6,29 V und beim Senden mit HTerm -6,12 V.
    Der PIN 232OUT0 hat die ganze Zeit -4,88 V.

    Leider weiß ich nicht wie ich das Problem lösen soll und hoffe auf eure Unterstützung.

    Vielen Dank.

    Grüße
    datatom
    Miniaturansichten angehängter Grafiken Miniaturansichten angehängter Grafiken bild_hterm.gif  

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

12V Akku bauen