00001 /************************************************************************** 00002 * 00003 * Copyright 2007 Tungsten Graphics, Inc., Cedar Park, Texas. 00004 * All Rights Reserved. 00005 * 00006 * Permission is hereby granted, free of charge, to any person obtaining a 00007 * copy of this software and associated documentation files (the 00008 * "Software"), to deal in the Software without restriction, including 00009 * without limitation the rights to use, copy, modify, merge, publish, 00010 * distribute, sub license, and/or sell copies of the Software, and to 00011 * permit persons to whom the Software is furnished to do so, subject to 00012 * the following conditions: 00013 * 00014 * The above copyright notice and this permission notice (including the 00015 * next paragraph) shall be included in all copies or substantial portions 00016 * of the Software. 00017 * 00018 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 00019 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 00020 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 00021 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR 00022 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 00023 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 00024 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 00025 * 00026 **************************************************************************/ 00027 00028 #ifndef CELL_SPU 00029 #define CELL_SPU 00030 00031 00032 #include <libspe2.h> 00033 #include <libmisc.h> 00034 #include "cell/common.h" 00035 00036 #include "cell_context.h" 00037 00038 00039 #define MAX_SPUS 8 00040 00044 struct cell_global_info 00045 { 00049 spe_context_ptr_t spe_contexts[MAX_SPUS]; 00050 pthread_t spe_threads[MAX_SPUS]; 00051 00055 struct cell_init_info inits[MAX_SPUS]; 00056 struct cell_command command[MAX_SPUS]; 00057 }; 00058 00059 00060 extern struct cell_global_info cell_global; 00061 00062 00064 extern spe_program_handle_t g3d_spu; 00065 00066 00067 extern void 00068 send_mbox_message(spe_context_ptr_t ctx, unsigned int msg); 00069 00070 extern uint 00071 wait_mbox_message(spe_context_ptr_t ctx); 00072 00073 00074 extern void 00075 cell_start_spus(struct cell_context *cell); 00076 00077 00078 extern void 00079 cell_spu_exit(struct cell_context *cell); 00080 00081 00082 #endif /* CELL_SPU */