view src/gpf2/osl/os_evt.c @ 673:62a5285e014a

Lorekeeping: allow tpudrv-leonardo.lib on Leonardo/Tango Back in 2015 the Mother's idea was to produce a FreeCalypso development board that would be a clone of TI Leonardo, including the original quadband RFFE; one major additional stipulation was that this board needed to be able to run original unmodified TCS211-20070608 firmware with all blobs intact, with only minimal binary patches to main.lib and tpudrv.lib. The necessary patched libs were produced at that time in the tcs211-patches repository. That plan was changed and we produced FCDEV3B instead, with Openmoko's triband RFFE instead of Leonardo quadband, but when FC Magnetite started in 2016, a TPUDRV_blob= provision was still made, allowing the possibility of patching OM's tpudrv.lib for a restored Leonardo RFFE. Now in 2020 we have FC Tango which is essentially a verbatim clone of Leonardo core, including the original quadband RFFE. We have also deblobbed our firmware so much that we have absolutely no real need for a blob version of tpudrv.lib - but I thought it would be neat to put the ancient TPUDRV_blob= mechanism (classic config) to its originally intended use, just for the heck of it.
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 29 May 2020 03:55:36 +0000
parents 91e8dac34ada
children
line wrap: on
line source

/*
 * This C module is a reconstruction based on the disassembly of
 * os_evt.obj in frame_na7_db_fl.lib from the Leonardo package.
 */

/* set of included headers from COFF symtab: */
#include <stdio.h>
#include <string.h>
#include "gpfconf.h"	/* FreeCalypso addition */
#include "../../nucleus/nucleus.h"
#include "typedefs.h"
#include "os.h"
#include "gdi.h"
#include "os_types.h"
#include "os_glob.h"

extern T_OS_EVTGRP_TABLE_ENTRY EvtGrpTable[];

GLOBAL LONG
os_SetEvents(OS_HANDLE evt_grp_handle, unsigned event_flags)
{
	if (!EvtGrpTable[evt_grp_handle].Name[0])
		return(OS_ERROR);
	if (NU_Set_Events(&EvtGrpTable[evt_grp_handle].EvtGrp, event_flags,
				NU_OR) == NU_SUCCESS)
		return(OS_OK);
	else
		return(OS_ERROR);
}

GLOBAL LONG
os_RetrieveEvents(OS_HANDLE evt_grp_handle, unsigned event_flags, char option,
		  unsigned *retrieved_events, unsigned suspend)
{
	if (!EvtGrpTable[evt_grp_handle].Name[0])
		return(OS_ERROR);
	if (NU_Retrieve_Events(&EvtGrpTable[evt_grp_handle].EvtGrp,
				event_flags, option, retrieved_events, suspend)
			== NU_SUCCESS)
		return(OS_OK);
	else
		return(OS_ERROR);
}

GLOBAL LONG
os_GetEventGroupHandle(char *evt_grp_name, OS_HANDLE *evt_grp_handle)
{
	int idx;

	for (idx = 0; idx <= MaxEventGroups; idx++) {
		if (!EvtGrpTable[idx].Name[0])
			break;
		if (!strncmp(EvtGrpTable[idx].Name, evt_grp_name,
				RESOURCE_NAMELEN))
			break;
	}
	if (idx > MaxEventGroups || !EvtGrpTable[idx].Name[0]) {
		*evt_grp_handle = -1;
		return(OS_ERROR);
	}
	*evt_grp_handle = idx;
	return(OS_OK);
}

GLOBAL LONG
os_EventGroupInformation(OS_HANDLE evt_grp_handle, char *Name,
			 unsigned *mask_evt, unsigned *tasks_waiting,
			 OS_HANDLE *first_task)
{
	if (!EvtGrpTable[evt_grp_handle].Name[0])
		return(OS_ERROR);
	if (NU_Event_Group_Information(&EvtGrpTable[evt_grp_handle].EvtGrp,
					Name, mask_evt, tasks_waiting,
					first_task) == NU_SUCCESS)
		return(OS_OK);
	else
		return(OS_ERROR);
}