131 lines
3.9 KiB
C
131 lines
3.9 KiB
C
/*
|
|
* test_hidh_keyboard.c
|
|
*
|
|
* Created on: Apr 5, 2013
|
|
* Author: hathach
|
|
*/
|
|
|
|
/*
|
|
* Software License Agreement (BSD License)
|
|
* Copyright (c) 2012, hathach (tinyusb.org)
|
|
* 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 the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
|
* SHALL THE AUTHOR 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.
|
|
*
|
|
* This file is part of the tiny usb stack.
|
|
*/
|
|
|
|
#include "stdlib.h"
|
|
#include "unity.h"
|
|
#include "type_helper.h"
|
|
#include "tusb_option.h"
|
|
#include "errors.h"
|
|
|
|
#include "mock_osal.h"
|
|
#include "hcd.h"
|
|
#include "usbh.h"
|
|
#include "tusb.h"
|
|
#include "hid_host.h"
|
|
|
|
#include "descriptor_test.h"
|
|
|
|
uint8_t dev_addr;
|
|
uint8_t hostid;
|
|
|
|
void setUp(void)
|
|
{
|
|
dev_addr = RANDOM(TUSB_CFG_HOST_DEVICE_MAX)+1;
|
|
hostid = RANDOM(CONTROLLER_HOST_NUMBER) + TEST_CONTROLLER_HOST_START_INDEX;
|
|
|
|
ehci_controller_init();
|
|
tusb_init();
|
|
|
|
}
|
|
|
|
void tearDown(void)
|
|
{
|
|
}
|
|
//
|
|
//osal_semaphore_handle_t sem_create_stub(osal_semaphore_t * const sem, int num_call)
|
|
//{
|
|
// (*p_sem) = 0;
|
|
// return (osal_semaphore_handle_t) p_sem;
|
|
//}
|
|
//void sem_wait_stub(osal_semaphore_handle_t const sem_hdl, uint32_t msec, tusb_error_t *p_error, int num_call)
|
|
//{
|
|
//
|
|
//}
|
|
//tusb_error_t sem_post_stub(osal_semaphore_handle_t const sem_hdl, int num_call)
|
|
//{
|
|
// (*sem_hdl)++;
|
|
//
|
|
// return TUSB_ERROR_NONE;
|
|
//}
|
|
//void sem_reset_stub(osal_semaphore_handle_t const sem_hdl, int num_call)
|
|
//{
|
|
// (*sem_hdl) = 0;
|
|
//}
|
|
//
|
|
//osal_queue_handle_t queue_create_stub (osal_queue_t *p_queue, int num_call)
|
|
//{
|
|
// p_queue->count = p_queue->wr_idx = p_queue->rd_idx = 0;
|
|
// return (osal_queue_handle_t) p_queue;
|
|
//}
|
|
//void queue_receive_stub (osal_queue_handle_t const queue_hdl, uint32_t *p_data, uint32_t msec, tusb_error_t *p_error, int num_call)
|
|
//{
|
|
//
|
|
//}
|
|
//tusb_error_t queue_send_stub (osal_queue_handle_t const queue_hdl, uint32_t data, int num_call)
|
|
//{
|
|
// //TODO mutex lock hal_interrupt_disable
|
|
//
|
|
// queue_hdl->buffer[queue_hdl->wr_idx] = data;
|
|
// queue_hdl->wr_idx = (queue_hdl->wr_idx + 1) % queue_hdl->depth;
|
|
//
|
|
// if (queue_hdl->depth == queue_hdl->count) // queue is full, 1st rd is overwritten
|
|
// {
|
|
// queue_hdl->rd_idx = queue_hdl->wr_idx; // keep full state
|
|
// }else
|
|
// {
|
|
// queue_hdl->count++;
|
|
// }
|
|
//
|
|
// //TODO mutex unlock hal_interrupt_enable
|
|
//
|
|
// return TUSB_ERROR_NONE;
|
|
//}
|
|
//void queue_flush_stub(osal_queue_handle_t const queue_hdl, int num_call)
|
|
//{
|
|
// queue_hdl->count = queue_hdl->rd_idx = queue_hdl->wr_idx = 0;
|
|
//}
|
|
//
|
|
//void test_(void)
|
|
//{
|
|
// ehci_controller_device_plug(hostid, TUSB_SPEED_HIGH);
|
|
//
|
|
// tusb_task_runner(); // get 8-byte descriptor
|
|
// ehci_controller_control_xfer_proceed(0, &desc_device);
|
|
//
|
|
// tusb_task_runner(); // get 8-byte descriptor
|
|
//}
|