Fix for bug 2283 (RVCT 4.0 support is missing from PDK 3.0.h)
Have multiple extension sections in the bld.inf, one for each version
of the compiler. The RVCT version building the tools will build the
runtime libraries for its version, but make sure we extract all the other
versions from zip archives. Also add the archive for RVCT4.
Version 1.02.371
================
(Made by Dennis 04/04/2002)
1) TimBa
1) Fix for BAD-58CDM4: Locale change has no effect on contact filtering.
2) ChrisM
1) Fix for MOS-58EJ8V (Integrator calibration doesn't work properly)
Removed the "patches" from the Y coordinate digitizertoscreen calculation and
changed the Y calibration constants to work with this.
2) Fix for CAR-57RETM (WINSCW UDEB Emulator crashes when launched in console mode)
3) Fix for TAR-58LEUV (Emulator title - variant indication) CR ref MTAR-58LDG2
4) Fix for SHY-58GGR5 (Test case that leads to unhandled exception
in DThread::GetDesMaxLength)
3) Nicolas
1) Fixed defect THY-588MLT (Integrator board with ARM926
core module does not boot). The ARM920 clock setting
code can not be reused as-is for ARM926. Modified
bootstrap to figure out which core is being used and
branch to the appropriate code. A software reset is
necessary halfway through the ARM926 clock
configuration. See comments in HwInitialise for more
details. For ARM926, the clocks are set to:
CPU: 125mhz
system bus: 25mhz
local bus: 31.25mhz (CPU clock / 4)
4) AndrewJ
1) Fixed defect JON-58DHHP where Assabet lffs media driver has an error in
suspend resume operation.
5) MarkCa
1) Fixed CAN-58GG5E (MEDMMC is not leave-safe.) Used non-leaving new in
D_MEDMMC.CPP.
6) PeteS
1) Added Lubbock Base port.
Version 1.02.370
================
(Made by CarlosF, 12/03/2002)
1) JonathanM
1) Fix for defect MET-57ZHTH - "TDblQueBase has incorrect copy constructor
and operator ="
2) Nicolas
1) Fixed defect MET-57YN7A (Power Sequence at EmergencyStandby).
Migrated 6.1 fix: In DPowerModel::PowerEmergencyStandbyDfc(),
PowerEmergencyStandby() is now called for all power handlers
*before* switching off the machine.
2) Fixed defect MET-57YMU7 (Template Port requires 'EARLY
DEBUG' examples in the template code).
3) Modified template port to use the same UART API as
recent ports, e.g. Uart1Data() and Uart2Data()
replaced with UartData(TUint32 aUartBase).
4) Fixed defect THY-585N22 (OOM during process creation
can crash the kernel). Now uses HBufC::New() instead
of NewL() in svProcessCreate() to allocate the
command-line buffer.
3) Markdo
1) Fixed defect DON-585LNV "Media door open does not work on WINS with
Mmc card controller". Removed call from PcCard Controller to set up a
media change callback in WINS. Only MmcCard Controller sets this callback
now.
4) ChrisM
1) Fixed defect MOS-586BWV (integrator had digitizer and mouse driver loaded
in e32 text shell roms). Removed mouse driver from rom.
2) Fixed defect MOS-55DJN4 (New integrator video driver should use constants
rather than magic numbers)
3) Tidied up integrator digitizer calibration.
4) Fixed defect OMC-586LJF assabet rom size
5) Fixed defect OMC-586K5Z mainline warnings
5) Pete
1) Change to the WINS local drive mappings.
The entire local drive mapping for WINS is now as follows:-
Local drive 0: Internal RAM drive (EFixedMedia0) - Y:
Local drive 1: MMC Card on MMC socket 0 (ERemovableMedia0) - X:
Local drive 2: MMC Card on MMC socket 1 - Partition1 (ERemovableMedia1)
Local drive 3: MMC Card on MMC socket 1 - Partition2 (ERemovableMedia1)
Local drive 4: PC Card on PC Card socket 0 (ERemovableMedia2)
Local drive 5: PC Card on PC Card socket 1 (ERemovableMedia3)
Local drive 6: Not currently assigned
Local drive 7: Not currently assigned
Local drive 8: Internal LFFS drive (EFixedMedia1) - W:
2) Implemented CR PHAR-54RJMT 'We should be able to simulate password
protected disks on the emulator'.
1) The method of mapping drive letter to local drive number on the WINS
emulator has been changed from being a fixed mapping, to one that uses
enviroment variables to specify the mapping. When the system starts up
it sets environment variables to reconstuct the same mapping as before:
Y:-LocDrv 0, X:-LocDrv 1, W:-LocDrv8. (This is done in SetupEmulatorPaths()
in \e32\euser\emul\win32\up_path.cpp). However, these default mappings can
overidden or new mappings created in EPOC.INI using the following syntax:
_EPOC_LocDrv_<locDrvNum> <drvLetter>: <FileSystemID string>
The FileSystem ID indicates which file system should be mounted on the
local drive in question. The following file system IDs are defined:
'Fat' and 'Lffs'.
For example, to map X: to local drive 1 specifying the FAT file system:
'_EPOC_LocDrv_1 X: Fat'
The file system ID is read by the text shell as it starts up and mounts the
appropriate file system on any local drive that it finds a mapping for.
2) A start-up media password can now be assigned to any MMC card - again
using environment variables to store the password. Passwords are set in
EPOC.INI using the syntax:
EPOC_LocDrv_<locDrvNum>_PWord_<cardNum> <password>
'locDrvNum' is the number of the local drive and 'cardNum' is the number of
the MMC card on that drive. The latter is only relevant on local drive 1 where
two virtual MMC cards are emulated (with the user hot swapping between cards
by hitting F4 while F5 is down). For example, to set Card0 on local drive 1:
'EPOC_LocDrv_1_PWord_0 aaa1'
3) The start-up state of the MMC card in local drive 1 can be configured to be
any one of the following: No MMC card, MMC Card0 or MMC Card1. The user
subsequently toggles between each of these states each time they hit the F4 key
while F5 is down. The start-up state is set in EPOC.INI using the syntax:
_EPOC_Active_LocDrv_1 <StartUpState>
'StartUpState' can be one of the following values: -1 - card present,
0 - MMC Card0, 1 - MMC Card1. For example, to set the start up state to MMC Card1:
'EPOC_Active_LocDrv_1 1'
6) MarkCa
1) Removed SD specific parts of MMC controller. EPBUSM no longer built for MEIG.
7) TimBa
1) Fix for COY-56DEYY: "MatchesPartial function uses undocumented
feature of CompareC". TDesC16::HasPrefix function added.
Version 1.02.369
================
(Made by ChrisM, 06/03/2002)
0) ArunsakhS
1) Fix for defect BAD-57HF3Y - "Locale persistence broken"
A new HAL atrribute was added to TAttribute in Hal_data.h for the
defect fix above. The new attribute is "ELocaleLoaded".
Made the required changes to "config.hcf" and "values.hda" in HAL
and all the reference platform components. Added the test for
ELocaleLoaded in the test "T_newhal" in HAL.
1) RobertJ
1) Silenced some warnings in:
\e32\drivers\medmmc\epoc\d_medmmc.cpp
\e32\drivers\medmmc\epoc\d_medsdp.cpp
2) Correction of comms header file to correct KCapsBpsxxxx constants
\e32\include\d32comm.h
JAN-57WL3N "Comm port capability constants same, missing"
(was SAS-554K4P in GT6.1)
3) Fixed JAN-57WL8G "Possible access violations in e32 drivers under OOM?"
was HAR-56DPLW in GT6.1
\e32\drivers\dfir\d_fir.cpp
\e32\drivers\ecomm\d_comm.cpp
\e32\drivers\ecommdce\epoc\d_commdce.cpp
2) CarlosF
1) Fixed defect MOS-579LUN powering down digitiser causes machine to hang
when screen is tapped.
2) Changes to Serial Port: the existing power-down timeout after finishing
transmitting has been made configurable through the introduction of a new
member to the comms config structure (this is now TCommConfigV02).
Changes to d_comm.cpp (ARM and WIN32 emulator) to support this. Also when
it powers down as a consequence of having timed out it now completes the
requests with KErrTimedOut instead of KErrAbort.
3) Further changes to the digitiser extension on Assabet and Brutus in order to
fix problems with Silent Running.
4) Fixed defect THE-57LHGD Unable to use the Profiler tool on Assabet.
3) MichaelP
1) Added data member access function TInt BytesToBeTransfered() to class
THwaDataTfReq (k32hwa.[h|inl]).
2) In T_HWA (\f32test\DEVICE\t_hwa.cpp) changed test of "HWA device specific
function (2)": the address that is now used lies within the DSP bridge
shared memory area.
3) Fixed address and size of reserved RAM area in \Helen\Bootstrap\Helen.s.
4) MarkCa
1) Fixed CAN-579MLN MultiMediaCard controller does not pre-check current
password.
5) Nicolas
1) Fixed defect THY-57QNYA (incorrect default debug port
on assabet). The default port is now UART3
everywhere.
7) ChrisM
1) Fix for DON-57RNLR (Screen is not switched on when coming back from digitiser
power-down)
2) Fix for defect PEN-57XBRV ("EPOC Emulator" should be replaced)
Changed the emulator name from EPOC Emulator to Symbian OS Emulator by default.
Name can be specified in epoc.ini with the keyword EmulatorName.
Version 1.02.368
================
(Made by RobertJ, 11/02/2002)
1) ChrisM
1) Fix for defect ROS-55CGCR - "EPOC.EXE logo fails to conform to Corporate ID guidelines"
3) JonathanM
1) Fix for defect MET-572N7U - "Destroying FixedContiguous TransferBuffers causes
memory to be 'lost' to the free pool"
4) Pete
1) Further extended the local drive caps class (TLocalDriveCapsV3)
by adding the following member:-
TUint iExtraInfo;
2) Modified the MMC Media driver to supply the above information as part of
the Media Driver Caps() function.
3) Fixed a defect where the 'iHiddenSectors' field in
the disk caps. info was not being initialised if a default boot
partition wasn't detected in the MBR.
Version 1.02.367
================
(Made by PeterS, 02/02/2002)
1) RobertJ
1) CR CLCT-55JENG. Modified \e32\include\d32usbc.h & \e32\include\d32usbc.inl
argument TInt& aLen for RDevUsbcClient::Write and
RDevUsbcClient::WriteEndpointZero changed to TInt aLen
2) JonathanM
1) Fix for defect FID-563G8A - "TPckgBuf cannot return a const reference"
2) Fix for defect PAR-56MGEB - "Generic EDISP driver lives in the wrong place."
3) Removed last vestiges of Cogent from E32
4) Fix for defect THY-4XPH4C - "T_CURRENCYFORMAT fails from time to time"
5) Fix for defect MET-56UJ35 - "Unhandled Leave in Kernel Server"
6) Fix for defect MET-56VJY6 - "Session creation can crash machine under OOM conditions"
3) MarkCa
1) Added caps buffer zeroing to MEDMMC and MEDLFS on MINT and MINK.
4) Nicolas
1) CR JPAR-54XMZD: ROM building and run time configuration of debug port
- On selected targets the current debug port can be
viewed and changed at run-time thanks to a new eshell
command (debugport). See rombuild release notes for details
about ROM building time configuration.
- Debug port setting applies everywhere (i.e. bootstrap
traces, early debug mode, non early debug mode (variant)
and debug monitor) *but* run-time port switching is not
supported in early debug mode as in this case the port
initialisation is done by the bootstrap.
- The bootstrap fetches the debug port from the ROM
header and copy it to a new field in the the super page.
- A new HAL attribute (EDebugPort) has been added and
a default implementation based on userhal has been provided.
- Assabet port modified. The accepted debug port
values are 1 (UART1) and 3 (UART3). The default is 3.
- Brutus port always uses UART3.
- Integrator (MINT) port modified. The accepted debug
port values are 0 (UART0), 1 (UART1) and 42 (JTAG DCC). The
default is 0.
- KHARDWAREASSIST flag removed. Ports supporting JTAG
DCC output should use the new scheme.
- Modified accordingly the template port
2) Modified bootvariant.mke in MINT port so that a symbol
file for bootromv1.bin is generated.
3) Fixed long standing bug in MISA variants: BOOTMISA.LIB was
not suffixed by a variant-specific identifier. This was
not discovered before as the libraries were identical on
assabet and brutus. The libraries are now called
BOOTMISAAB.LIB and BOOTMISABA.LIB.
4) "abld clean bootmisa" now removes symbol files for both
assabet and brutus.
5) ChrisM
1) Euser source reorg for ipr categorisation CR GBON-567RCZ
- created new directory base\e32\euser\utils
- moved us_array.cpp, us_func.cpp, us_lex8.cpp, us_lex16.cpp, us_heap.cpp
and us_que.cpp into the new dir which has a cat D ipr file.
- created new file us_desx.cpp which contains all the exported constructors
from us_des8.cpp and us_des16.cpp
- created a new header file in utils which contains some inline funcs which
are needed in us_desx.cpp and the old us_des8.cpp and us_des16.cpp files
- + some panic numbers and a few other shared bits.
- removed the exported constructors from us_des8.cpp and us_des16.cpp
Version 1.02.366
================
(Made by MarkCa, 15/01/2002)
1) MarkCa
1) Modified MEDMMC to support partial reads, write-through caching and
multi-block writes. Multi-block writes are a compile-time option
that is not compiled in by default.
2) Removed packed struct optimization from PS_MMC.CPP.
3) Changed debug print statements in D_MEDSDP.CPP so can distinguish
from D_MEDMMC.CPP.
4) Fixed FID-54YK2B (MEDMMC buffer not DMA-safe.) Pages of physically
contiguous RAM are allocated by the EPBUS controller at bootup and
the media driver uses a virtual function to find out where they are.
Note this is a convenience for the principal EPBUS client, i.e.,
MEDMMC / MEDSDU. If other drivers want to be clients of EPBUS, they
should still allocate their own internal buffers.
5) Fixed MBR.H header file to use include guards and #include <e32std.h>.
6) Fixed FID-54VENJ (MMC: Same debug trace used for different functions.)
Changed debug text for DMMCStack::SchedGroundDown().
2) Peter
1) Added support on MMC Card Controller for mechanical write protect switch.
2) Extended the local drive caps class (now extended to TLocalDriveCapsV3)
by adding two extra members:-
TUint iMediaSubType;
TInt64 iTotalDiskCapacity;
3) Added support for multiple Peripheral Bus Controllers.
For all platforms other than WINS, these are now loaded as kernel
extensions which then register themselves with the kernel from
the extension DLL entry-point. Each Controllers register once for
each socket that it controls and the kernel supports up to
KMaxPBusSockets(4) sockets (i.e. the system could support four different
Controllers each managing a single socket, two different Controllers
each managing a pair of sockets etc). The Peripheral Bus Controller
DLLs have been renamed. All used to be build as EPBUS.DLL. Now PC Card
Controllers are built as EPBUSP.DLL and MMC Controllers are built as
EPBUSM.DLL. For non-WINS platforms, the kernel no longer links with the
Peripheral Bus object and a platform can be configured with multiple
Controllers, a single Controller or no Controllers simply by the inclusion
(or non-inclusion) of the Controller extension DLL in the rom OBY file. The
WINS and MEIG platforms now support dual Controllers, both a PC Card
Controller and an MMC Controller. (Note, to achieve this in WINS, the kernel
now links to EPBUSP.DLL and EPBUSM.DLL). Changes to support this include:-
a) Added the function:-
void Kern::RegisterPBusController(TPBusNum aMachineBusNum,
DPeriphBusController* aController,TPBusNum aControllerBusNum)
which should be called from the Controller extension DLL entry-point for
each bus that the Controller manages in order to register that Controller
for that bus. 'aControllerBus' is the number of the bus relative to that
particular Controller as opposed to 'aMachineBus' which is the bus number
relative to the entire machine (e.g. on a machine configured with two
Controllers each managing two buses, then when the 2nd controller registers
for it's 2nd bus, the machine bus number of this is 3, but the number relative
to the 2nd Controller is 1).
b) With there now being potentially multiple Controllers,
the function to retrieve the pointer to the Controller now takes a bus
number as a parameter and becomes:-
DPeriphBusController* Kern::PBusController(TPBusNum aMachineBusNum)
c) Added the function
TPBusNum Kern::PBusControllerBusNum(TPBusNum aMachineBusNum)
which returns the bus number relative to its owning Controller for a given
machine bus number.
d) The kernel now keeps a count of Controller registered. This means the
platform specific HAL function ImpHal::TotalSupportedBuses() is now
redundant and has been removed.
e) Modified the extension DLL entry-point function for the generic
Peripheral Bus Controller to allocate the Controller object and perform
secondary initialisation before registering the Controller with the kernel.
This makes the function P::InitialiseLocalDrives() redundant and it has
therefore been removed. Also, the function DPeriphBusController::NewL() is
no longer exported. (Still exported from WINS Controllers which aren't
extensions and therefore still need to to initialised directly by the kernel).
f) Removed the function DPeriphBusController::TotalSupportedDrives() and
replaced this with a straight call to the variant of the same name:
Custom::TotalSupportedDrives().
Following on from this, removed the data member iTotalSupportedDrives
from the classes TPcCardMachineInfo and TMmcCardMachineInfo.
g) Added the pure virtual function:
TPBusNum DPeriphBusController::BaseBusNumber()
to the generic Peripheral Bus Controller class which returns the
machine bus number of the first bus under the control of this Peripheral
bus Controller. Provided implementations of this in the DPcCardController
and DMMCController classes. These read the required information from the
corresponding TPcCardMachineInfo and TMmcCardMachineInfo classes. Added the
corresponding data member iBaseBusNumber to each of these classes which
is supplied from the variant.
h) Constructors for TPBusCallBack made inline rather than being exported
from the Peripheral Bus Controller so that the kernel no longer needs to
link with EPBUS.LIB.
i) Moved the function:
DPBusMediaDriver::SetCurrentConsumptionInMilliAmps()
to the Media Driver base class - DMediaDriver and removed the function
DMediaDriver::DeltaCurrentConsumptionInMilliAmps() which was now redundant.
Also added a destructor to the DMediaDriver class to reset the current
consumption when the object is destroyed. This again required in order that
the kernel need no longer link with EPBUS.LIB (as this needs to reset
the media driver current consumption on a media change - with object
destruction not occuring until the next mount).
j) Change to the WINS local drive mappings to include emulation of PC Card
drives as well as MMC drives.
The entire local drive mapping for WINS is now as follows:-
Local drive 0: Internal RAM drive (EFixedMedia0) - Y:
Local drive 1: 1st special MMC Card on MMC socket 0 (ERemovableMedia0) - X:
Local drive 2: 2nd special MMC Card on MMC socket 0 (ERemovableMedia0) - V:
Local drive 3: MMC Card on MMC socket 1 (ERemovableMedia1)
Local drive 4: PC Card on PC Card socket 0 (ERemovableMedia2)
Local drive 5: PC Card on PC Card socket 1 (ERemovableMedia3)
Local drive 6: Not currently assigned
Local drive 7: Not currently assigned
Local drive 8: Internal LFFS drive (EFixedMedia1) - W:
k) For MEIG, MISA and MTEMPLATE platforms, the Peripheral Bus variant interface has
been removed from the variant DLL and is instead built as a separate kernel extension - either
as EPBUSPV.DLL for PC Card Controller variants or EPBUSMV.DLL for MMC Controller variants.
For these platforms, registration of the Controller with the kernel takes place via a call
from the Controller variant extension DLL entry point rather than from the Controller extension
DLL entry point. For all other platforms, the Controller variant remains as part of the main
variant DLL. These platforms therefore have no separate Controller variant DLL.
As a result of this change, the Controller DLL entry
point has been moved out of the generic layer of the Peripheral Bus
Controller (PS_PBUS.CPP) into the ASSP layer.
Splitting the Controller variant out of the main
variant DLL is necesssary where there are multiple
Peripheral Bus Controllers on a platform - otherwise the variant DLL has to contain
multiple Controller variants.
l) Deleted V32PCCD.H, and V32PCCDI which were being used as a general definition of the
PC Card Controller variant interface for all platforms. Each peripheral bus ASSP layer
should define its own variant interface as required for that impelementation. This
should be defined in the header file \e32\epbus\epoc\<assp>\v32pccdv.h (or v32mmcv.h
for MMC Controllers). Implemented this for all supported platforms.
NOTE: The power model extension - EPOWER.DLL must be loaded before any Peripheral
Bus Controller extensions - EPBUS?.DLL or EPBUS?V.DLL (i.e. in the OBY file, the
lines that specify the inclusion of EPBUS??.DLL must occur after the line which
specifies the inclusion of EPOWER.DLL).
3) RobertJ
1) Changed string descriptor text in pa_usbc.cpp to remove reference
to EPOC and ER6.2
2) Removed function CopyMaxToClient in d_usbc.cpp, this was in effect a
duplicate of CopyToClient. Code now uses CopyToClient in all cases.
3) In usbdma.cpp & k32usbc.h changed interface to
TDmaBuf::RxCopyPacketToClient & TDmaBuf::RxCopyDataToClient to take
an explicit length argument. This removes the need to modify the
TEndpointTransferInfo
Modified d_usbc.cpp to reflect change in the calling interface to
TDmaBuf::RxCopyPacketToClient & TDmaBuf::RxCopyDataToClient
4) MichaelP
1) Fixed compile time error in /e32/drivers/ehwa/d_hwa.cpp which only occurred
when GETPUTDATA_ARE_KERNELSERVERCALLS had been #defined.
2) Added parameter 'TInt aNumWindows' to functions DHwaTask::Init() and
THwaTaskHwInterface::Init(), which are declared in k32hwa.h.
3) Introduction of boolean flag iInUse to class THwaDataTfReq: used to identify
transfer requests which are currently being processed by the PDD.
4) HWA bogus PDDs: changed order of calls to DHwaTask::GetNextRequest to account
for change no. 3).
5) Moved HWA device state member iStatus from class DHwaDevice to class
DHwaDevicePdd; maintaining its correct value is now up to the PDD.
Version 1.02.365
================
(Made by AndrewJ, 12/12/2001)
1) Morgan
1) Integrated DPassiveDebugger enhancements from \tools\debugger_stub\...
into Helen variant: \helen\debugger\...
2) ChrisM
1) Fixed MET-54HLQA (T_NEWHAL tests fail)
2) Fixed MET-555GLS (On WINS HAL function EDisplayMemoryAddress should return the Window Handle)
3) Dennis
1) Fixed HEY-54JJ9Y (DPlatLibrary not filled in for some loads)
4) JonathanM
1) Fix for 6.1 defect MOS-54NLHX - "__PROFILE_DISPLAY macro in e32def.h has error"
5) WilliamRo
1) Fixed ROS-54MGXX "WINSCW builds enable C++ exceptions and RTTI" by adding
appropriate #pragmas to the __CW32__ section of e32def.h
6) Nicolas
1) Fixed MOS-54QM2W (Building bootstrap MMU layer &
special bit patterns in permissions): The MMU
permissions are now global variables defined in the
variant part of the bootstrap and used by the generic
ones.
2) Removed the write-through version of the generic
bootstrap MMU library. This was used only by the
Helen port which now uses the same code as everything
else and selects write-through behaviour by changing
the MMU permissions in the variant (see previous
entry). See commented out code at the top of helen.s
and helenc.cpp to switch between write-back and
write-through.
3) Fixed THY-54XJFZ (When fast RAM used, cache should be
disabled for kernel stacks, data and heap). When
those entities are in DRAM, they are always cacheable.
When they are in FRAM, they are mapped using the map
flags specified in the FRAM bank. This allows to
enable/disable the cache on a per-bank basis.
7) RobertJ
1) Fixed HEY-54JME9. Removed mini-loader
"Drive specifier missing on libraries loaded with the mini-loader"
8) MichaelP
1) Removed /e32/drivers/ subdirectories ecommdma and emcbsp. These two drivers were
introduced by the Helen port and are actually TI-specific. Since they are not even
used by the current Helen port, we can safely get rid of them.
9) PeterH
1) Integrated changes to DEF files from the mainline.
Frozen exports are now marked with the R3UNUSED flag where appropriate.
This is to support the thumb stub optimisation where the R3 register is
use to generate a smaller import stub for a function if it isn't used to
receive parameters.
10) MarkCa
1) Updated MLNK EPBUS port to detect all events in ISR.
2) Reduced EPBUS by c1.2k by using packed TMMCCommandSpec structure.
Version 1.02.364
================
(Made by MichaelP, 20/11/2001)
1) MarkCa
1) Changed DFlashDevice::SetupWrite() in \integratorap\lffs\flashfile.cpp
to use wrapper class for testing if write buffer available instead of
testing bits in 32bit value.
2) Fixed CAN-547HD3 (Controller panics when no events to handle.)
2) RobertJ
1) Corrected coding comments in d_usbc.cpp & minor clarification in pa_usbc.cpp
2) Implemented new USB VID.
3) Further cleanup work following deconfiguration on USB client SIN-535KPU
4) Propagated fix for PBN-4TKJ7J "Bluetooth panics with HCI error 23".
In \brutusa\vi_com2.cpp, reordered ISR rx now done first
then tx, removed uart tx busy spin.
3) Nicolas
1) Fixed FID-53YD58 (Bootstrap doesn't dump all MMU
pages): off-by-one error.
2) Enabled cache for exception vector page when it is in
DRAM (cache still disabled if the page is in fast RAM
as TC RAM and cache are not compatible).
4) ChrisM
1) Fixed ALM-53LHP4 (Fixed Calibration settings are not saved). Assabet only defect,
problem was in the variant vi_xyin.cpp in DDigitiserSA1100::DigitiserToScreen.
2) Fixed FOD-54MET2 (Display bytesPerLine calculated as bits not bytes). Fixed the problem in template port + integrator.
5) AndrewJ
1) Fixed DOM-4XWC5P (Medlfs driver is not reliable) This problem was concerned with
flash devices not erasing properly when suspended, on assabet boards. This was
fixed by not suspending an erase unless both chips have gone into suspend mode
properly.
2) Fixed FID-53YDJC (Error LFFS driver SetupWrite() function) Semi implemented
suggestion in defect report though still need to issue dummy command after
correct register has been read, otherwise command issued does not work.
6) JonM
1) Implemented change request JMET-544FUM - "Change RTransferWindow::MapInBuffer() to
return error code and not panic"
7) CarlosF
1) Fixed MOU-543FVR HAL attribute ECaseSwitch returns wrong value for Assabet.
The following files were modified:
\assabetb\hal\config.hcf
\assabetb\hal\values.hda
\assabetb\lffs\loadlffs.cpp
\assabetb\vi_hal.cpp
\hal\inc\hal_data.cpp
\hal\tsrc\t_new_hal.cpp.
Fixed FRS-534EWW T_SERIAL fails on Assabet. The following files were
modified:
\assabetb\bmisa\visaabu.def
\assabetb\v32scpld1111.h
\assabetb\vi_com1.cpp
\assabetb\vi_com3.cpp
\assabetb\vi_cpld1111.h
\assabetb\vi_hw.cpp
\assabetb\vi_power.cpp.
8) MichaelP
1) HWA API implementation now corresponds to API document version 0.15:
a) Removed enum TTaskPriority from d32hwa.h (was not used).
b) Two new functions in class RHwaTask:
TInt PutData(RTransferBuffer& aBuf, TInt aBytesToBeTransfered,
TInt* aBytesTransfered=NULL, TInt TransferId=KTfBufIdNull);
and
TInt PutData(RTransferBuffer& aBuf, TRequestStatus& aStat,
TInt aBytesToBeTransfered, TInt* aBytesTransfered=NULL,
TInt aTransferId=KTfBufIdNull);
which allow the user to specify the number of bytes to be transferred to the
DSP (rather than the whole buffer).
c) New member in class TTaskDataTfInfo (d32hwa.h): TInt iBytesToBeTransfered;
d) Renamed THwaPanic enums from EHwaXxx to EHwaPanicXxx (k32hwa.h).
e) Added virtual destructor for class THwaTaskHwInterface to prevent resource
leaking in derived classes.
f) Removed function TInt DHwaTask::Priority() (was not used).
g) New member in class THwaDataTfReq (k32hwa.h): TInt iBytesToBeTransfered;
h) Removed data member iPriority from class DHwaTask: moved to class
THwaTaskHwInterface; thus the task priority is now managed entirely by the PDD.
i) Added three additional arguments to TInt THwaTaskHwInterface::DoInputFrom(const
DHwaTask& /*aTask*/, TInt /*aOutputIndex*/, TInt /*aInputIndex*/,
TInt /*aConnectionId*/) to pass the task index and connection ID information to
the PDD.
j) Made function void DHwaDevice::SetStatus(THwaDeviceStatus aStatus) public
(was: protected).
k) Merged two functions of class DHwaDevice
TInt TaskCallPutData(DHwaTask* aTask, const TAny* aArg);
TInt TaskCallGetData(DHwaTask* aTask, const TAny* aArg);
into one function
TInt TaskCallTransferData(DHwaTask* aTask, const TAny* aArg, THwaDataTfDir aDir);
l) Fixed kernel heap memory leak caused by incorrect call to S::TransferWindowClose()
in destructor DHwaTask::~DHwaTask().
2) USB client implementation:
a) Added "#define SET_DESCRIPTOR_REQUEST_SUPPORTED" to k32usbc.h (in commented-out
form).
b) Added "const TUint16 KUsbVendorId_Symbian = 0x0E22;" to usb.h (USB-IF assigned
Vendor ID).
Version 1.02.363
================
(Made by Dennis 26/10/2001)
1) MarkCa
1) Updated Linkup MMC port with event checking asserts.
2) Modified P32MMC.H to allow per-platform configuration. The file
can only be included into ASSP-specific builds. It reads a header
file MMC_CFG.H from \epoc32\include\kernel\ASSP.
3) Fixed FID-4ZKEKQ (Inefficient memfill in MMC driver.) Use Mem::Fill()
instead of loops to fill buffers with 0xff in DoFormat() for
DMmcMediaDriverFlash.
2) Nicolas
1) Fixed THY-52WJTE (DLL static data support doesn't
allow for DLLs which only have BSS): The "$DAT" chunk
which holds the initial content of the DATA section is
not created when there is no DATA section.
Additionally it is not created for ROM-based DLLs as
the initial content is fetched from ROM in that case.
2) Fixed generic bootstrap defect FID-53BKSD (920T
MMU_Invalidate is wrong): The ARM920T version of that
function now only invalidates TLB and I-cache.
3) Fixed kernel defect THY-53FE32 (Confusion between
TheKernelPage and TKernelPage ctor)
4) Fixed generic bootstrap defect THY-53LC9Y (crash when
only exception handlers and supervisor stack/heap in
IRAM). Reversed exception code and supervisor
heap/stack allocation order in fast RAM to ensure that
stack/heap always at top of bank where the bootstrap
stack is. Otherwise the adjusted stack value after
enabling MMU is wrong.
5) Fixed generic bootstrap defect FID-53LKTG (Bootstrap
test code: heap test is useless, author should be
shot). Kernel data is now really checked.
6) Modified bootstrap tests to take into account possible
exception vectors relocation to highmem.
7) Removed deprecated "screensize" keyword from bootstrap
test obey files.
3) ChrisM
1) Fixed WIR-53FANN (RArrayBase::HeapSort makes assumption about max iEntrySize value)
Changed temp buffer in HeapSort functions to use the const KSimpleArrayMaxEntrySize
2) Fixed MOS-53FLUF (HAL attribute ordering incorrect). Moved EPenState from
before EKeyboardState to after ESystemDrive.
3) Fixed MOS-53RHP3v(Screen width and height returned by HAL are constant). Added func
to hal\src\emul.cpp to return the current sizes defined in epoc.ini.
4) Carlosf
1) Changes to Assabet Variant to fix a problem with the External Interrupts
dispatching. Modified \assabetb\vi_hw.cpp.
2) Fixed BAN-52BKKC Physical device driver for serial port have a defect and
can cause loss of data.
5) Pete
Migrated the fixes for the following 6.1 defects:
1) Fixed PAS-4WRMQS: "Requeing a read() after PowerOn Panics the Driver/Kernel".
Problem caused by driver registering for PC Card IREQ events twice without
de-registering in between. This causes a panic in the PC Card Controller.
- Modified the Brutus and Assabet PC Card serial PDDs
(DITXBA4.PDD/DITXAB4.PDD) so that rather than registering and de-registering
for notification of PC Card IREQ events whenever they need to disable serial
interrupts, the drivers keep the notification request registered - and simply
enable and disable IREQ events on that socket.
- Changed the PC Card Controller so that registering a TPBusCallBack object
for event notification (with DPcCardController::RegisterEvent()) which is
already registered returns an error rather than causing a kernel panic.
- Modified the PC Card Controller by adding support for a new configuration
request flag: KPccdConfigOverrideNormalPwrEvents. If a configuration is
requested (via DPcCardController::RequestConfig()) which contains this flag
setting then normal machine power handling by the Controller for the socket
in question will be disabled - leaving the PC Card Controller client to
implement its own power handling policy. This only applies to machine power
on/ power off events. The Controller will continue to handle emergency power
down and media change events. The power handling override will remain in
force as long as the configuration is applied (i.e. this condition is removed
following a call of DPcCardController::ReleaseConfig(),
DPcCardController::DeregisterClient(), a media change event etc). This
feature is required to support PC Card serial cards in order to support the
'idle off' power policy which serial ports now implement. Without this, even
though the PC Card serial driver will ignore a machine power down call when
it still has a write request in progress, the PC Card Controller will still
turn off the VCC supply to the card and thus power it down.
2) Fixed SCE-534GAE: "Problems with Serial Comms LDD power handling"
- Modification to the serial port LDDs, ECOMM.LDD (including the WINS version)
and ECOMMDCE.LDD to fix a problem with the way it implements the 'idle off'
power policy. Although it currently ignores Power-Off notifications, it does
not ignore Power-On notifications and instead completes any outstanding request
with KErrAbort. Hence, if the machine happens to be powered off and then back
on again before the serial port has had an inactivity timeout, any outstanding
requests will wrongly be completed with KErrAbort as the machine turns back on.
- Another problem fixed is associated with the fact that the
current comms driver power handler doesn't actually power the
device down on a normal power down event. However, the driver
itself uses the power model at other times to control power
to the device (e.g. when closing the driver). Hence,
DChannelComm::DoPowerDown() is never called and the driver
closes leaving the comms h/w powered up. This is now fixed,
with the driver calling DoPowerDown directly when required.
3) Fixed SCE-52YHQE: "Serial change notifier problems".
6) WilliamR
1) Fix defect ROS-53TDGG "Access Violation in CreateFirstDllRefTable" by allowing for
GetModuleHandleA to return 0. This is essentially the same code as used in
CreateDllRefTable() which handles dynamically loaded DLLs.
Version 1.02.362
================
(Made by ChrisM, 05/10/2001)
1) CarlosF
1) Port defect fix for defect ALM-4VQB5V Ditizer freezes (was: The Brutus
board freezes after entering 50-60 characters with HWR) from 6.1.
Modified \assabetb\vi_xyin.cpp and \brutusa\vi_xyin.cpp.
2) MarkCa
1) Fixed FID-4ZWDMZ (MMC program poll is too slow to be useful.)
Use TMilliSecondCallBack instead of TTickLink. Pure virtual DMMCStack
function ProgramPollPeriod() replaced with pure virtual DMMCController
function ProgramPeriodInMilliSeconds().
2) Moved Integrator LFFS drive to k:. ImpHal::TotalSupportedDrives() now
returns 9 instead of 2, as does unused Variant::PeriphBusMachineInfo().
MEDLFS changed to use 22MB of flash across three pairs of chips.
The memory range is a contiguous block, which can be specified at
compile time in \integratorap\lffs\ffs_config.h.
3) JonM
1) Fixed defect FER-4XDK9G - "Assabet timers go off at strange intervals."
2) Fixed defect MET-52AF29 - "Power off/on may freeze Assabet/Brutus"
3) Fixed defect in TSa1100::SetRtcData. This needed to wait longer for the new value to take effect.
4) Moved HELEN's exported headers from E32 to the HELEN variant.
This helps fix defect MAY-4XWM9Q - "e32 does not build in an IPR-E OCK".
It also moves what should probably be IPR category B stuff from a cat E directory.
4) MichaelP
1) HWA API implementation now corresponds to API doc version 0.14
a) THwaTaskHwInterface::DoCloseTask() now has a parameter TBool
aCallbackRequest which indicates whether or not the PDD should
finally call DHwaTask::CloseComplete()
b) RHwaTask::Logon() now has a second parameter TUint aFlagsWord which
can be used to make a logon request more specific
c) RHwaTask functions Start(), Suspend(), Resume(), and SetPriority()
are now asynchronous; however this is transparent to the user as the
asynchronousness is wrapped up in the d32hwa.inl inline header file
d) Renamed DHwaTask::DoLogonComplete() to LogonComplete()
2) USB PIL: Endpoint Data Toggles are now correctly reset after Set_Interface and
Set_Configuration requests.
5) AndrewT
1) Fixed BAN-52BKTN (CAsyncCallBack ctor TCallBack& could be const). Made
the TCallBack parameters to the constructor and Set() const.
2) Fixed BAN-52BKV2 (Should inline TInt RSubSessionBase::SubSessionHandle() be
const?). Added const to this member.
3) Fixed THE-52WJR6 (Equality operators for TThreadId and TProcessId should be
const). Made the accessor and comparison operators const on these classes.
6) RobertJ
1) Incorrect behaviour in usb client after getting deconfigured then
configured, without an intervening reset.
Data toggles were not getting reset,
ldd wasn't cancelling user requests,
PIL layer wasn't cancelling ldd requests and
psl layer was trying to drain fifo because RPE bit was set.
RPE will get reset on next read when RPC gets cleared and fifo is
automatically emptied.
2) Fixed FID-52HBTA: USB driver not leave safe
3) Fixed ROS-534EAV: usbdma.cpp mixes new[] and delete
7) ChrisM
1) Fixed PAR-52CLSB (920T bootstrap code is Cat D it should be Cat E). Changed
categorisation to E after source code recategorisation CR - CMOS-52WJ5V
8) Pete
1) Removed Cogent source
2) Removed Windermere source
3) Removed MEDCRM and MEDCRR media driver source.
Version 1.02.361
================
(Made by AndrewT, 31/08/2001)
1) AndrewT
1) Fixed EDNATHE-4QQKZM (RThread().Suspend() deadlocks the emulator) again.
The original fix was incomplete.
2) Fixed HEY-4XHGD5 (Remove \e32\include\K32DBGDD.H)
3) Fixed MET-4YSM3M (Text shell DIR command problems)
2) Nicolas
1) Fixed FID-4VHGDK (Debug should show current thread
after exception). When a thread or process panics or
takes an unhandled exception, the name and ID of the
thread/process is displayed in the kernel traces (only
if KPANIC is set).
2) Replaced void GetExceptionVectorsInfo(addr, size) with
TUint32 ExcVectorsAddr() in generic bootstrap because
vector table size not used anymore. Documented that
in bootstrap doc version 1.2.
3) Small changes following RHR 113.2 (exception code in
fast RAM) review.
4) Exception vectors are now moved to highmem on assabet.
5) Updated makefiles used to build bootstrap tests for
MLNK, MINT and VTEMPLATE now that the generic test
code is contained in libraries.
3) Chris
1) Fixed problem with cirrus not turning display on introduced with LCD changes for GT111
2) finished implementation of mapping video chunk from more than one physical region
3) Updates to video driver code from code review. Split video driver up into bit which needs porting and the interface.
4) Changes to video driver for CR LROS-4Z7E7Z to allow scdv get all display modes
5) updated video test code to include tests for palette when not in palettized video mode and updated assabet and brutus
to report if backlight is supported via HAL and fixed inconsistency between assabet,brutus and the template reporting
different error value if palette functions called on a none palettized video mode.
6) Fixed FID-4ZGJ2L WINS/WINC doesn't handle command line args correctly. If executable command path
has spaces it will be quoted. If a quote is found it skips until the next one.
7) Fixed MOS-4Y4D9K Two taps on screen required to turn on display.
4) AndrewJ
1) Fixed THY-4YCP96 stopped Null pointer from being derefrenced in LFFS media driver
5) JonM
1) Fixed defect FID-4WUGL4 - "MMU secondary config is annoying"
The MMU secondary config is now obtained from a constant (KMmuSecondaryConfig) contained
in the bootstrap's variant library.
2) Fixed defect FID-4XTC27 - "Bank width corrupted in BDB"
3) Fixed defect FID-4Y3CP3 - "Should fill unused Rom config blocks"
4) TransferBuffer performance greatly improved.
5) API CHANGE: DTransferWindow::MapInBufferL is now non-leaving and has been
renamed to MapInBuffer.
6) Fixed bug in DPlatProcess::RemoveChunk, this no longer flushed the data chache
when removing EFixedAddress chunks.
7) Extended T_HWA test to include a benchmark test for PutData. Also made this
work on Integrator.
8) Fix for defect PAR-4VMKV7 - "WD_VT100 has lost its basic nature and now depends on the Comms drivers!!"
WD_VT100.CPP Has now reverted being output only, via the debug port.
The implementation using the ECOMM driver has been added as WD_VT100_ECOMM.CPP
9) Fix for defect FID-4YTET9 - "Manufacturer in HAL should be a UID"
(Made TManufacturer definition obviousely extendable by using UIDs.)
10) Fixed defect SAS-4ZTD5D - "Missing l7200a t_trace.cpp file for bootstrap tests"
Also fixed build failure with Integrator bootstrap test code.
11) Fixed defect SAS-4ZSGBU - "Exports inconsistent. v32isaab.h includes not exported"
12) Fixed defect FER-4XGDVT - "Integrator can't cope with time being set randomly"
13) Removed #include <e32transbuf.h> from e32std.h
6) MarkCa
1) Implemented MEDLFS driver for Integrator. Mounts on local drive 1
and provides access to 2 * 4Mb flash chips. ELFFS is not mounted
by default.
7) CarlosF
1) Changes to Assabet bootstrap and Variant to make Assabet's CPU and Memory
bus clock speed configurable. Also includes an option to always format the
C:\ drive on start-up if LFFS filesystem is mounted on this media.
2) Changes to SA1100 ASSP to enable WAIT signal detection on Assabet PCCard
IO accesses. This is required as the Assabet controller needs to be
configured to detect the assertion of this signal on accesses to IO space
contrary to Brutus which has this detection enabled by default.
8) TimBa
1) Folding now folds 0xA0 (non-breaking space) to normal space (0x20)
9) Andy Curran (Uikon)
1) Fix for (PER-4Z5DW6) Switch On/Off Control Panel Dialog case closed option does not work.
Really just correcting a few typos. Fix tested with success. Fix accepetd by Nicolas T.
10) MichaelP
1) Updated Helen port (mhelen target) to 6.1 port sources from 30 July
2001 (Perforce revision 10426). Many changes, among them items 2) - 6).
2) Added directory stdarmWT (containing some files) under /bootstrap/mmu/:
"Bootstrap MMU Write-Through Mode."
3) Added directory ecommdma (also containing some files) under
/e32/drivers/: "Implements the Logical device driver for a serial port
using DMA transfers." This driver is used by the mhelen target.
4) New kernel exports for mhelen:
THelen::ReadIntMask(unsigned int);
THelen::SetMcBspReg(unsigned int, unsigned int, unsigned int);
THelen::SetComBSPStatus(int);
5) Re-activated #define __EARLY_DEBUG__ in
\e32\ekern\epoc\arm\Helen\KA_UTL.CPP.
6) Added file \e32\rombuild\HelenTests.oby.
7) HWA API: RHwaTask functions GetData / PutData are now kernel exec calls
(as opposed to kernel server calls) --> significant performance
increase.
The previous behaviour (i.e. server calls) can be had by uncommenting
//#define GETPUTDATA_ARE_KERNELSERVERCALLS in d32hwa.h.
8) HWA API: Constant value changed: KTfBufIdNull = 0x0 (was: 0xf0000000).
9) Added overloaded function
DTransferWindow* Kern::TransferWindowFromHandle(TInt aHandle, DThread* aThread);
to \e32\include\k32std.h, exported and frozen for all targets. Function
is implemented in \e32\ekern\ks_transbuf.cpp. This function is used
where the current thread is not the same as the one that created the
window handle.
10) T_HWA has now integrated profiling support, activated by calling "t_hwa
profile".
11) RobertJ
1) Added a new constructor each for RArray and RArrayPointer. This enables
the sort/find to be used with an existing array with memory allocated
outside of these classes.
Version 1.02.360
================
(Made by Peter, 06/08/2001)
1) MarkCa
1) Fixed FID-4X8JKB (TMMCCommandDesc::Direction() should be const.)
2) Fixed MMC controller defect in ExecCommandSM() / EStDeselectEndCheck
where cmd was not reset after the stack was popped.
3) Optimized DMMCcontroller::PowerUpBus() to initialize stack once for
all drives. Check if initialized successfully and still powered up.
If so, complete immediately. Retain ability to power down and power
up again if failed because of unknown password (CMD3 RTO.)
2) Chris
1) Changed brutusa\video.mmp to use visaba.lib not visaab.lib and cixyba.lib not cixyab.lib
2) Updated headers and removed dead code from files changed for LCD driver improvements.
3) Removed "screensize" keyword from header.iby files
3) AndrewT
1) Fixed NEO-4X8CFY (TTime::WeekNoInYear() function returns wrong
week number if week start day is not monday). Rewrote the
second half of the offending function to do the right calculations.
4) Michael
1) Commented out #define __EARLY_DEBUG__ in
\e32\ekern\epoc\arm\Helen\KA_UTL.CPP.
2) Deleted line "screensize=320x240x12" from
\e32\rombuild\mhelen\header.iby.
3) Added to \hal\inc\hal_data.h enum TManufacturer
"EManufacturer_TexasInstruments" and enum TMachineUid
"EMachineUid_Helen=0x101F3EE3".
4) HWA API:
a) Introduction of concept of input and output index for tasks with
multiple I/Os. These indices are additional (& optional) arguments for
RHwaTask functions InputFrom(), DisConnectInput(), InputConnection(),
and OutputConnection(), and are also part of class TTaskConnectInfo.
b) New RHwaTask querying functions: GetTaskProperties() and
GetTaskStatus().
c) With these come two new classes: TTaskPropertyInfo (this not new but
updated), and TTaskStatusInfo.
d) RHwaDevice::Tasks() now returns a find-handle -- the handle is no
longer a component of the filled TTaskPropertyInfo structure.
e) RHwaDevice::CreateTask() has an additional parameter aNumWindows (#
of transfer windows for DHwaTask object).
f) RHwaTask functions Logon() and LogonCancel() are now void.
g) RHwaTask::SetOwningDevice() is now a protected class member and no
longer documented in the API doc.
h) Class RHwaDevice is now a friend of class RHwaTask.
i) Removed RHwaTask functions GetStatus() and GetTaskID().
j) Removed RHwaTask default constructor (was empty).
k) Removed enum THwaTaskLogon (was not used).
5) Nicolas
1) Modified MCOY bootstrap to take into account the super
and CPU pages layout changes introduced in E32 359.
2) MCOY ASSP layer now contains static arrays for the
various stacks and initialises the PP::* and Arm::*
stack "top" pointers. Note that it would be possible
to perform the stack allocation in the bootstrap
instead.
3) Fixed MAY-4V4E5V (Breakpoints don't work on ARM
architecture 5 processors). Now two opcodes in the
undefined space are used: a 16 bit one for THUMB and a
32 bit one for ARM (previously a unique 16 bit pattern
was used). RDebug::SetBreakPoint() has now a new
overload which allows to specify what kind of
breakpoint is excepted. The old overload is
deprecated (it returns KErrGeneral systematically).
4) Cosmetic changes to bootstrap and kernel following
code review.
5) Removed dubious assert from bootstrap which crashed
Brutus when warm-booting: MarkRamImageInBank() can
actually be called with a BDB containing
KBdbBankTypeRamAsRom in that case because the BDB
initialised during cold boot is reused. This allows
to skip bank size/width detection.
6) William
1) Add CleanupArrayDelete template to E32BASE.H, and remove the __EPOC_CLEANUP_SUPPORT__
include guards to complete Epoc32 Proposal SW1-87 (See STORE 0049 notes from 1998)
2) Export EKDATA.DEF so that ASSPs can get it from a published place, rather than
referring to ..\e32\bmarm\ekdata.def. Modified various MMP files to get this file
from \epoc32\release\marm\ekdata.def instead.
7) Pete
1) Fixed FID-4XEE3C "Remount of fixed media broken". Change to the function
DPrimaryMediaBase::NotifyMediaStatusChange() which is called on media
change, but more significantly when forcing a remount on a drive. The change
involves only attempting to reset media driver current consumption if the
media is removable (since only drivers for removable media track current
consumption). This fixes a problem where the kernel heap became corrupt when
forcing a remount on a fixed drive.
2) Added the following functions to the TBusLocalDrive class:-
a) TInt SetMountInfo(const TDesC8* aMountInfo,TInt aMountInfoThreadHandle);
The SetMountInfo() function allows a descriptor to be associated with
a local drive - which is passed down to the corresponding media driver for the
drive as that driver is opened. This therefore provides a means of supplying
additional information to the driver at creation time. In the case of 'secure'
drives, a driver may not open successfully unless the correct mount information
is supplied at creation time. Mount information, once passed into the drive, is
stored in the correspnding DPrimaryMedia object for the drive and is therefore
available for subsequent remounts of the drive following media change or machine
power down events. Mount information can be cleared by passing in a NULL mount
info descriptor.
b) TInt ForceRemount(TUint aFlags);
This forces a local drive to be remounted. This is a replacement for the
function UserSvr::ForceRemountMedia(TMediaDevice aDevice) since the latter
requires knowlege of the h/w platform in quesion in order to select the
appropraite TMediaDevice value for a particular drive.
3) Added SetMountInfo() function to TLocDrv class and modified TLocDrv::Open()
so this no longer takes a 'const TDesC* aMountInfo' parameter. Corresponding
change to DMedia::Open() function which also no longer has a
'const TDesC* aMountInfo' a parameter. The mount info is intead stored in the
DPrimaryMedia class which has two new functions:-
TInt SetMountInfo(TLocalDriveMessageData &aMountInfo,TInt aMediaNum);
TMediaDrvDescData* MountInfo(TInt aMediaNum);
4) Change to DMediaDriver class which now supplies the DoCreate() function and instead
requires a derived driver class to supply the pure virtual function:-
Int Open(TMediaDevice aMediaDevice).
In most cases, convertion of existing non-removable drivers will require the existing
DoCreate() function to be renamed Open().
Version 1.02.359
================
(Made by JonathanM, 18/07/2001)
1) Morgan
1) Implemented CR MHEY-4XHN9D "Move DPassiveDebugger implementation out
of the core kernel"
Exported the following functions and K32DBG.H
ImpMmu::AllocatePageTable(unsigned long, unsigned long, int)
DPlatProcess::DataSectionBase(DPlatChunk *) const
ImpMmu::FreePageTable(int, int)
Moved ka_edbg.cpp from all ASSPs and
\e32\ekern\epoc\arm\kc_edbg.cpp into a device-driver/extention in
\tools\debugger_stub\passivestub\...
2) Removed DDebugger initialisation calls from boot.
A DDebugger implementation should load itself as an extension or a
device driver, and install using Plat::SetDebugger(debugger);
3) Added __ENABLE_NOTIFY_DEBUGGER__ macro to enable/disable debug support
in the kernel. Currently on in UREL and UDEB builds by default.
4) Cogent passive debugger now lives in \tools\debugger_stub\passivestub
and is built as EDEBUG.LDD. Include this as an extension to get
Lauterbach OS aware debug. Or load it as an LDD with DEBUGGER.EXE
"DEBUGGER load" from the command line
5) Helen debugger now lives in \helen\debugger and built as EDEBUG.LDD
See 4) for usage.
2) Nicolas
1) The kernel data/bss section can be relocated to any fast
RAM bank by setting KBdbFlagKernelData in the
appropriate BDB bank descriptor (generic bootstrap
only).
2) The supervisor stack/heap can be relocated to any fast
RAM bank by setting KBdbFlagSvStackHeap in the
appropriate BDB bank descriptor (generic bootstrap
only).
3) The kernel stacks (reentrant, null, irq, fiq, exception)
can be relocated to any fast RAM bank by setting the
relevant bit (KBdbFlagStack*) in the appropriate BDB
bank descriptor (generic bootstrap only).
4) The kernel stacks are now allocated by the generic
bootstrap (either in DRAM or fast RAM). Super and CPU
pages layout modified to pass stack info to the kernel.
Each variant using the generic bootstrap calls
Arm::Init1Stacks() from ImpHal::Init1() to initialise
the stacks.
5) For the windermere port which does not use the generic
bootstrap, the stacks are statically allocated in the
ASSP layer and ImpHal::Init1() initialises the
Arm::*StackTop and PP::*StackTop pointers.
6) The exception vectors, handler and dispatch table can
be relocated to any fast RAM bank by setting
KBdbExcCode4k in the appropriate bank descriptor
(generic bootstrap only). There also exist
KBdbExcCode8k and KBdbExcCode12k in case the exception
handlers get bigger in the future.
7) The exception vectors are now located at 0xFFFF0000 on
platforms which support this. Grep for
__CPU_EXC_VECTORS_MOVABLE in u32std.h for a
comprehensive list. As a consequence dereferencing
NULL pointers in privileged mode now enters the debug
monitor.
8) Fix defect CLE-4Y4EMG (Bootstrap doesn't fill in Rom
config section completely): ROM type fields now
correctly initialised in the super page.
9) Bootstrap test code added for assabet.
10) Bootstrap documentation updated.
11) Template port updated.
3) Michael
1) Fixed Helen crashing (exc id 26) at boot-up time: ImpHal::Idle() in
\e32\ekern\epoc\arm\Helen\KA_UTL.CPP
2) Modified macro test() in e32test.h such that it now also displays the
respective source filename when an RTest test fails. Added the necessary
overloaded operator() and constructor to class RTest in us_test.cpp.
An occasional stack overflow problem has been fixed: we now pass the filename
string as a const TText* rather than a const TDesc& (_S() vs. _L()).
3) Fixed DPlatChunk::SetContiguousRamL() and DPlatChunk::SetHardwareL() in
\e32\ekern\epoc\kp_chk.cpp: too much memory was reserved upon creation of a
transfer buffer, too little freed after closing it.
4) Fixed CBitMapAllocator::ExtractRamPages() in \e32\euser\cbase\ub_bma.cpp:
eliminated a condition when the do/while loop would never be left.
5) added two exported static kernel functions: DThread* Kern::SvThread() and
DProcess* Kern::SvProcess(), frozen for mawd, mcga, mcoy, meig, mhelen, mint,
misa, mlnk, mtemplate, wins
6) HWA API:
- changed task parameter TaskID from type TInt to TUid
- RHwaTask::Close() and RHwaDevice::CloseTask() now return an TInt error code
from the kernel (actually from the PDD), rather than being void
- T_HWA: creating a contiguous transfer buffer from the user side now works,
added test of task messaging functions, misc. fixes.
4) Tim Band and Arun Sachamuneewongse
1) Added three 'next favourite' language specifiers to TLocale and
SLocaleData, and setters and getters for them in TLocale.
5) JonathanM
LCD Driver Portability Enhancements
Moved all display related code into new kernel extension (VIDEODRIVEREX)
New LDD stub (VIDEODRIVERLDD) provides access to this implementation.
Added HAL attributes
EDisplayIsMono, // Display is monochrome
EDisplayIsPalettized, // True if display is in a paletized mode
EDisplayBitsPerPixel, // Number of bits per pixel for current display mode
EDisplayMaxBitsPerPixel, // Max color resolution display mode
EDisplayMemoryAddress, // Start of video memory
EDisplayOffsetToFirstPixel, // Offset of first displayed pixel from EDisplayMemoryAddress
EDisplayOffsetBetweenLines, // Number of bytes between the first pixel in successive lines
EDisplayPaletteEntry, // To get, pass entry number (Color returned as 0x00bbggrr)
// To set, pass entry in bits 31-24, color in bits 23-0
EDisplayIsPixelOrderRGB, // True if physical pixel layout is RGB, false for BGR
EDisplayIsPixelOrderLandscape, // True if physical pixel layout is landcape, false for portrait
Added new exports to EKERN
DPlatChunkHw::DoCreateL(class TPhysAddrs* aAddr,TInt aCount,TChunkType aChunkType)
TBool Plat::CheckInWservThread() // Returns true if current thread is the registerd WSERV thread
void Hal::SetDisplaySizeInPixels(const TSize& aSize) // Inform kernel of display size in pixels
void Hal::SetPhysicalScreenSize(const TSize& aSize) // Inform kernel of display size in twips
void Hal::SetMaximumDisplayColors(TInt aMaxColors) // Inform kernel of number of phsysical colors
Removed the following methods
ImpHal::DisplaySizeInPixels()
ImpHal::PhysicalScreenSize()
ImpHal::MaximumDisplayColors()
Hal::DisplaySizeInPixels()
Hal::PhysicalScreenSize()
ImpPsu::DisplayOn()
Custom::DisplaySize();
Custom::PhysicalScreenSize();
Custom::DisplayOn();
Custom::DisplayOff();
Custom::MaximumDisplayColors()=0;
P::ClearScreen()
6) JonathanM
Fixes for base release.
1) Updated E32 and F32 version numbers.
2) Added IPR Policy files to base\assabetb\bootstrap\test (Category E)
and base\helen\debugger (Category B).
3) Fixed WINS EDISP build warning.
4) Changed T_VIDEO so that it doesn't build for WINS.
5) Modified OBY files for varients which now use the new VideoDriverExtension.
These now have "#define USE_VIDEODRIVEREXTENSION"
6) Removed spuriours Kern::Printfs.
7) Renamed Integrator VideoDriverExtension to match romkit name pattern.
8) Fixed bug in MISA videodriver GetPaletteEntry function.
9) Removed always on tracing from brutus screen driver code.
10) Fixed Integrator ROM building (needed to include video driver by correct name
and exclude the old Neon250 kernel extension.
Version 1.02.358
================
(Made by Michael, 19/06/2001)
1) MichaelP
1) Added (many) and modified (some) files for the MHELEN ASSP base port.
2) Modified macro test() in e32test.h such that it now also displays the
respective source filename when an RTest test fails. Added the necessary
overloaded operator() and constructor to class RTest in us_test.cpp.
3) Reverted the change of the test() macro mentioned under 2) because of stack
overflow problems with some programs which were detected during the link
stage. This needs to be further investigated. For the time being we use the
old version of test().
4) Updated HWA driver (LDD + WINS PDD) and API code. Added (bogus) PDD for Helen.
2) Nicolas
1) rom.cfg: suppressed no-header option for integrator.
2) Fixed defect FER-4XDH9P (Switch On messages not
received) on WINS by calling Power::SwitchOn() when
waking up following normal or emergency standby.
3) Deleted Eiger custom bootstrap because the port
actually uses the generic one.
3) MarkCa
1) Fixed EDNHLJT-4WZGTD (Secure mmc - "Invalid" after cancelling pw change
& FM panic) and related EDNHAAO-4WZFYR (Secure MMC: Note "Invalid" shown
after updating the file system.) New media attribute KMediaAttHasPassword
shadows PWD_LEN != 0 in card, and controller backs up store before
password operation, recovering on failure.
2) Fixed CAN-4WJHJN (6.0) and EDNMCAN-4VYKTY (6.1) ("File server must accept
new MultiMediaCard password encoding scheme".) Password notifier
changed to encode passwords as Unicode.
3) Enabled debug password notifier for F32 fix EDNPCHY-4VWP5B
(problems with secure mmc implementation.) This completes after
a user specified period and is used to debug using F32 when a
notifier is raised.
4) Implemented CR PSCE-4VMP3K to set hard limit for RAM drive. New HAL
attribute EMaxRAMDriveSize must be set to size in bytes, where value
includes FAT.
4) TimBa Fixed bug in MatchF: if argument was an empty descriptor, it always
returned null. Now if the candidate is nonempty it returns KErrNotFound.
Version 1.02.357
================
(Made by Carlos, 31/05/2001)
1) William
1) Change DebugThreadPanic to use a struct for the debugger-friendly values, so that
a simple autoexp.dat change will display the panic details properly.
2) Dennis
1) Fixed defect HAR-4WSGJ5 (RArray::FindInUnsignedKeyOrder not returning KErrNotFound).
This was due to problems with the special case handling of 4 byte entries in the ARM
assembler version.
2) Fixed problem with MCOY failing to boot when image was loaded using RedBoot
instead of RT bootloader.
There were two problems - a spurious CIU interrupt and the fact that the RTC correction
and LastSetTime were uninitialised.
3) Nicolas (RHR 113.1 completly implemented)
1) 5mx: Set LCD contrast to its default level every time
the screen is switched on. This works around the
regression introduced while cleaning up the Hal class (p4 changelist
(the screen was completely black and unusable).
2) Fixed typo in ImpMmu::UnmapPage(): confusion between pde and pte.
3) Added support for TC RAM banks in generic bootstrap.
Hardware-specific initialisation is left as an
exercise to the system integrator. It should be done
in HWInitialise().
4) Added new consistency checks in generic bootstrap
(ROM/RAM bank ordering, bank overlap in
physical/linear space). Enabled for UDEB only.
5) Partially implemented scheme allowing to fake IRAM on
assabet (disabled).
6) Reorganised bootstrap test code: generic code moved
from brutusa to bootstrap.
7) Ported bootstrap test code on assabet.
4) JonathanM
1) Added a new export to the BLD.INF files for BRUTUSA and ASSABETB.
VI_POWER.H is now exported to KERNEL\SA1100\ to enable the sound drivers to
set their power requirements.
5) AndrewCu
1) Small changes to the RNotifier class in e32 (for Uikon 6.2 Dialog Server work).
6) Tim Band
1) Changed TChar functions that query the type of the character so that
they do not make an Exec call
2) Made Private Use Area characters graphical and printable according
to their meaning
3) New folding code that respects Unicode
4) Removed Uzbek, Tajik and Azerbaijani from language list, added
Tagalog in place of Azerbaijani
7) CarlosF
1) Several changes to Assabet Variant to get LFFS to mount on C:\ drive. This ended up
being made configurable, Switch 4 of the switch-pack on the Companion Chip Card
is used to decide wheter to Mount FAT or LFFS on drive C:\.
1) Nicolas (RHR 113.1 completly implemented)
1) 5mx: Set LCD contrast to its default level every time
the screen is switched on. This works around the
regression introduced while cleaning up the Hal class (p4 changelist
(the screen was completely black and unusable).
2) Fixed typo in ImpMmu::UnmapPage(): confusion between pde and pte.
3) Added support for TC RAM banks in generic bootstrap.
Hardware-specific initialisation is left as an
exercise to the system integrator. It should be done
in HWInitialise().
4) Added new consistency checks in generic bootstrap
(ROM/RAM bank ordering, bank overlap in
physical/linear space). Enabled for UDEB only.
5) Partially implemented scheme allowing to fake IRAM on
assabet (disabled).
6) Reorganised bootstrap test code: generic code moved
from brutusa to bootstrap.
7) Ported bootstrap test code on assabet.
Version 1.02.356
================
(Made by Pete, 10/05/2001)
1) MarkCa
1) Added base support for store LFFS optimization. KDriveAttTransaction
bit added to \e32\include\e32std.h.
2) Dennis
1) Added mouse driver and VGA video driver for Integrator.
2) Renamed the text window server DServer object to "TextWindowServer".
3) Morgan
1) Implemented Silent Running on Assabet
4) Pete
Further changes to MMC Controller:-
1) Renamed the function
DMMCSession::FillCommandDesc(TMMCArgumentTUint32,TUint8*,TUint32) to
FillCommandArgs() since it doesn't actually result in the command descriptor
array being updated.
3) Removed check from DMMCStack::IssueCommandCheckResponseSM() whether
a multiblock read/write command has been selected with a total length less than
a block. This is redundant.
4) Modified DMMCStack::CIMReadWriteBlocksSM(). This
function no longer sets up the command descriptor array for special block transfer
commands (but expects this to have been already done before the function is called).
8) Further change to the WINS local drive mappings. The entire local drive mapping for
WINS is now as follows:-
Local drive 0: Internal RAM drive (EFixedMedia0) - Y:
Local drive 1: 1st special MMC Card on MMC socket 0 (ERemovableMedia0) - X:
Local drive 2: 2nd special MMC Card on MMC socket 0 (ERemovableMedia0)
Local drive 3: MMC Card on MMC socket 1 (ERemovableMedia1)
Local drive 4: Not currently assigned
Local drive 5: Not currently assigned
Local drive 6: Not currently assigned
Local drive 7: Not currently assigned
Local drive 8: Internal LFFS drive (EFixedMedia1) - W:
5) Pete
1) Modified bootstrap for Cirrus7211a so that this now runs at 36MHz.
6) Nicolas
1) Added fixed size internal RAM banks in generic
bootstrap.
2) Introduced support for area relocation in generic
bootstrap. Every kind of file (including the primary)
can be relocated to an internal RAM bank.
3) Updated generic bootstrap version number to 2.1.
4) Submitted Richard's bootstrap test files.
5) Removed MCORE stuff from generic bootstrap.
6) Inversed order of "static" and "const" in _LIT()
definition to avoid lint warning.
7) Added assabet.mbc (metabuild script).
8) Implemented RProcess::GetMemoryInfo(). This allows to
extend GDB so it can attach itself to running threads.
7) Michael
1) Added overloaded function:
DTransferBuffer* TransferBufferFromHandle(TInt aHandle, DThread *aThread)
to \e32\include\k32std.h, exported and frozen for all BUILDS. Function
implemented in \e32\ekern\ks_transbuf.cpp. This function is used where the
current thread is not the same as the one that created the handle.
2) Changed behaviour of DPlatTransferBuffer::~DPlatTransferBuffer() and
DPlatTransferBuffer::DoClose() in \e32\ekern\emul\win32\kp_transbuf.cpp and
\e32\ekern\epoc\kp_transbuf.cpp: iChunk gets only deleted if it actually exists,
i.e. is non-NULL
3) Numerous changes to HWA implementation (User API, LDD and WINS PDD), work
still ongoing.
Version 1.02.355
================
(Made by Nicolas, 04/05/2001)
1) William
1) Changed the WINC-only KernelStarted semaphore to be anonymous, to prevent
problems with concurrent WINC execution on a multiple processor build machine.
This will not re-open defect EDNGBON-4JYNU6 "Inaccessibility of request
semaphores breaks EPOC connect" because this isn't a request semaphore.
2) Fixed TGlobalAlloc to use User::AllocL rather than new[], and User::Free instead of
the mismatched delete. This will now work even if new[] plays funny tricks (which
is the case with CodeWarrior) and makes the User::ReAllocL call legitimate.
2) Nicolas
1) Merged 6.1 release branch back into the mainline.
Version 1.02.354
================
(Made by Dennis, 20/04/2001)
1) AndrewJ
1) Changed the misa kernel.iby file to detect whether the build is for
Assabet varient. If it is for assabet an alternative estart is
included in the rom which automatically loads the LFFS on to K: drive
as well as other tasks performed by estart. This should not take place
on any other platform.
2) The generic estart is only loaded (in f32) for non Assabet platform as
added a definition call CUSTOM_ROM that is only defined for assabet.
3) Added estart.cpp /assabetb/ and loadlffs.cpp to /assabetb/lffs/ for
new estart.exe component loaded only fopr Assabet.
4) removed /test/ subdirectory in /assabetb/lffs/ as nothing it it is or
should be used.
5) removed obsolete definition of BASE_ROM from F32tests.oby,
E32tests.Oby and Alltests.oby
2) Morgan
1) Deleted \e32\bmarm\EXYIN.DEF
2) Added EPenState attribute to HAL to get/set state of the digitiser.
3) Added EKeyboardState.
4) Added pen/display get/set functionality to BRUTUS HAL DLL and driver.
5) Added Enable() and Disable() functions to digitiser driver on Brutus.
6) Tweeked Brutus digitiser driver to send switch on events when coming
out of standby or hibernation (disabled) mode.
7) Removed LCD switch on from LCD power handler.
8) Generic kernel now doesn't call DisplayOn().
9) Added Power::SwitchOn() that can be called from device drivers to
send a ESwitchOn event if the KPowerUserCpu bit is not set. Does the
same thing as a call to SetRequirement(KPowerUserCpu | ...) but is
easier to understand.
Added variant that takes a TRawEvent to specify which event is sent
for switch on.
Call Power::SwitchOn() from your device driver to cause full UI switch
on.
10) Tidied Brutus HAL DLL startup code.
11) Made text window server take responsibility for turning on the screen
at switch on.
12) Tidied Assabet HAL DLL startup code and removed spurious panicking
code.
13) Updated HAL\DOC\HAL.DOC boilerplate startup code.
14) Made display on imply switch on, and send events as appropriate
15) assabetb, cirrus7211a, series5mx1 variant updates to maintain current
behaviour.
16) Changed the prototype of DPowerModel::PowerStandby() to return an error
value.
3) Dennis
1) Fixed a problem with creation of fixed address chunks with initial
size zero.
4) Jonathan
1) Removed redundant Hal and UserHal functions from kernel and ASSPs.
2) Refroze kernel exports for all platforms other than WINS/WINC.
3) Removed associated variant functions and, where necessary to implement
the HAL API, re-implemented them via a HAL driver on the mainstream
platforms Brutus, Assabet and VTemplate. Other variant DLLs still
contain some redundant functions and may not have implementations for
all appropriate HAL attributes.
5) Carlos
1) Several changes to Assabet Variant to get PC Card working
2) Assabet builds its own ATA driver (vi_medata.cpp). The generic ATA
driver is not used. Changed the MISA kernel.iby to allow Brutus to use
the generic ATA driver and Assabet to use its Variant-specific one.
6) Dennis
1) Added integrator port. No screen or serial drivers yet.
7) Pete
4) Fixed SCE-4V7S6C "MMC Controller card init. function is in-efficient
and unnecessarily complex". This entailed:-
- Add new TMmcCardArray class to replace the DMMCStack::iCxNewAcqArray[]
and DMMCStack::iCards[] arrays and their associated functionality.
- Removal of ASSP layer function DMMCStack::PhysicalCardSlots()
function as this was duplicating information already returned in the
ASSP layer function DMMCController::SetMachineInfo() function.
- Addition of generic layer DMMCStack::Init() function to determine
the max. number of cards for the platform once - at Controller
init. time rather than every time a card stack is initialized.
- Modification to DMMCStack::PowerDownStack() function to add an extra
argument to this function (TBool aMediaChange) indicating whether
the power down is required due to media change or not.
- Removal of the 'update stack' implementation in the generic layer of
the Controller. This was intended to re-scan for new cards after a
media change. This is now redundant since all cards are always
powered down on media change.
- Various comments added throughout PS_MMC.CPP to aid clarity.
5) Fixed FID-4UZLFG "Increase number of supported local drives"
8) Nicolas
1) Added \brutusa\brutusa.mbc
2) Cogent: Moved call to ImpHal::EnableIrqs() from ImpPic::Init3() to
beginning of ImpHal::Init3() to avoid the board hanging forever while
initialising the PCI base module.
9) William
1) Removed temporary WINSCW workaround in up_i64.cpp, now that the CodeWarrior
compiler supports the BT instruction.
2) Added WINSCW-specific variation of the path constants in up_path.cpp
3) Rearranged win32/up_trp.cpp version of TTrap::Trap() so that the register
saving happens before the C++ code to manipulate iResult and aResult. This
avoids a problem where the CodeWarrior compiler was saving EBX on the stack and
and using it as a temporary during the iResult/aResult mangling, causing the
wrong EBX value to be restored during Leave.
Version 1.02.353
================
(Made by RobertJ, 26/03/2001)
1) Carlos
1) Several Changes in Assabet Bootstrap and vi_power.cpp in order to get
the Power Management/Sleep Mode working properly.
2) Changes to Assabet Keyboard driver/controller
3) Removed #define __USE_LEDS_FOR_SYSTEM_DEBUG. User software can now use
those LEDs if they wish.
4) Had to implement a function in the Assabet Variant to allow enabling
RTC Interrupts. Surprisingly the SA1100 ASSP does not have these
functions!
5) Some changes to the SA1100 Interrupt controller (only affect Assabet
as they were changes in the way External Interrupts are handled).
6) Needed to export the Kernel function ImpMmu::LinearToPhysical as this
will be called from the Assabet Variant (vi_power.cpp).
7) Got rid of the debug message printed every time the Variant is called:
after waking up, a call to re-enable the Debug Port would attempt to
print this out and crash!
2) Alastair
1) Added initial transfer buffer functionality. Chief classes are
RTransferBuffer and RTransferWindow user-side, described in
E32TransBuf.h, and DTransferBuffer and DTransferWindow
kernel-side, described in K32Std.h. Test program is built from
e32test\mmu\t_transbuf.cpp, though the test isn't fully
complete yet. Also, the scheme doesn't yet cater for transfer
buffer access via transfer windows for "fixed" processes, though
it will shortly.
3) Nicolas
1) Introduced example metabuild script for MCGA (see
\cogent1\cogent1.mbc).
4) MarkCa
1) Fixed CAN-4TXKZQ (Using a PC Card can wrongly produce password
notifier)
2) Fixed CAN-4TWM6E (L7200 MMC Controller takes control of second UART)
Fix affects t_atadrv, so changed \l7200a\va_hw.cpp to use non-zero
machine uid.
3) Fixed CAN-4TYFHS (Reading to the end of a MultiMediaCard can produce
an out-of-range error)
4) Fixed EDNTDAS-4L4JZ8 (Thread leakage using emulators)
5) Fixed TOD-4RXJSS (Race condition causing accessing of already delete
pointer when deleting DChannelComm)
6) Fixed CAN-4UBJU2 (Controller does not process all error conditions)
7) Changed l7200\pa_mmc.cpp to return KMMCErrNotSupported because pre 2.1
controller.
8) Added __MLNK__ case to cpu defines in u32std.h.
9) Fixed CAN-4UNE8D (MMC Controller access violation after emergency power
down)
10) Removed KPBUS1 | KPBUS2 | KPBUSDRV tracing from mlnk\header.iby.
5) AndrewJ
1) Enabled LFFS on assabet.
2) Edited vi_hw.cpp and vi_pbus.cpp to enable LFFS on K: with PC Card
disabled.
3) put in fixes from 6.1 Numbers: SCE-4TVQ78
TOD-4RWEHL
6) Dennis
1) Fixed XScale RTC rounding problem
2) Added check for imprecise aborts on XScale - fault the kernel if they
occur.
3) iExtraData=FSR for both data and prefetch aborts.
*** Release note for XScale delivery ***
This release supports the Intel IQ80310 evaluation board based on the
XScale 80200 processor (Coyanosa). Code for this board can be built by
specifying platform MCOY on the build command line.
The following property definitions are used to specify the CPU type (in
\e32\include\u32std.h):
__CPU_XSCALE__
Means that the CPU is based on the XScale microarchitecture
__CPU_ARMV5TE
Means that the CPU supports the ARMv5TE instruction set
__CPU_ARM_ABORT_MODEL_RESTORED
Means that the base register is unaltered if a load/store with base
register writeback is aborted.
__CPU_SPLIT_CACHE
Means that the CPU uses separate instruction and data caches
__CPU_SPLIT_TLB
Means that the CPU uses separate instruction and data TLBs
__CPU_WRITE_BUFFER
Means that the CPU uses a write buffer
__CPU_WRITE_BACK_CACHE
Means that the CPU (data) cache supports write-back operation and that
the OS uses this mode for normal RAM allocations.
__CPU_CACHE_WRITE_ALLOCATE
Means that the CPU (data) cache supports line allocation on writes and
that the OS uses this mode for normal RAM allocations.
__CPU_CACHE_FLUSH_BY_LINE_ALLOC
Means that the (data) cache is cleaned/flushed by using an explicit
line allocate instruction.
__CPU_CACHE_POLICY_IN_PTE
Means that the (data) cache policy can be changed between writethrough
and writeback on a page-by-page basis using flags in the page table
entries.
__CPU_HAS_CACHE_TYPE_REGISTER
Means that the CPU possesses the cache type register as specified in
the ARM architecture reference manual (CP15 CRn=CRm=0, opc2=1)
__CPU_HAS_SINGLE_ENTRY_ITLB_FLUSH
Means that the CPU supports the 'Flush single ITLB entry by MVA'
instruction (MCR P15, 0, Rn, C8, C5, 1)
__CPU_HAS_SINGLE_ENTRY_ICACHE_FLUSH
Means that the CPU supports the 'Flush single ICache line by MVA'
instruction (MCR P15, 0, Rn, C7, C5, 1)
__CPU_HAS_BTB
Means that the CPU has a branch target buffer which needs to be
flushed explicitly in conjunction with partial ICache flushes.
__CPU_USE_MMU_TEX_FIELD
Means that the CPU supports the extended page table permissions (TEX)
field.
__CPU_EXC_VECTORS_MOVABLE
Means that the CPU allows the exception vectors to be relocated to
FFFF0000.
All E32 and F32 automatic tests pass on this release, with the exception
of:
T_PCCD1, T_PCCD2 - because the board does not support PCMCIA
T_DEBUGGER - because the debugger uses a bit pattern for breakpoints
which is defined in ARM Arch 5 (was undefined on ARM Arch 4). This
is being handled as a defect (defect number MAY-4V4E5V).
The branch target buffer is not enabled by this release. This is due to a
known problem when executing THUMB code with the BTB enabled.
7) Pete
1) First release of Hardware Accelerator (HWA) LDD and a crude emulation
of a HWA PDD on WINS.
2) Changes to MMC Controller to support SD Memory card initialisation.
3) Added TMMCCardArray class and various other minor changes to the MMC
Controller such (e.g. more comments).
4) Improved the WINS MMC emulation. Two cards are now emulated rather
than one as before. Also, better account of the current card status is
taken when deciding how to respond to an MMC command.
5) Change to the WINS local drive mapping. Local drive 2
is now the primary partition on the second emulated MMC card rather
than a secondry partition on the first emulated MMC card.
6) Temporarily disabled PC Card Peripheral bus (EPBUS.DLL) on Cirrus Logic
board and replaced this with MMC Peripheral bus to facilitate development
of SD Memory card development. (PC Card support will be restored once
the multiple peripheral bus Controllers are supported).
8) William
1) Added exported destructor to CAsyncCallBack, to solve a problem with
the CodeWarrior compiler.
Version 1.02.352
================
(Made by Morgan, 08/03/2001)
0) Requires E32TOOLS(173), E32TOOLP(226), F32(260)
from \\epoc\development\base\ongoing\...
1) Morgan
1) Split functions in UP_DLL.CPP into separate source files. This
allows the linker to discard unused functions.
Functions are grouped by functional area. up_dll_file.cpp,
up_dll_global.cpp, up_dll_static, up_dll_tls.cpp.
2) Split EDLL.LIB into EDLL.LIB containing the entrypoint and
EDLLSTUB.LIB containing the class Dll stub functions.
3) Removed strange .idata$3 padding from UP_DLL.CPP since (we think) it
is a hack for a defunct version of GCC
4) Moved thumb gcc helper functions into up_gcc.cpp in EGCC.LIB
5) Removed thumb gcc helper functions from uc_exe.cpp. These are now in
EGCC.LIB that should be included in the link of a GCC EXE or GCC DLL.
6) Moved float gcc helper functions into up_gcc_float.cpp in EGCC.LIB
7) Removed null definition of atexit() from up_dll.cpp
8) Deleted \e32\euser\epoc\arm\uc_dll.cpp since it is not used anywhere
9) Integrated MAWD DDebugger bug fix (again)
10) Added default cpu definition for __MTEMPLATE__ in U32STD.H to make it
compile
2) Carlos
1) Disabled the Pc Card on Assabet as it is not fully working and causes
problems when using the CF loader to download an image.
3) Dennis
1) Added basic port to Intel XScale 80200 CPU on IQ80310 board.
2) Fixed defect HAS-4U7N92 (T_WWINS hangs on Brutus). This is due to the
smaller screen size compared with the Series 5.
Modified notifier stuff to take account of the screen size.
4) RobertJ
1) Added notification of clear stall to USB Client
2) Fixed dma handling code for USB Client.
5) Alastair
1) Added initial transfer buffer functionality. Chief classes are
RTransferBuffer and RTransferWindow user-side, described in
E32TransBuf.h, and DTransferBuffer and DTransferWindow
kernel-side, described in K32Std.h. Test program is built from
e32test\mmu\t_transbuf.cpp, though the test isn't fully
complete yet. Also, the scheme doesn't yet cater for transfer
buffer access via transfer windows for "fixed" processes, though
it will shortly.
6) Nicolas
1) Introduced example metabuild script for MCGA (see
\cogent1\cogent1.mbc).
7) MarkCa
1) Fixed CAN-4TXKZQ (Using a PC Card can wrongly produce password notifier)
2) Fixed CAN-4TWM6E (L7200 MMC Controller takes control of second UART)
Fix affects t_atadrv, so changed \l7200a\va_hw.cpp to use non-zero
machine uid.
3) Fixed CAN-4TYFHS (Reading to the end of a MultiMediaCard can produce an
out-of-range error)
4) Fixed EDNTDAS-4L4JZ8 (Thread leakage using emulators)
5) Fixed TOD-4RXJSS (Race condition causing accessing of already delete
pointer when deleting DChannelComm)
6) Fixed CAN-4UBJU2 (Controller does not process all error conditions)
7) Changed l7200\pa_mmc.cpp to return KMMCErrNotSupported because pre 2.1
controller.
8) Added __MLNK__ case to cpu defines in u32std.h.
9) Fixed CAN-4UNE8D (MMC Controller access vilation after emergency power
down)
10) Removed KPBUS1 | KPBUS2 | KPBUSDRV tracing from mlnk\header.iby.
Version 1.02.351
================
(Made by Carlos, 20/02/2001)
1) Carlos
1) Added Assabet Variant (\Assabetb). This is an interim release
(see Release_Notes.txt)
2) Debug Monitor on SA1100 ASSP: now gets the serial port number to
be used as debug port from the variant TInt Variant::DebugInit().
3) Interrupt Controller on SA1100 ASSP: expanded the Interrupt controller
to work with Conceptual Interrupts (IRQ11-27) and external interrupts.
Also disabled the watchdog to free-up the OST Timer3 as an auxillary
timed interrupt source for LFFS.
4) Several changes to Brutus' Variant according to what's decribed above.
5) FIR Driver: Assabet allows setting the IR range. Therefore a new
Synchronous Request was introduced to deal with this.
6) ecomm driver - as above, passes the setting for the range on
iSIRSettings member of the Config structure.
7) Implemented EARLY DEBUG on SA1100 ASSP.
8) A few changes on the SA1100 ASSP implementation of PC Card Controller.
9) SA1100 Text shell: changed Background/foreground colours to improve
visibility on Assabet.
10) Text Shell (generic): now traps EKeyIncBrightness and
EKeyDecBrightness.
11) HAL: added Machine ID for Assabet on hal_data.h.
12) HAL: changed hal.iby file to include an HAL##VARIANT##.DLL to get
round the problem of having two Variants coming off the same ASSP but
not sharing the same HAL. Changed the hal.mmp on \assabetb, \brutus,
\cirrus721, \cogent1, \l7200, \series5mx1 and \vtemplate.
NOTE: Had to change \romkit\base.iby to allow overnight builds to
build correctly.
13) MISA EKERN def file (e32\bmisa\ekernu.def) - includes a new export
Plat::BindExtInterrupt(..) to allow binding to external interrupts
on Assabet.
14) Some changes on MISA .IBY files. LFFS is excluded for the time being,
even on Brutus. It will be put back when Assabet's LFFS is ready. The
bootstrap is now passed with the Variant extension to its name. Now
includes a Hal LDD in kernel.iby.
15) MISA Variants allowed (\e32\rombuild\rom.cfg): now allows 3 variants,
Brutus (BA), Assabet-only (A0) and Assabet+Companion Card (AB).
2) MarkCa
1) UART media change must now be explicitly compiled in for linkup
MMC port.
2) t_atadrv will now not run media change tests on linkup. Machine
UID modified in va_hw.cpp to avoid clash with Cogent.
3) William
1) Introduce __CW32__ defines for CodeWarrior, and adjust various
compiler-related definitions accordingly.
2) Workaround bugs in the CW inline assembler
3) Remove spurious WINBASEAPI decorations in euniw.h, which upset
CodeWarrior.
4) RobertJ
1) Fixed problem with FIR reads in D_FIR.CPP, the LDD. When read
completes to LDD from the PDD it was possible for another read to
complete the same user request.
2) Added first release of USB client for SA-1100. Components are
EUSBC.LDD, which is a generic LDD, and EUSBCC.DLL. \EUSBCC is the USB
Client Controller and loads as a KERNEL extension.
Version 1.02.350
================
(Made by Dennis, 05/02/2001)
1) William
1) Adjust the x86 inline assember in euser\emul\win32 so that it is
acceptable to the CodeWarrior compiler: change the 8000h style
constants to 0x8000, and change "_asm SomeLabel:" into "SomeLabel:".
2) Dennis
1) Added APIs to support execution of data as code, for use by just in
time compilers for Java and also for the ARM JBit extension. New APIs
are:
TInt RChunk::CreateLocalCode(TInt aSize, TInt aMaxSize, TOwnerType);
This creates a data chunk with a globally unique virtual address which
is allocated from the top of virtual address space (as for EXE and DLL
code chunks). The chunk is accessible only by the current process
(unlike DLL code chunks) and is marked by the kernel as containing
code. This means that on a split-TLB machine the ITLB will be flushed
when a reschedule occurs to or from a process with a chunk of this
type mapped into it and also when pages are decommitted from such a
chunk. The globally unique virtual address means that the ICache need
not be flushed on a reschedule.
RHeap* UserHeap::ChunkHeap(RChunk& aChunk, TInt aMinLength, TInt aGrowBy=KMinHeapGrowBy);
This creates a heap in an already existing chunk. It is intended to
allow a heap to be created in a local code chunk; this heap can then
be used to hold code fragments from a JIT compiler.
void User::IMB_Range(TAny* aStart, TAny* aEnd);
This performs whatever cache cleaning/flushing operations are
necessary in order to guarantee correct execution of code in the
specified address range (from aStart inclusive to aEnd exclusive),
under the assumption that this code has been loaded/modified by user
code. Typically this will involve cleaning the data cache for the area
concerned, draining the write buffer and flushing the instruction
cache and branch target buffer for the area concerned.
2) Added a new chunk type EUserSelfModCode to TChunkType to represent the
new chunks. Added a new attribute DPlatChunk::ECode to the DPlatChunk
iAttributes field to signify any chunk containing code.
3) Added code to notify the ARM ETM of reschedules if the PROCID register
exists (conditioned on __CPU_HAS_ETM_PROCID_REG).
4) Added support for kernel trace via the JTAG port on ARM720 and ARM920.
The KHARDWAREASSIST bit in the debug mask controls whether tracing is
directed to the JTAG port or to a UART.
5) Modified perl script halcfg.pl so that the output file is not opened
until the inputs have been parsed - this prevents strange error
messages due to a zero length file being generated.
Version 1.02.310
================
(Made by Morgan, 09/04/2001)
1) Jonathan
1) Move notes for releases prior to creation of 6.1 release branch to
releases_old.txt.
2) Pete
1) Fixed SCE-4V7S6C "MMC Controller card init. function is in-efficient and
unnecessarily complex". This entailed:-
- Add new TMmcCardArray class to replace the DMMCStack::iCxNewAcqArray[]
and DMMCStack::iCards[] arrays and their associated functionality.
- Removal of ASSP layer function DMMCStack::PhysicalCardSlots() function as
this was duplicating information already returned in the ASSP layer function
DMMCController::SetMachineInfo() function.
- Addition of generic layer DMMCStack::Init() function to determine the max.
number of cards for the platform once - at Controller init. time rather than
every time a card stack is initialized.
- Modification to DMMCStack::PowerDownStack() function to add an extra
argument to this function (TBool aMediaChange) indicating whether the power
down is required due to media change or not.
- Removal of the 'update stack' implementation in the generic layer of the
Controller. This was intended to re-scan for new cards after a media change.
This is now redundant since all cards are always powered down on media
change.
- Various comments added throughout PS_MMC.CPP to aid clarity.
2) Fixed FID-4UZLFG "Increase number of supported local drives"
Version 1.02.309
================
(Made by Will Ramsay, 03/04/2001)
1) Requires E32TOOLP(226), F32(237)
from \\epoc\development\base\ongoing\...
2) Backported Morgan's 6.2 changes to remove import stubs:
1) Split functions in UP_DLL.CPP into separate source files. This
allows the linker to discard unused functions.
Functions are grouped by functional area. up_dll_file.cpp,
up_dll_global.cpp, up_dll_static, up_dll_tls.cpp.
2) Split EDLL.LIB into EDLL.LIB containing the entrypoint and
EDLLSTUB.LIB containing the class Dll stub functions.
3) Removed strange .idata$3 padding from UP_DLL.CPP since (we think) it
is a hack for a defunct version of GCC
4) Moved thumb gcc helper functions into up_gcc.cpp in EGCC.LIB
5) Removed thumb gcc helper functions from uc_exe.cpp. These are now in
EGCC.LIB that should be included in the link of a GCC EXE or GCC DLL.
6) Moved float gcc helper functions into up_gcc_float.cpp in EGCC.LIB
7) Removed null definition of atexit() from up_dll.cpp
Version 1.02.308
================
(Made by MarkCa, 20/03/2001)
1) Morgan/AndrewF
1) Fixed FOD-4TAH7A "DMA double buffering will not work on Halla".
This is an interface change and it is not source compatable.
Added extra buffer fill during transfer initialisation for double
buffered HW. Added explicitly named enums and new imp functions
in ASSP to make writing ImpDMA easier.
2) Changed all ASSPs, and added implementation details to template
port.
Detail of changes required to \e32\ekern\epoc\arm\<assp>\KA_DMA.CPP:
a) Remove ImpDma::NextBlock()
b) Add the following functions:
/**
* No more DMA blocks for this transfer
*
* TO DO: (mandatory)
*
* Modify to suit your hardware. The code below is just an example
*
* If your DMA hardware has multiple buffers this function should be
* used to disable the empty buffer
*/
void ImpDma::FinalBlock(TInt aChannel);
/**
* Get the reason for the DMA interrupt.
* Called from TDmaInterrupt::Service()
*
* TO DO: (mandatory)
*
* Modify to suit your hardware. The code below is just an example
*
* EBufferEmpty indicates that one buffer is empty
* EStall indicates the entire transfer is complete, ie both buffers
* empty, FinalBlock() has been called.
* EError indicates a transfer error
* (ELastBuffer indicates that one buffer is empty and FinalBlock()
* has been called. On most hardware it is sufficient to return
* EBufferEmpty in this case)
*
*/
Dma::TDmaState ImpDma::GetState(TInt aChannel);
//
// Return ESingleBuffer or EDoubleBuffer
//
Dma::TDmaBufferMode ImpDma::BufferMode();
2) Nicolas
1) Fixed STE-4UEQC2 "The case off event and possibly some other events
do not get through WSERV correctly". EPOC doesn't any more send
two ESwitchOn notifications instead of one when starting up. The
emulator now sends only one ESwitchOn notification when being
switched back on after an emergency power off. The emulator sends
ECaseOpen or ECaseClose notifications when F11 is pressed while not
in standby mode. And finally the emulator doesn't any more switch
off automatically when the case is closed (this is up to the
user-side event consumer).
2) Fixed STE-4UJPEC "Some of the HAL attributes are not supported".
The following attributes are now supported on WINS: EPenDisplayOn,
ECaseSwitch, ECaseSwitchDisplayOn, ECaseSwitchDisplayOff.
3) T_NEWHAL TestGetAll() output modified to make it readable on a
small screen (key press expected when screen is full).
3) MarkCa
1) Fixed CAN-4UNE8D (MMC Controller access vilation after emergency power
down)
2) Removed KPBUS1 | KPBUS2 | KPBUSDRV tracing from mlnk\header.iby.
Version 1.02.307
================
(Made by Nicolas, 27/02/2001)
1) Jonathan
Manual e32test cleanup:
1) Moved T_COLOUR from a manual to a support test since no-one bothers
implementing text video modes other than mono. Made those screen
drivers that didn't already return KErrNone from SetMode(EMono).
2) Moved T_PS and T_WWINS from manual to support tests since they're not
useful.
3) Nuked T_PTNOS test and D_PTNOS test driver.
4) Nuked T_REGRAM registry test (which was lurking unused since v6.0).
5) Made T_INF prompt for confirmation that displayed values are OK, so
if not OK an error appears in the test log.
6) Fixed FID-4TXFVX "Wrong defaults for MainBatteryGood()".
7) Fixed FID-4TYF78 "FIQ link with battery state is broken".
8) Fixed BAR-4SMG99 "Efficiently implement the "MergeModifiers" function
in e32\include\K32KEYS.INL".
9) Fixed FID-4RRMTH "bootstrap: Bug searching for sleep info block".
2) MarkCa
1) Fixed CAN-4TXKZQ (Using a PC Card can wrongly produce password
notifier)
2) Fixed CAN-4TWM6E (L7200 MMC Controller takes control of second UART)
Fix affects t_atadrv, so changed \l7200a\va_hw.cpp to use non-zero
machine uid.
3) Fixed CAN-4TYFHS (Reading to the end of a MultiMediaCard can produce
an out-of-range error)
4) Fixed EDNTDAS-4L4JZ8 (Thread leakage using emulators)
5) Fixed TOD-4RXJSS (Race condition causing accessing of already delete
pointer when deleting DChannelComm)
6) Fixed CAN-4UBJU2 (Controller does not process all error conditions)
3) Dennis
1) Fixed defect HAS-4U7N92 (T_WWINS hangs on Brutus). This is due to the
smaller screen size compared with the Series 5.
Modified notifier stuff to take account of the screen size.
2) Fixed defect HAD-4T2EJ5 (P::TimerLockSpecToTicks returns incorrect
value).
3) Fixed defect MAT-4TYKLE (Profiler doesn't work on Quartz/Brutus).
Version 1.02.306
================
(Made by Markdo, 07/02/2001)
1) Tim Band
1) Fixed BAD-4SVJY8 "Unavoidable initialisation cost for TRect, TPoint
and TSize"
2) Alastair
1) Fixed EDNTBAD-4Q8M2F "CBufSeg can leak memory"
2) Fixed EDNATHE-4QQJSU
"Inconsistent error handling in use of S::MakeHandleAndOpen",
though there's still some work to be done in this area.
3) Fixed FID-4RKDJT
"Use Cogent key translation tables on template port"
4) Fixed HAD-4RLFVN
"Template header.iby has exyin.dll as file instead of extension"
5) Fixed HAD-4RLFSY
"Template header.iby missing kerneltrace entry"
6) Fixed FID-4SNDAD
"TemplatePort: Tick counter not invalidated when time changed"
3) Morgan
1) Integrated fix for DPassiveDebugger allocation bug for
WINDERMERE
4) Jonathan
1) Created new \e32\ekern\emul\win32\d_entry.cpp as a copy of
\e32\euser\emul\win32\up_dll.cpp. This allows edev.lib to be built
for WINS in an IPR Category E only build. To preserve layering WINS
device driver initialisation no longer wires the kernel.
2) Documented the deprecated nature of UserHAL enums in e32hal.h.
Added minimal documentation to \hal\inc\hal.h and hal_data.h.
5) MarkCa
1) Update linked build by removing warnings from linkup ekern and
implemented polling after MMC data transfers.
Version 1.02.304
================
(Made by Pete, 19/01/2001)
1) Morgan
1) Fixed EDNSCHM-4M7PAJ. Added RMessagePtr::IsNull()
2) Fixed EDNJPAR-4KLLCA "Brutus bootstrap contains large delay..."
3) Fixed EDNRFID-4NVFWF "Bootstrap test-code has Brutus-specific code"
4) Fixed EDNRFID-4MVEQV "Bootstrap: bug in RAM width checking"
5) Fixed EDNRFID-4MVKBL "Bootstrap attempts to write to ROM"
6) Fixed EDNRFID-4NXETX "Bootstrap: bugs mapping IO as sections"
7) Fixed EDNWROS-4LQEPN "bootstrap component -WHAT output incorrect"
8) Fixed EDNRFID-4LGBVH "Bootstrap should keep PE file"
9) Fixed EDNRFID-4PXFYK "Add buffered, not cached flag to bootstrap"
10) Fixed EDNRFID-4PTHXH "Flush D TLBs & Cache in bootstrap after enabling
MMU"
11) Fixed EDNRFID-4MVJZQ "Bootstrap bugs finding initial scratch RAM"
Tested on COGENT, BRUTUS, [UDEB,UREL]
12) Fixed HEY-4STFK7 "Template port: Definition of interrupt names
should..."
13) Fixed TOD-4RJJ75 "Corruption of K::TickQ". This fix creates a change
in the behaviour of the emulator - comms power handler active requests
keep the power requirement up. In practice this means that the
emulator will never power off. A proper fix will have to wait for v7.
2) Pete
1) Fixed a problem introduced in release 303 with the
Cirrus bootstrap which was mapping in 16K rather than 12K for the h/w
registers.
2) Changes to the MMC Controller - to the way that the
ASSP layer reports the operating PSU voltage. Removed TOCR class.
3) Dennis
1) Modified low-memory notification system. There are now two TChanges
flags: EChangesFreeMemory and EChangesOutOfMemory. The first is raised
if the free memory level crosses the relevant threshold, and the
second is raised if an allocation fails due to insufficient free
memory.
4) Jonathan
1) Brutus HAL: Fixed defect EDNABOT-4MCGNL "HALData::EKeyboardClickVolume
doesn't accept valid value". Key click and digitiser click are not
supported on Brutus for 6.1. Changed the values reported by HAL to
reflect this. Cogent was similarly incorrect.
2) Added memory traces for kernel stack and data.
3) Brutus keyboard: Fixed defect JAN-4RLLH3 "Brutus board doesn't map
EKeyDevice key codes". Made Fn modifier generate EKeyDevice0-9. Fixed
some Fn and Shift translation errors.
5) Markdo
1) Implemented Pc Card Controller for Cogent. Controller is disabled (by
setting total supported drives to 1) until timer problem sorted out.
2) Fixed problem in Brutus Pc Card Controller where reset signal not
asserted for long enough when powering up. Reduced length of time spent
in Sa1100::BootWaitMilliSeconds when called in \brutus1\vi_pbus.cpp.
3) Ensured that uart1 in linkup initialised in release builds.
4) Implemented dma on linkup.
6) MarkCa
1) Merged in MMC security code. _LOCKABLE_MEDIA in e32svr.h is not
commented out any more.
2) Updates to linkup example mmc port.
Version 1.02.303
================
(Made by RobertJ, 13/12/2000)
1) Nicolas
1) ECOMMDCE: Cancel power handler timer and reset power requirements in
DChannelComm dtor (pasted from ECOMM). This avoid a kernel panics
in DPowerHandler::RemovePowerModel() when a DCE comm port is
closed.
2) Added DISTRIBUTION.POLICY file (cat. E) to \e32\rombuild\mlnk and
removed superfluous ones from E32 and BOOTSTRAP.
3) Modified rom.bat to avoid spurious error msg when some files
included in the ROM image contain "warning" or "error".
2) Dennis
1) Removed all MCORE code.
2) Minor consolidation of MMU-related #ifdefs in order to support ARM920.
__CPU_SOFTWARE_CACHE_FLUSH, __CPU_CACHE_CONFIGURABLE have gone.
__CPU_ARMV3 is no longer supported.
Remaining #ifdefs with meanings are:
__CPU_CACHE_POLICY_IN_PTE
This means that you can select write through or write-back caching
on a page-by-page basis.
__CPU_WRITE_BACK_CACHE
This means that write-back caching is being used. This may be
either because the cache only supports write-back mode (eg SA1100)
or the cache supports both modes and write-back mode is being used
(eg ARM920). If this is not defined and the cache can support both
modes, write-through caching will be used.
__CPU_CACHE_FLUSH_BY_DATA_READ
This option is only applicable if write-back caching is in use.
It means that the cache must be flushed by reading spurious data
(i.e. SA1100 mode). Currently the data used for flushing is always
mapped at 0x430fe000 and a cache size of 8K is assumed. If this
option is not selected and write-back caching is in use, the
ARM920 method is used (ie flush each line by way/set index) and
the CP15 cache config register is read to determine the size and
layout of the cache.
__CPU_SPLIT_CACHE
This means that the processor has separate instruction and data
caches.
__CPU_SPLIT_TLB
This means that the processor has separate instruction and data
TLBs.
3) Added low memory notification. This uses two thresholds (low and
good). If a low-level chunk adjust or allocation of page tables fails
due to out-of-memory or causes the amount of free memory to drop below
the low threshold, all change notifiers are signalled. If a low-level
chunk adjust or freeing of page tables causes the amount of free
memory to rise above the good threshold change notifiers are also
signalled. A new change notifier flag (EChangesFreeMemory) has been
added to signify the occurrence of one of these conditions. A new
function
TInt UserSvr::SetMemoryThresholds(TInt low, TInt good)
has been added to set the thresholds at which notification occurs.
Test program T_CHUNK has been extended to test this system.
4) Fixed defect EDNATHE-4LCEWZ (Sessions using global message pool can
lose available slots).
5) Fixed defect PAR-4R6DGK (WS_MAIN.CPP should have an extra line of debug
to warn you that you have booted in test mode).
6) Fixed defect EDNJPAR-4L2LMM (WS_MAIN.CPP has a leave without a trap).
7) Fixed defect EDNJPAR-4N9GU2 (TEiger:: missing from added 7211 functions
in ka_eiger.cpp)
8) Fixed defect HAS-4R5NPC (JTAG trace example in template variant).
3) Alastair
1) Fixed EDNJHAS-4QLRPC "All 3rd UIDs wrong" (in the template port).
Uids are now the UNICODE rather than narrow values.
2) Split this file up on the assumption that its large size is the
reason P4 sometimes has difficulty accepting changes to it.
Old release notes are now in release_old.txt.
3) Fixed EDNJHAS-4QNRUB "Template variant include file in E32" by moving
it into the vtemplate directory and exporting it from there.
4) Fixed EDNJHAS-4QNR4M "Template ASSP is in the wrong place"
5) Changed include paths in VTemplate .mmp files so that they no longer
refer to \e32\include.
6) Added DISTRIBUTION.POLICY files (cat. E) to the \VTemplate
directories.
7) Fixed EDNABRY-4L8NR2 "Text console appears stripy on Windows 95"
8) Fixed problem with emulator parent window appearing jazzed if no
bitmap is specified on Windows9x platforms.
9) Fixed EDNJBRN-4MEP5F
"Threads that use a shared heap don't get their stack 0x29 filled".
10) Fixed EDNATHE-4QQKZM
"RThread().Suspend() deadlocks the emulator".
Under WINS/WINC, if a thread is about to suspends itself then it
relinquishes the kernel critical first.
11) Fixed EDNTEEA-4L4BHV
"WINS emulator does not remember its previous position".
Emulator only remembers its position if it's shutdown with Alt+F4 or
via the Windows menus, not with typing "exit" in eshell or exiting
from a test. It is clever about not "reappearing" off-screen.
12) Extended Dennis' low memory notification changes to work under WINS.
13) Fixed defect FID-4RDJTJ
"Template port keyboard driver generates streams of keyup"
14) Fixed defect FID-4RHKC9
"Template Idle function should not be naked"
15) Fixed defect EDNNGRE-4LGJU7
"UserHal::SwitchOff() hangs emulator if mouse is pressed".
Problem: Emulator would power off but not minimise since mouse button
was down, and power on requires impossible window restoration.
Solution: No longer minimise and maximise Emulator window to emulate
Power Off and Power On. Instead, blank screen for Power Off. Power
back on when EStdKeyOff (F9 by default) is pressed. Power on also if
screen is tapped, or case is opened (toggle F11 by default), depending
upon EPointerSwitchesOn and ECaseOpenSwitchesOn
HAL/machine_configuration settings: these values now default to TRUE
for WINS.
4) MarkCa
1) Fixed defect EDNJHET-4PTLUD (Emulator crashes on startup if com
ports used by another program under win98.)
5) Pete
1) Modified the FIR LDD so it conforms with latest power handling scheme
(i.e. it requests it's power requirement on all tx requests while at
the same time setting a timer to releases these requirements if it is
allowed to expire). This in turn required an extra function to be
added to each FIR PDD - PowerRequirement() which returns the FIR power
requirements for that particular platform.
2) Fixed warnings when building WINS version of MMC Controller.
3) Modified TBusLocalDrive class and the associated local media
sub-system so that an info. descriptor can be passed down to the media
driver which is available to the driver at the point at which it is
opened.
4) Fixed warnings when building WINS version of MMC Media Driver.
5) Applied various bug fixes supplied by Pete Sanders for Cirrus Logic
build:-
- Increased BDB IO block size from 8K to 16K in bootstrap.
- Moved addition of power handler from Variant::Init3() to
Variant::Init4().
- Set mem. config registers for both banks of 8Mb flash in
Variant::Init1().
- Fixed problem with digitizer resistive plate enable signals.
6) Morgan
1) Fixed EDNGTIN-4KUH3E "Dll::FileName inconsistent in ARMI",
Mini-loader now forms the filename correctly.
2) Fixed memory allocation bug in DPassiveDebugger
2.1) Fixed empty members of DProcess for bootstrapped processes,
(kernel and file server) for the benefit of the debugger
3) Enabled DPassiveDebugger on Cogent UDEB builds
4) EDNMHEY-4N3FV8 "TDma::iChannel should be set back to ENotBound ..."
5) PAR-4R5EGK "Definition of interrupt name should be in ASSP header ..."
Moved interrupt name definitions from ka_pic.cpp to a32*.h
MCGA, MISA, MAWD, MLNK, MEIG
6) Updated Cogent1, Brutusa, Series5mx1, l7200a, cirrus7211x, variants to
use symbolic interrupt names
7) Updated \e32\rombuild\rom.cfg to match stricter options in ROMBUILD
7) Jonathan
1) Changed meaning of KMEMTRACE kernel trace option. Now only traces
changes in chunk committed size and does not trace RHeap allocation.
8) Markdo
1) Changed WINS simulated mmc drive to 1MB size (from 2MB).
9) William
1) Added iRomRootDirectoryList to TSuperPage in K32STD.H
2) Added TExtensionRomHeader in E32ROM.H
3) Modified epoc\kp_ini.cpp to get the iRomRootDirectoryList from the
superpage
4) Changed bootstrap to pass the iRomRootDirectoryList address vai the
superpage, and added code to support extension ROMs. If a valid
extension ROM is found, the Root Directory List comes from the
extension rather than the main ROM.
Version 1.02.302
================
(Made by Nicolas, 19/10/2000)
1) Alastair
1) Applied fix which will be made on the release branch to EDNJBON-4PBJFD
"Crystal emulator won't run under Windows 98"
2) Replaced calls to Win32 "W" suffixed functions, which won't work on
Windows9x platforms, with new versions supplied in EUNIW.DLL.
3) Merged in Template Port from //epoc/release/bpk/.... This builds as
platform MTemplate and the variant is described by the \VTemplate
directory. Function comments have been changed to JavaDoc format.
Changes have also been made in accordance with Jonathan's changes to
E32 version 301, detailed below ...
\e32\include\v32arm.h --> \e32\ekern\epoc\katemplate\v32template.h
\e32\include\v32templateassp.h --> \e32\ekern\epoc\katemplate\a32templateassp.h
\e32\include\v32templatev1.h --> \e32\ekern\epoc\katemplate\v32template1.h
2) Nicolas
1) Fixed defect EDNNTHY-4PMKJW "RDebug Breakpoints Are Sometimes
Ignored Under Brutus". The B bit is now set in
KRomSectionPermissions and KRomPtePermissions. As a side-effect,
on CPUs with write-through caches the write buffer is now used for
shadowed pages. On SA-1100, setting B ensures the main data cache
is used instead of the mini one, and so fixes the defect.
3) Pete
1) Added WINS platform layer for MMC Controller.
2) Changed the WINS EPBUS.DLL from being a PC Card Controller
to being an MMC Controller (i.e emulation of the PC
Card Controller has now been disabled in WINS and replaced
with an MMC Controller emulator). Similarly, the Media Driver
for WINS drive X: is now a MMC Media driver rather than a CF card
Media Driver.
3) Fixed defect EDNMCAN-4P5C37 "File Mgr:Memory card menu is
not dynamic'. Fixed by powering down any MMC cards while
the media door is open and not allowing any operations on
the cards during this time.
4) Implemented inactivity timer on MMC Controller. While the
MMC bus is powered up, if a given period elapses (set at the
ASSP/Variant layer) where no MMC bus activity has taken place,
then the MMC clock is turned off and power removed from the
bus.
4) Dennis
1) Fixed defect EDNDFER-4N2K8R (Wrong error code returned by fix to
another bug). DThread::Read/Write now return KErrDied if the target
thread has exited.
5) Jonathan
1) Removed old distrib IPR files and script.
Version 1.02.301
================
(Made by MarkCa, 29/09/2000)
0) Must add the following line (BEFORE LINE 44) to
\\epoc\main\romkit\include\base.iby when releasing to mainline:
extension[VARID]=ASSP_DIR\BUILD_DIR\epower.dll System\Libs\EPower.dll
1) Pete
1) Merged in changes to MMC Controller from Cambridge base porting
branch.
2) Improved scheme in MMC Controller on how information on
number of MMC sockets and media drives is returned.
This is now set in the variant layer as you would expect.
3) Removed workaround for broken MCR instruction on ARM915T from
\E32\EKERN\EPOC\ARM\KC_MMU.CPP.
4) Changes to Cogent DTE serial port drivers. Also to
Cogent IREQ1 interrupt control code. These changes,
together your Cogent board re-configured with config 'p120_05_v12'
and also a PCB cut/strap modification to each DTE serial port to
reverse the TX and RX signals will allow the Cogent DTE serial ports
to work fully.
Cogent EUART3.PDD which had been temporarily modified
to drive 'SERIAL 1' rather than 'SERIAL 2' (PCB designations) has now
been changed to drive 'SERIAL 2'.
2) MarkCa
2) Added linkup port from BPC. Build with assp MLNK, variant LA.
3) Nicolas
1) Fixed defect EDNNTHY-4P3GT6 (RDebug::SingleStep() does not stop
after one instruction sometimes). Fix applied to arm generic and
windermere.
4) Jonathan
1) Include file re-org for IPR reasons - ASSP-specific include files live
in the ASSP directory under ekern:
- Include files describing ASSPs (TEiger etc) are named a32*.h:
v32eiger.h -> ekern\epoc\arm\721x\a32eiger.h
v32s1100.h -> ekern\epoc\arm\sa1100\a32sa1100.h
v32wind.h -> ekern\epoc\arm\windermere\a32windermere.h
v32cog.h -> ekern\epoc\generic\cogent\a32cogent.h
- Custom interface files are named v32*.h:
v32arm.h -> ekern\epoc\arm\721x\v32eiger.h
v32arm.h -> ekern\epoc\arm\sa1100\v32sa1100.h
v32awd.h -> ekern\epoc\arm\windermere\v32windermere.h
v32arm.h -> ekern\epoc\generic\cogent\a32cogent.h
v32mcore.h -> ekern\epoc\generic\cogent\a32cogent.h
- All variant-specific include files moved to the variants.
- kc_std.h -> kc_arm.h.
2) New exported file for the text notifier interface
\e32\include\twintnotifier.h split out from ws_std.h, which is no
longer exported.
5) Morgan
1) Integrated fix from 6.0 branch: Fixed EDNTRIN-4BPCTM2 "Detection of
pointer events stops - multiple platforms" for MAWD. Keyboard now
detects switch on keys while sleeping.
2) Removed \brutus\v32isa.h and references
3) Called through to the variant for the following functions on MISA
TBool ImpPsu::ExternalPowerPresent();
TSupplyStatus ImpPsu::MainBatteryStatus();
TInt ImpPsu::MainBatteryMilliVolts();
TSupplyStatus ImpPsu::BackupBatteryStatus();
TInt ImpPsu::BackupBatteryMilliVolts();
4) Moved MISA, MCGA, MCGM, MEIG default power models to variant layer so
they can be replaced as necessary
5) Removed P::SwitchOffBacklight(). Calls to this can be replaced with
Hal::SetBacklightOn(EFalse)
6) Promoted P::OsSwitchOnScreen() to Plat:: so it can be called from the
power model.
7) Added Plat::DebugInit() to force re-initialisation of the trace port
after switch off.
8) Fixes to the interface and implementation of DDebugger/DPassiveDebugger
6) Alastair
1) Applied fixes already made on release branch for EDNABRY-4PHFJJ:
"Emulator support for international keyboards is broken on Windows9x
platforms" and EDNSRES-4P4EFD: "CopyAnyWhere page fault on Win 98".
Version 1.02.300
================
(Made by Dennis, 13/09/2000)
1) Alastair
1) Renamed K32ADDR.H to M32ADDR.H and removed references to it from
WINS/WINC builds, since it isn't required.
2) Fixed Base v6.1 defect EDNWROS-4MJKWH
"Request for a change to emulator window size calculation".
The Emulator window no longer defaults to the Series5 Fascia bitmap
size, and expands to accommodate the specified digitizer size if
necessary.
2) William
1) Modified COGENT1 MMP files to use \e32\bmarm DEF files in all cases
2) Fixed a few places in RArrayBase where delete was being used on a
TAny* pointer. This should be User::Free() as there is no destructor
to be called.
3) Fixed EDNMMIR-4JQDYY "E32DEF.H doesn't correctly use all the features
of GCC" by changing the definitions of CONST_CAST etc.
4) Fixed EDNWROS-4MEJRS "_LIT generates compiler warnings when string
contains large Unicode constants" as suggested in the defect report.
5) Replaced lots of M*Core PP:Fault(PP:ESystemException) calls with
distinct Mcore::Panic(Esomething) calls so that we can tell which is
which.
6) Export \e32\bmarm\eloclu.def
7) Remove excess ".." in bootstrap makefile variables BUILDDIR and
TARGETDIR
3) Jonathan
1) Changes to distrib mechanism:
- "mnt distrib generic" no longer includes source under \e32\euser
since this is "IPR Category D: Additional" source. Split out MMP
files under \e32\euser into new \e32\additional.inf file.
- New "mnt distrib Additional" is similar to "generic" but does
include the \e32\euser source.
4) Dennis
1) Merged in MCore source from Motorola.
2) Added GCC helpers for 64-bit integers (long long) to EUSER so that the
same .DEF file can be used for ARM and MCore.
3) Added test program SAVEHAL to HAL component to store the modifiable HAL
values in \System\Data\HAL.DAT
6) Markdo
1) Added support for pci interrupts on Cogent.
Version 1.02.276
================
(Made by Morgan, 31/08/2000)
1) Alastair
1) Fixed defect EDNABRY-4NFNPX
"HAL component should create HAL.LIB from a dummy HAL.DLL project".
Now a dummy HAL.LIB can be created for ARMI, ARM4 or THUMB builds by
executing "abld build armi", or some similar command(s), for dependent
components to link to. The HAL.DLL created in the ARMI, ARM4 or THUMB
release directories is an empty implementation and should be ignored.
2) Morgan
1) Fixed defect EDNJBED-4NAFQ2 "Switch makes the digitiser freeze"
1) Gave the LCD a power handler so it can respond to on/off calls
from the power model. (Effects MISA, MAWD)
2) PowerStandby can now be aborted. Power handlers are given a
power-on call if they were sent power-off and standby is later
aborted. (Effects generic kernel)
3) Changed the MISA digitiser wrt 2
4) Improved the PM heuristics in the WINS and EPOC comms drivers to
guess when it is busy. (Effects WINS/EPOC comms)
Version 1.02.275
================
(Made by Alastair, 24/08/2000)
1) Alastair
1) Fixed defect EDNPHAR-4N3HRA "Access Violation when closing RLibrary
` handle".
Note that entrypoints of DLLs which are statically-linked
to, having already been dynamically-loaded, will not have their
entrypoints called in the statically-linked context.
Version 1.02.274
================
(Made by MarkCa, 17/08/2000)
1) Morgan
1) Fixed EDNMHEY-4N3FAY. Removed references to V32ETNA.H from MEIG and
MAWD platforms.
2) MarkCa
1) Fixed EDNTBLT-4MFKKY (peripherals need to be started after extensions
loaded). The pbus code has been moved to P::InitialiseLocalDrives(),
which is called from InitialiseLocalDrivesL().
Version 1.02.273
================
(Made by Alastair, 2/8/2000)
1) Alastair
1) Removed enum EKeyEuro from E32Keys.h - fixes EDNGASR-4MKLHW
"EKeyEuro should not be 0x80 but 0x20AC in e32keys.h"
2) MarkCa
1) Fixed defect EDNPSCE-4MFPQC Media Change doesn't work properly
on MMC Controller
\e32\drivers\medmmc\epoc\d_medmmc.cpp
Added return value checking for Engage() calls, particularly in
DMmcMediaDriverFlash::SessionEndDfc() where value is used to
determine behaviour on media door opening / closing.
\e32\epbus\epoc\linda\pa_mmc.cpp
Added KPBUS1 conditional door interrupt debug trace.
\e32\epbus\epoc\linda\pa_std.h
Made MediaState() definition in TLindaMMCMediaChange virtual. It
is implicitly virtual because it is derived from TMediaChangeBase.
\e32\include\p32mmc.h
Made TMediaState MediaState() pure virtual function in
TMMCMediaChange. The function is pure virtual from
TMediaChangeBase anyway. Added AccessMediaChange(TPBusNum aBus)
function to DMMCController. MediaChange(TPBusNum aBus) is
declared as a pure virtual protected function in
DPeriphBusController, and so is not accessible from
DMMCSession::Engage().
\e32\include\p32mmc.inl
Added definition for DMMCController::AccessMediaChange(TPBusNum
aBus). This is an accessor function that simply returns
MediaChange(aBus).
\e32\epbus\ps_mmc.cpp
Added checking to DMMCSession::Engage() to return KErrNotReady if
media driver tries to launch a write while the door for the
associated bus is opened.
\e32test\pccd\t_mmcdrv.cpp
Added test code to check above modifications. Source file must be
explicitly recompiled with TEST_DOOR_CLOSE #define set to non-zero
for test to work.
3) Jonathan
1) Disallow reads/writes to/from dead threads. Fixes EDNDFER-4MFNER.
2) Also removed some old code from ks_thrd, commented out since ER1.
4) Nicolas
1) Fixed EDNNTHY-4MNJXK (Kernel crash after calling ARM4 code from
THUMB code).
In the exception reporting code in __ArmVectorUndef(), the address of
the invalid ARM opcode is now forced to a four-byte boundary before
fetching the opcode. Fixed both in kc_int.cpp (arm generic) and
ke_int.cpp (windermere).
Version 1.02.272
================
(Made by RobertJ, 20/07/2000)
1) Morgan
1) Added a TVersion member to the Debugger API
2) Added a iDebugger member to TKernelPage so it is available
to externel debugger software over JTAG/BDM, at a constant
address. Removed K::Debugger.
3) Fixed EDNMMAT-4M6KHZ "TLex::Val returns the wrong number"
2) Alastair
1) Fixed EDNJBON-4MBMC8 '"set _epoc_drive_j=...." causing emulator
problems' by removing trailing spaces from _EPOC_DRIVE_? environment
variables as they are read.
3) Dennis
1) Fixed EDNKLIG-4LVJST (Device turns off when time changed).
The problem was due to K::TickCounter being updated when the system
time changed. This no longer happens - K::TickCounter now increments
every tick when the machine is on and does not change when the machine
is off. The offset between K::TickCounter and the real time clock is
remembered in order to make locked timers work.
Version 1.02.271
================
(Made by Morgan, 5/07/2000)
1) Morgan
1) Fixed EDNBBOY-4LWGW2
2) Fixed MCGA Monitor warnings
3) Fixed Cirrus7211a MMP warnings
Version 1.02.270
================
(Made by RobertJ, 29/06/2000)
1) RobertJ
1) Fixed EDNMHEY-4L3KX7 "References to Licensee hardware in generic code"
2) Changed \e32\drivers\dfir\epoc\d_fir.cpp to return an error code for a
read failure
3) Changed \e32\drivers\dfir\epoc\d_fir.cpp test for buffer full from
>= to > as limit excluded valid transfer address.
4) Changed \e32\drivers\dfir\epoc\dmabuff.cpp error code was not always
correctly returned. It could return zero when in error
5) Changed \brutusa\vi_fir.cpp to remove 1ms wait after write to
spin until TUR flag set (fifo is empty) then TBY flag transmitter busy.
This is to remove as much latency as possible in tx->rx turnaround
2) Jonathan
1) Fixed EDNJHAS-4LQPA5: changed MMAD to use ARM Base Restored Data
Abort Model.
3) Pete
1) Fixed EDNPSCE-4L3CHV "Device driver slow open
mechanism doesn't work properly on machines with more than one PCMCIA
slot."
In fact, the slow open mechanism is OK as long as a
separate unit number can be used to open a serial channel on each
slot. Hence, the change really just involves enabling the PC Card
Serial driver on Brutus to open on either PC Card slot.
Bottom slot - Unit number 3 (Com4).
Top slot - Unit number 4 (Com5).
Also a change to the function DPhysicalDevice::CheckForSlowOpening()
just to make this more logical.
4) MarkCa
1) Removed Kern::Printf() debug from DLindaMMCStack::DoPowerUpSM() in
\e32\epbus\epoc\linda\pa_mmc.cpp.
Version 1.02.269
================
(Made by Dennis, 22/06/2000)
1) Alastair
1) Using CP_ACP rather that CP_UTF8 for EPOC.INI file text conversion
since CP_UTF8 is not supported on Windows 95
2) Fixed EDNWROS-4L5NLW "Text window server has hardcoded width of 80
characters in some places" and EDNNGRE-4H2MKK "ConsoleBase does not
work on small screens" by replacing the hardcoded widths of 80
characters by iTextScreenSize.iWidth in
\e32\drivers\edisp\emul\win32\wd_wins.cpp.
3) Fixed EDNNSIH-4LCLNE "Access violation when loading SMUM.DLL..." by
using the base name of a dll rather than it's full name to get a Win32
handle to it, in case it's already been loaded from a different
directory.
4) Fixed EDNRCLF-4L4FB2 "User::LeaveIfError crash while trying to connect
to File Server Session in WINC" Now the dll reference table for the
starting process includes efile.dll and dependent dlls if efile.dll
has already been loaded by the process. This ensures that the
efile.dll's entry point is called on startup where necessary and that
the file server is started.
5) Fixed EDNRCLF-4LALXK "E32Initialize Crash".
UpWins::__DllAttachProcess() now changes "TRUE" return value from
Win32 DLLs to KErrNone.
2) Morgan
1) EDNRFID-4FQKKQ Zero-filled the 'Visibility Map' in the text window
server, during initialisation.
2) EDNMHEY-4L9NKJ Added TRawEvent::ECaseOpen and TRawEvent::ECaseClose
events
3) Added idle off behaviour to the comms LDD D_COMM. This stops the
machine turning off while
a) there is a write request outstanding,
b) 20 seconds elapse after the last character has been sent,
c) there is a read request outstanding
4) Altered comms PDD for all variants wrt above.
3) Dennis
1) Yet another 'fix' for defect EDNGBON-4JYNU6 (Inaccessibility of request
semaphores breaks EPOC connect). For WINC the semaphore name has been
reverted to be the same as ER5U.
4) Pete
1) Changes required to move Cirris Logic bootstrap over
to the new bootstrap scheme.
Version 1.02.268
================
(Made by Markdo, 07/06/2000)
1) Alastair
1) Fixed EDNTJOS-4JGME4 "Dialog title EPOC32 fault needs to be changed"
2) If dll entrypoints return TRUE, the return value is changed to
KErrNone.
This change means that Win32 DLLs linked to by EPOC DLLs can return
TRUE without resulting in a KErrBadLibraryEntryPoint error.
2) Nicolas
1) Fixed bugs preventing from building __EARLY_DEBUG__-enabled MCGA
kernels.
3) Dennis
1) Fixed EDNPPAN-4KEELX (HAL attribute for keyboard backlight needed).
2) Fixed EDNPPAN-4KPEEL (HAL attribute EAccessoryPower needed).
3) Fixed EDNJPAR-4KLLGL (HAL TManufacturer not generic).
4) Fixed EDNRFID-4KTFD3 (Bootstrap doesn't clear first new page table).
5) Removed ARM architecture 3 maths code from UC_I64.CPP and UC_REALX.CPP.
The architecture 4 code is always used now.
Version 1.02.267
================
(Made by Alastair, 23.5.2000)
1) Dennis
1) Fixed problem with all ARM bootstraps caused by switching mode from
svc26 to svc32 in a subroutine - LR will contain flags since the BL
was executed in 26-bit mode, giving an incorrect return address for
32-bit mode. Fixed by masking top 6 bits of LR if the routine was
actually entered in 26-bit mode.
2) Fixed defect EDNGBON-4JYNU6 (Inaccessibility of request semaphores
breaks EPOC connect). Thread request semaphores are no longer added
to the K::Semaphores container so that other EPOC code cannot access
them directly. On EPOC they are also unnamed, on Win32 they are named
PROCESSNAME::THREADNAME{EPOCTHREADID} so that the Win32 semaphore
inherits this name and can be found by EPOC connect.
3) Fixed defect EDNSCHM-4K7MTC (CActiveScheduler::Error() broken on ARM).
4) Fixed defect EDNDBAR-4K5EU3 (Close functions in RArray...)
5) Fixed defect EDNMBOX-4JZEAP (TDblQueLink should allow multiple deques).
6) Fixed defect EDNACLN-4JQK2F (HAL::Get panics on low memory).
7) Fixed defect EDNSCHM-4JHRRS (RTimer::Inactivity only useful for switch
off)
2) Nicolas
1) Debug::EnableBreakPoint() now flushes instruction cache after writing
breakpoints into memory. This fixes the transient test failures
observed on brutus.
3) Alastair
1) Introduced new scheme into WINS/WINC so that Dll entry-points are
called by EPOC in much the same way that they are called on a target
device.
When a process is started or when a library is loaded, the Kernel
creates a Dll reference table for the executable to mimic the Dll
information available on the target device. EPOC under WINS/WINC can
thus call Dll entry-points at the appropriate times. This change
means that the Win32 Dll entrypoint mechanism is no longer used for
calling Dll entry-points, and therefore avoids deadlock occurring due
to the "hidden" critical section used by Windows operating systems
while making entry-point calls. This change fixes Symbian defect
EDNATHE-4GAL54 -
"Emulator hangs during startup"
Whether this change will also fix similar deadlocks occuring with the
Emulator running with NT SP5 on Compaq PCs remains to be seen.
2) Added WINS/WINC base address for HAL.DLL - 0x6b000000
4) Morgan
1) Undid a change to TMillisecondTimer::CounterExpired that was causing
the digitiser to crash on Series5mx.
Version 1.02.266
================
(Made by MarkCa, 16/05/00)
1) Pete
1) Fixed EDNPHAR-4JCNSC (Can't access removable drives
on latetst Brutus Roms).
2) Fixed a couple of problems to allow UserSvr::ForceRemountMedia()
to work when a non-removable drive is specified. This now
allows the media driver for a non-removable drive to be swapped
successfully.
3) Modified the ISR for the Brutus PCMCIA/CF Card Serial driver (COM4)
so that it now handles all pending UART interrupts in
a single call rather than just the highest priority interrupt. This
fixes problems with the driver where it could 'lose track' of
interrupts when multiple interrupts were pending.
This fixes EDNACLE-4JZL3V (Brutus PCMCIA Serial I/O Adapter hangs...)
and EDNPREF-4JCKV (Protocol hanging on Brutus board).
4) Modified the Brutus PCMCIA/CF Card Serial driver (COM4)
to support change notification.
5) Fixed a problem with Brutus built-in serial ports
(COM1 and COM2) which were not correctly configuring the port when
either Odd or Even parity was selected.
2) RobertJ
1) Fixed \brutusa\vi_com2.cpp, \brutusa\vi_fir.cpp, \brutusa\v32isaba.h
to cope with transceiver SIR/FIR mode change
3) Morgan
Fixed some anomalies in the power handling code:
1) Removed ImpHal::Standby() and ImpHal::Standby(aWakeup) (from
MAWD, MISA, MCGA, MEIG, MMAD)
and replaced it with appropriate code in the power model.
The correct way to turn off the machine from kernel-side is to call
a) DPowerModel::PowerStandby() for immediate kernel-side switchoff
b) Kern::AddEvent(ESwitchOff) for ordered user shutdown
To turn off from user side, we call UserHal::SwitchOff().
1.2)Renamed K::SwitchOff() to Power::SwitchOff()
Renamed K::PowerOn() to Power::PowerOn()
Removed DPowerModel::PowerStandby(aWakeup) because it is useless.
2) UserHal::SwitchOff calls Power::SwitchOff which calls PowerStandby on
all power handlers. This will cause
DPowerModel::PowerTransition(EPowerNone) to be called (when each power
hander has called SetRequirement(0)). The power model should then
call DPowerModel::PowerStandby() to turn the machine off. (see a)
above).
3) DPowerModel::PowerStandby() works out when the next alarm is due, and
turns off the machine by calling the appropriate
DPowerModel::DoPowerStandby(/*aWakeup*/) function.
4) Added a User-Cpu-In-Use flag to the power model's power-requirement.
This stops the machine turning off while there is user-side processing
but no device drivers (power handlers) active. This flag does NOT
prevent idle. This flag is unset when UserHal::SwitchOff is called,
and set for PowerOn.
Version 1.02.265
================
(Made by Morgan, 18/4/2000)
0) Must change \\epoc\main\generic\romkit\include\base.iby line
file[VARID]=ASSP_DIR\BUILD_DIR\cVARLETTERxyVARIANT.dll System\Libs\Exyin.dll
to
extension[VARID]=ASSP_DIR\BUILD_DIR\cVARLETTERxyVARIANT.dll System\Libs\Exyin.dll
when integrating to mainline.
1) Morgan
1) Made all XYInputs into kernel-extensions
2) Removed TXYInput from M32HAL.H
2) Dennis
1) Fixed EDNJPAR-4G5FA8 (missing chunk types)
2) Fixed EDNMBOX-4DSJXH (missing #include guards on e32des8.h
and e32des16.h)
3) Fixed EDNJBON-4DCEHD (Kern::Printf doesn't support %c)
4) Fixed EDNPBAA-4HXEST (TDes::Format doesn't support %i)
5) Fixed EFNATHE-4GYFQ8 (Thread semaphores named after thread)
6) Fixed EDNJHAS-4HCQAF (SA1100 standby)
7) Fixed EDNDBAR-4C5E7V (RArray<> should have a TArray interface).
8) Fixed EDNJHAS-4HXEGT (Literal length as compiler constant).
9) Fixed EDNJHAS-4HXELS (Compile-time TFixedArray).
10) Fixed EDNJHAS-4HXEPN (Support for profiling).
11) Added CleanupStack checking functions:
CleanupStack::Pop(TAny* aExpectedItem) check top item and pop
CleanupStack::PopAndDestroy(TAny* aExpectedItem) check top
item, pop and destroy
CleanupStack::Pop(TInt aCount, TAny* aExpectedItem) Pop aCount
items, checking last one
CleanupStack::PopAndDestroy(TInt aCount, TAny* aExpectedItem)
Pop/destroy aCount items, checking last one
12) Removed compiler warnings from E32 and variants.
13) Added EMemoryRAMFree option to HAL to get amount of free RAM.
14) Fixed EDNCDUG-4J3QA8 (collate.h includes files not in \epoc32\include).
3) Alastair
1) Fixed EDNABRY-4JGJG4 "Test T_Float fails under WINS/WINC"
Version 1.02.264
================
(Made by Morgan, 7/4/2000)
1) Morgan
1) Added DPowerHandler::DoPowerTransition(aPowerState) virtual
function to the power handlers. Power handlers should
implement this if they need notification when the power state
of the machine changes.
2) Added DPowerModel::PowerTransition to call the power handlers.
Added pure virtual function DPowerModel::DoPowerTransition()
to replace the DPowerModel::SetPowerState function, (which has
now been killed).
3) Added Power Model locking - Power::[Un]LockPowerModel(). This
prevents the power model from shifting power states during
power critical periods.
4) Added ECaseState to the HAL.
5) Removed ImpHal::EmergencyStandby() from all platforms. This fn
is not used or needed any more.
2) Nicolas
1) Improvements and bug fixes in RDebug API implementation
so in-target-debugging will be usable on ER6 devices.
USER-LEVEL VISIBLE CHANGES:
* Debugging resources owned by the debugger and the
debuggee are automatically released when the
debugger/debuggee ends (this includes automatically
closing the debugging session).
* SDebugInfo has a new field containing the start
address of the debuggee's data/bss chunk: this is
mandatory to support the current toolchain in
gdbstub.
* THUMB breakpoints supported. Let A be the address
of a breakpoint to be set/cleared. In THUMB mode, A
should be passed as-is to RDebug. In ARM mode, A+2
should be passed. See below for a rationale.
* New class TArmBreakPoint added in kc_std.h. It
contains breakpoint characteristics and an inline
function that can be used to insert a hardcoded ARM
or THUMB breakpoint in user code.
INTERNAL CHANGES:
* Breakpoint notification in __ArmVectorUndef() was
disabled. It is now re-enabled. Code updated to
take into account both THUMB and ARM.
* Support for ARM BX instruction has been added to
single-stepping code. THUMB single-stepping still
not supported.
* In Debug::Continue(), removed code which stepped
over breakpoints located at the start address
because GDB already does the same thing. Removed
too, code which stepped over hardcoded breakpoints
because it was buggy and hardcoded breakpoints are
uncommon.
* New scheme used for breakpoints: a single 16-bit
opcode is used for both ARM and THUMB breakpoint.
For ARM, this pattern must replace the upper 16-bits
of the instruction to break at. As little-endian is
used, the breakpoint bit pattern is actually at
address+2, hence the API change described above.
* CPU-dependent modifications done in both generic ARM
and in windermere.
2) Fixed defect EDNNTHY-4H6PXT (PC address computed at
start of __ArmVectorUndef() is wrong in THUMB mode).
3) AndrewB
1) Removed K32SND.H, K32SND.INL, D32SND.H and D32SND.INL
from the export section of bld.inf. These files should
no longer be public since all sound functionality is now
managed by the Media Server.
4) MarkCa
1) \E32\EPBUS\EMUL\WIN32\PP_PCCD.CPP
Added ReadPasswordFromStore() and EncodePassword().
Added logic to RPlatPccdChunk::(Read|Write) to automatically unlock
card if pw in store Replaced assertion w. return code in
DPlatPcCardController::WritePasswordData(). Added comments to describe
how emulated mechanism corresponds with real MMC mechanism.
Modified password store to use 128-bit card ids to simulate mmc better.
DPlatPcCardController::PasswordControl(),
DPlatPcCardController::PasswordStoreLengthInBytes(),
DPlatPcCardController::(Read|Write)PasswordStore()
All modified to give same behaviour as default DPeriphBusController
virtual functions if _LOCKABLE_MEDIA is not #defined.
2) \E32\EPBUS\EMUL\WIN32\PP_STD.H
DPlatPcCardController prototypes for above.
Removed panics EWinsPcCard(MappingNotInStore|PswdStoreBadWriteDesc).
3) \E32\INCLUDE\E32SVR.H
Added "//#define _LOCKABLE_MEDIA" so WINS PC Card controller can be
built without locking mechanism.
5) Morgan
1) Changed declaration of Custom::DriveSettings to pure virtual on
MAWD and MMAD and MIEG platforms.
2) k32snd.h and d32snd.h are no longer exported, so:
Changed \series5mx\va_sdrv.h to get k32snd.* and d32snd.*
from \e32\include. Changed \cirrus72x1\va_sdrv.h to get k32snd.*
and d32snd.* from \e32\include. Modified k32snd.h and d32snd.h
to get header files from \e32\include
6) Alastair
1) Removed unused __USE_CRITICAL_SECTION__ #defines from the WINS/WINC
kernel.
2) Removed badly-spelt LedArrangeVerticaly keyword from the EPOC.INI file
processing code - use LedArrangeVertically instead.
3) Named the WINS/WINC kernel critical section mutex so that it can be
shared between processes.
4) Fixed Symbian ER5u defect EDNHLOO-4HGKKJ
"EXPORT_C used instead of IMPORT_C in header file".
7) Pete
1) Added extra member to TDriveInfoV1 class:-
TInt iRuggedFileSystem
With this set (to KRuggedFileSystem), it indicates to the
file server that it should implement a rugged file system.
This required the addition of a new variant function - DriveSettings()
so the ruggedization option can be selected at the variant level.
2) Added latest versions of LFFS Media drivers for WINS and Brutus - 4th
candidate version (R1.2) of LFFS.
3) Modification to E32 local media subsystem so that the reading
of partition information from the media driver on mounting
a drive is done asynchronously. This affects the media driver API as
follows:-
TInt DMediaDriver::PartitionInfo(TPartitionInfo &anInfo);
becomes
void DMediaDriver::ReadPartitionInfo(TInt &aResult,const TCallBack& aCallBack);
The ReadPartitionInfo() call just initiates the reading of partitiion
information with this typically being concluded on an interrupt. From
the interrupt, the driver signals the conclusion of the requests by
call 'aCallback', having first written the result of the request to
'aResult'. The partition info is now written by the driver directly
into its member data - DMediadriver::iPartitionInfo rather than being
passed back to the local media subsystem.
8) Dennis
1) Renamed iCount member of CObjectIx to iHighWaterMark. Added new member
iNumEntries which counts the number of actual entries in the index.
The Count() member function now returns iHighWaterMark so its meaning
is unchanged. Added new ActiveCount() member function to return the
new iNumEntries member.
Changed Exec::HandleCount() to return the number of actual handles open
rather than the high water mark of the handles array as before.
Version 1.02.263
================
(Made by MarkDo, 30.03.2000)
1) Morgan
1) Reorganised the super-page into TSuperPage, TKernelPage,
and TMachineConfiguration. TMachineConfiguration has
been promoted from WINS.
TSuperPage holds values discovered by the bootstrap that
are required by the generic kernel. TKernelPage
contains generic kernel data that needs to be preserved
over a warm reset. TMachineConfiguration contains
system wide settings that should be persisted over a
warm reset and machine state saves (backup).
2) Changed P::SetMachineConfiguration() and
P::MachineConfiguration() to use the new
TMachineConfiguration on all platforms.
3) Removed iDebugger from the super page
4) Fixed some warnings
5) Changed the bootstraps for MEIG and MAWD to match new
superpage layout.
Changed bootstrap\include\superpage.h to match new
bootstrap.
6) Removed PowerRestart functions since the power model
never calls them.
Version 1.02.262
================
(Made by Dennis, 23.03.2000)
1) Alastair
1) Added calls to Sleep(0) before all occurrences of SetEvent(),
ReleaseSemaphore() and ReleaseMutex() in accordance with advice given
in MSDN Knowledge Base article Q173260. This change should make one
variant of the Emulator Hanging bug less likely to occur.
2) MarkCa
1) \E32\EPBUS\EMUL\WIN32\PP_PCCD
Added ReadPasswordFromStore() and EncodePassword().
Added logic to RPlatPccdChunk::(Read|Write) to automatically unlock
card if pw in store.
\E32\EPBUS\EMUL\WIN32\PP_STD.H
DPlatPcCardController prototypes for above.
3) MarkDo
1) Added additional media attributes KMediaAttLockable and
KMediaAttLocked.
4) Pete
1) Removed the EUSER class UserPcCardCntrl.
2) Modified the function MBusDev::DoAsyncLateOpen() to
now take an additional second parameter 'TInt anOpenInfo'.
5) Dennis
1) Removed the EPOC registry - files US_REG.CPP, UB_REG.CPP and KP_REG.CPP
along with TRegistryCategory, TRegistryItemName, TRegistryItemValue,
CRegistry, CPersistentRegistry and Environment classes.
2) Removed most UserHal:: functions - these have been superseded by HAL::
functions.
3) Removed RThread::Create() overload taking a RProcess& parameter and
removed RProcess* parameter from the overload taking an RLibrary*
parameter. Threads may now only be created in the current process.
4) Reassigned ARM domains following demise of registry. 2 is still used
for page tables, 3 is now used for the RAM drive and 4 for F32.
5) Change to Brutus bootstrap to link at 0xc8000000 for compatibility
with 12Mb bootloader.
Version 1.02.261
================
(Made by Robert, 17.3.2000)
1) Morgan
1) Added User::ResetInactivityTime() to reset all
RTimer::Inactivity timers
2) Added TRawEvent::EKeyRepeat for adding auto repeated key events
to the event queue
2) Pete
1) Added kernel functions to read, write and return the
size of the Peripheral Bus Controller password store.
3) MarkCa
1) Added WINS PC Card locking features to test mmc (Crystal) functions
\E32\EKERN\KW_EXEC.CPP
Modified ExecHandler::Drive(ReadPasswordData|PasswordStoreLengthInBytes)()
to call P functions.
\E32\EKERN\KS_SVR.CPP
Modified svDriveWritePasswordData to call P::WritePeriphBusPasswordData().
\E32\EPBUS\EMUL\WIN32\PP_PCCD.CPP
Modified DPlatPcCardController::PasswordControl().
Implemented DPlatPcCardController::(Read|Write)PasswordStore(),
DPlatPcCardController::PasswordStoreLengthInBytes().
Read and write routines return KErrLocked if locked and accessing
EPccdAttribMem memory. This still allows chunks to be created for
locked cards.
\E32\EPBUS\EMUL\WIN32\PP_STD.H
Prototypes for above and store panic codes.
4) RobertJ
1) Entered suppilied mods to Linda SIR in vm_com2.cpp for all variants
Version 1.02.260
================
(Made by Alastair, 10.3.2000)
1) Alastair
1) Updated e32 rombuild scripts to pick up the test .IBY files
generated by Bldmake from the new directory structure implied
by recent changes to E32TOOLP.
2) Added temporary hack to bootstrap component extension makefile
so that mainline rombuilds for MEIG, MAWD and MMAD will still work,
now that the rombuild system has been changed to work with output
produced by the generic bootstrap build system.
2) Pete
1) Modified PC Card Controller emulator (EPBUS) in WINS
to implement Peripheral bus password functions (Lock/Unlock/Clear).
This is only possible on the simulated CF cards in Socket 0 (not the
simulated Compact rom card in socket 1).
3) MarkCa
1) \E32\EUSER\US_KSVR: converted
TBusLocalDrive::((Lock|Unlock)Drive)|ClearPassword) from async to sync.
\E32\E32SVR.H: changed TBusLocalDrive prototypes.
Version 1.02.259
=================
(Made by MarkCa 03-03-00)
1) Morgan
1) Guarded POS hooks with #define __SUPPORT_PARTNER_OS__ and updated
U32STD.H appropriately. This removes partner OS support from most
platforms.
2) 'Enhanced' the POS hooks. Kernel lock is now done after the POS
reschedule hook, instead of before. This makes it necessary to
check for the POS rescheduler being interrupted. If it has been
interrupted then we now make an early exit from the int-vector to
prevent running DFCs from the nested interrupt.
2) William
1) Fixed the borders for text-window server windows on EPOC devices.
WINS uses true Unicode fonts, but EPOC devices have a cp1252 font
built in, and so need to continue using the cp1252 encoding for the
box drawing characters.
3) MarkCa
1) Added TBusLocalDrive -> Exec -> ExecHandler functions for MMC
password support.
4) Pete
1) Added PasswordControl() function to TLocDrv,DMediaDriver and
DPeriphBusController classes.
Version 1.02.258
================
(Made by Pete 24/02/00)
1) Alastair
1) Updated a few .mmp files to hardcode .def file locations.
2) Dennis
1) Made TDesC8::Left(), TDesC8::Right(), TDesC16::Left() and
TDesC16::Right() truncate the requested length to Length() instead
of panicing.
2) Export COLLATE.H to \Epoc32\Include instead of \Epoc32\Include\Kernel
since it contains public interfaces.
3) Added DEBUG mode checking to ensure that heaps are not referenced by
DFCs. Before calling a DFC the current heap pointer is changed to
0xC90FDAA2 and is restored when the DFC returns.
3) Morgan
1) Removed \hal\group. BLD.INF is now in \hal. Removed annoying
"Nothing to do" declarations. Updated all variant hals to match.
4) Robert
1) Added new export ClearIrError for Linda in ka_linda.cpp and v32linda.h
5) Pete
1) Signal change notification added to Cogent DTE serial drivers (COM3 &
COM4).
2) Fixed problem with signal change notification on DTE
and DCE serial drivers where it was possible for a transition on a
modem status line to occasionally fail to trigger notification.
3) Added CF Card Serial driver for Brutus (COM4) - not yet tested.
Version 1.02.257
================
(Made by Dennis, 14-02-2000)
1) Dennis
1) Added HAL component.
2) Removed calls to most UserHal functions except for those which are
always available from the kernel.
3) Inlined ::operator new(TUint, TLeave) and
CBase::operator new(TUint, TLeave) to remove the need for the
TLeave parameter to be generated by the compiler.
4) Kernel now always disables auto switch off by default.
5) Added RTimer::Inactivity() and CTimer::Inactivity() functions to
support generic user inactivity timers.
6) Added K::InactivityQ and TInactivityLink to the kernel to implement
generic user inactivity timers.
7) Added User::InactivityTime() to return the time elapsed since the last
user event.
2) Morgan
1) Exported hal_int.h into the system\kernel include dir
2) Made \hal\group\config.mke generic so it works for HALs in
\hal component and also works for HALs in \<variant>\hal.
Renamed <variant>.hda and <variant>.hcf to values.hda and
config.hcf.
3) Added HALs to linda b,c,1 variants
4) Updated Variant::DisplayOn for all linda variants.
Code from Sampsa - not tested locally.
5) Fixed EPBUS build error in pa_std.h on MMAD platform
6) Added kernel-extension loading to kernel init.
Kernel extensions are loaded just before the file-server.
Extensions can have writable static data but global constructors
are not called.
8) Made keyboard drivers on all platforms into kernel-extensions.
9) Removed TKeyboard.
10) Fixed bug in TIdler::Idle(). There are now 64 ticks in a second.
3) Jonathan
1) Fixes to "mnt distrib" mechanism and dsitrib.txt files.
Made distrib.pl checking stricter: Checks for mising distrib.txt files
and for non-existent files listed in distrib.txt.
4) Pete
1) Re-enabled the ACD on MEIG.
2) Enabled main battery voltage measurement on Cirrus 7211
board (which is simulated using a pot. on the board). Also reference
voltage measurement. Disabled backup battery measurement.
3) Added digitizer driver for Cirrus 7211 board - using
ADC channels to measure screen position.
4) Generally tidied up variant for Cirrus 7211 board.
5) Modified MEIG bootsrap so it resets DRAM width to
32bit. (Cirrus 7211 repro program sets it to 16bit).
6) Temporarily re-assigned Cogent UART3.PDD to use
UARTB rather than UARTC since UARTC/UARTD still have h/w problems
with setting thier interrupt mask registers. This means Cogent now
has a single DCE and DTE serial port. The ports are now assigned:-
Driver Port Number Uart Port Type
------ ----------- ---- ---------
EUART1 Serial 0 UART-A DCE
EUART2 Serial 2 UART-C Not working
EUART3 Serial 1 UART-B DTE
EUART4 Serial 3 UART-D Not working
Version 1.02.256
================
(Made by Simon, 01-02-2000)
1) Dennis
1) Added aLength parameter to Dll::GlobalRead() to specify how much data
to read.
2) Added UserSvr::HalGet() and UserSvr::HalSet().
2) Pete
1) Modified Linda MMC Controller to include calls on the
power model to reduce the clock frequency during MMC operation (and
restore to normal clock frequency afterwards).
2) Corresponding changes to the Linda power model to support MMC clock
switching.
3) Added various additional functions to TLinda class to
support power model clock switching.
4) Added CF card modem serial PDD to MAWD - DATXB13
3) Morgan
1) Integrated Matt's changes for the LCD on the HPs
4) Simon
1) Restructured e32 source directory, and moved varients to new components
Version 1.02.255
================
(Made by Dennis, 19th January 2000)
1) Morgan
1) Bug fix for WINS emulator-configuration on the command-line
(EDNATHE-4ETJPC)
2) MMAD LC/LB/L1 clock moved to 52Mhz and changed LCD settings
3) EXPORT_Ced some more functions (in ImpAsic) for use by ENOS
4) Integrated changes from Nile to MMAD keyboard drivers
5) Added TRUST changes to MMAD bootstrap
6) Modification to the POS fiq vector to defer POS reschedule
when interrupted from irq or svc mode
2) Dennis
1) Removed X86 build
2) Removed NoLongerSupported... functions from EUSER and EKERN
3) Removed TReal96. Removed the implementations of Math:: functions which
use TReal96; only the TRealX implementations now remain. Rewrote some
code in UM_RTOD.CPP (real to text conversion) to use TRealX instead of
TReal96.
4) Removed SObjectIxArray, SObjectConArray and SObjectConIxArray. These
data members are now part of CObjectIx, CObjectCon and CObjectConIx
respectively.
5) Inlined CObjectCon::UniqueID() and CObjectCon::Count()
6) Changes to descriptor code from Andrew Thoelke. Copy constructors are
no longer explicitly defined (compiler generated instead). A protected
empty destructor has been added to TDesC8 and TDesC16 to prevent the
passing of TDesC and TDes parameters by value, which would result in
object slicing. To cope with static descriptors, an empty atexit()
function has been added to UP_DLL, UP_EXE and KC_EXE for all platforms.
7) Added machine coded 16-bit descriptor code for ARM (UC_DES16.CPP). This
is enabled by __DES16_MACHINE_CODED in U32STD.H.
8) Inlined TCallBack functions.
9) Removed TChar copy constructor. This means that TChar parameters passed
by value are now passed in registers by GCC. Modified machine coded
functions which take a TChar parameter to account for this.
10) Removed TLex8 and TLex16 copy constructors.
11) UserSvr::StaticCallList(), UserSvr::DynamicCallList() and
RLibrary::LibraryCallList() are no longer exported.
12) RChunk::CreateDllStatic(), RChunk::ReserveAt() and all overloads of
RChunk::Read() and RChunk::Write() have been removed.
13) Added inline functions for converting TProcessId and TThreadId to and
from TUint.
14) Removed RThread::Mark(), RThread::SetMark(), RThread::NotifyIfDie(),
RThread::SetNotifyIfDie(), RThread::Busy() and RThread::SetBusy().
15) Removed RProcess::Mark(), RProcess::SetMark() and RProcess::Busy().
16) Removed User::Abort() and User::Dying().
17) Inlined TRawEvent default constructor, TRawEvent::Type() and
TRawEvent::Ticks().
18) Removed RLoader::LoadProcess and RLoader::LoadLibrary functions which
don't take a TUidType. RLoader::Version() and RLoader::LoadProcess()
are no longer exported.
19) Changed CCaptureKeys to use RArray instead of CArrayFixFlat.
20) Removed class RMmu.
21) Removed CArrayFixA etc.
22) Options %E, %F, %G in TDes::AppendFormatList() now convert a TRealX
instead of a TReal96.
23) Fixed bug in chunk creation - between setting the domain and the
iOwningProcess, the SetNameL could leave. The chunk destructor would
then erroneously free the domain.
3) Alastair
1) Removed SROS, ARM3 and MARM targets from BLD.INF and GENERIC.INF.
2) Fixed minor problem with DIFILB.MMP.
3) Added support for specifying color depths Gray256 and Color64K in the
EPOC.INI file with the ColorDepth keyword. Changed the Emulator color
depths default to all supported color depths rather than just Gray2,
Gray4 and Gray16.
4) Made processing of all EPOC.INI file keywords case-insensitive, and
extended maximum line length from 80 to 256 characters. EPOC.INI
syntax errors are now captured and displayed in a Message box before
causing the Emulator to exit. Text from the EPOC.INI file is
converted to UNICODE before processing.
4) Mark
1) Added KLindaUidValue and used to set iMachineUniqueId in superpage
for MMAD L1/LB/LC.
5) Pete
1) Merged in latest changes to MMC Controller and MMC Media driver.
The Controller now supports multiple block read/writes requests
and the Media driver makes use of the multiple block reads.
2) Added support in TCogent for the 2nd Dual UART device (ST16C2552) and
also suppport for its associated interrupts (in KA_PIC.CPP).
3) Added DCE serial drivers to Cogent - not yet fully functional. Also
re-organized cogent serial PDDs. These are now assigned as follows:-
Serial 0 - DCE using ST16C552 device (CTS/RTS).
Serial 1 - DCE using ST16C552 device (CTS/RTS).
Serial 2 - DTE using ST16C2552 device (RTS,DTR/CTS,DSR,RI).
Serial 3 - DTE using ST16C2552 device (RTS,DTR/CTS,DSR,RI).
4) Removed TLocalDrive class from EUSER (use TBusLocalDrive instead).
5) Changed TBusLocalDrive Read(), Write() Format() functions to use a
TInt64 rather than a TInt to specify position within the drive.
6) Removed RLogicalChannel class from EUSER (use RBusLogicalChannel
instead).
7) Removed RDevComm class from EUSER (use RBusDevComm instead).
Version 1.02.254
================
(Made by Pete, 21st December 1999)
1) Petteri
1) Added extended serial port functionality as required by Linda. A new
pair of device drivers has been added to enable Linda to act as a DCE
device in addition to DTE. New notifications and capabilities have
been added.
Files changed:
Inc\D32comm.h Inc\D32comm.inl
Inc\K32comm.h Inc\K32comm.inl
Inc\K32std.h Inc\V32linda.h
Dcomm\D_comm.cpp Vmadlc\Vm_com1.cpp
Vmadlc\Vm_com2.cpp Vmadlb\Vm_com1.cpp
Vmadlb\Vm_com2.cpp Varmca\Va_com1.cpp
Varmca\Va_com2.cpp Varmcl\Va_com1.cpp
Varmcl\Va_com2.cpp Varmp2\Va_com1.cpp
Varmpb\Va_com1.cpp Varmpc\Va_com1.cpp
Varmpc\Va_com2.cpp Varmpd\Va_com1.cpp
Varmpd\Va_com2.cpp Varmpd\Va_com3.cpp
Vawdb1\Va_com1.cpp Vawdb1\Va_com2.cpp
Vcgac1\Va_com1.cpp Vcgac1\Va_com2.cpp
Visaba\Vi_com1.cpp Visaba\Vi_com2.cpp
Visaba\Vi_com3.cpp Vrosr1\Va_coms.cpp
Vx86pc\Vx_comm.cpp Dpwins\D_cdrv.cpp
Kamad\Ka_linda.cpp Bmmad\Ekernu.def
Group\Bld.inf Ksrc\Ks_chn.cpp
Files added:
Dcomm\D_commdce.cpp Vmadlc\Vm_com1dce.cpp
Group\Ecommdce.mmp Group\Dmtxlc1dce.mmp
Group\Dmtxlb1dce.mmp Vmadlb\Vm_com1dce.cpp
2) Pete
Changes to the above DCE serial drivers and the new notification aspects
of the DTE serial drivers:-
1) Added DCE serial driver for Linda L1 together with the corresponding
changes to the existing DTE serial drivers for Linda L1.
2) Postponed various notification completion calls to a DFC. Also, now
uses DThread::Write() were appropriate to return completion
information to the client thread.
3) Changed implementation of NotifyFlowControlChange() so this only
completes when a change to a h/w signal has actually changed the Tx
flow control status. Also, now XON/XOFF changes trigger this notifier
too.
4) Slight change to the way NotifySignalChange() is implemented.
5) Implemented notification changes to WINS serial driver.
3) Pete
Converted MEIG build to the Cirrus Logic 7211 - a ARM Architecture V4
device. MEIG can now be built for ARM4, ARMI and THUMB and can no longer
be used on ARM 7110 (Eiger) platforms.
1) Modifications to Varmca variant (i.e. Cirrus Logic 7211 evaluation
board:
- Alterations to reflect changed GPIO allocation for the Rev.B
evaluation board.
- Fixed problem with diagnostic LED.
2) Fixed a problem with enabling additional CL-PS7111 interrupts.
3) Fixed a problem with TEiger::SetUart2Config() so that the 2nd 7211
serial port now works OK.
4) Altered MEIG bootstrap to use ARMv4 rather than ARMv3 coprocessor
instructions to flush the cache and TLB. Also, now maps an extra page
for the additional 7211 Eiger specific registers.
5) Changed the definitions for MEIG in U32STD.H to use ARM4 rather than
ARM3 settings.
6) Added added support for additional 7211 registers in the TEiger class.
7) Modifed BLD.INF so that only the CA variant is built for MEIG
builds. The PB,PC,PD,P2,CL variants are no longer built.
4) Pete
1) Changes to e32\dcomm\d_comm.cpp to fix a s/w flow control
problem. If SetConfig() is called on the serial port with
KConfigSendXon set in config.iHandshake and the port h/w has not yet
been initialised then the driver attempts to send an XON char with the
h/w off. No XON char is transmitted and no subsequent data can be
transmitted.
5) Morgan
1) Bug fix for MMAD LB and LC variants
Version 1.02.253
================
(Made by Morgan, 3/12/99)
0) Use with F32(201)
1) Dennis
1) Use section mapped garbage area for SA1100 cache flushing. Main cache
flush area is at 0x43000000, mini cache at 0x43100000.
2) Added new function Mmu::FlushUnmap() which is called when RAM is
unmapped. This function flushes a writeback DCache to ensure that no
modified lines remain which relate to the unmapped memory.
3) Added new function Mmu::FlushCode() which is called after new code
is loaded into RAM - in DPlatProcess::Loaded and DPlatLibrary::Loaded.
This flushes the ICache on a split-cache machine.
4) Reinstated machine coded CActiveScheduler::Start() and CServer::RunL()
after applying the RunError() modifications from last release.
5) Added new define __CPU_EXC_VECTORS_MOVABLE in U32STD.H for
SA1100. This signifies that the processor offers a choice about the
virtual address used for the exception vector table. Changed SA1100
bootstrap to place the vectors at 0xFFFF0000 and changed Mmu::Init1()
to set the end of the home section to 0xFFF00000 on SA1100.
6) Fixed scheduler bug which caused a null pointer dereference in the case
where TheCurrentVMProcess=NULL, i.e. during boot.
7) Modified SA1100 bootstrap to output boot tracing to the same port as
kernel tracing. Added more boot tracing. Tracing can now be done after
the MMU is enabled, since the output char function checks the MMU
control register.
8) Modified SA1100 bootstrap to set the correct RAM wait states when
running from RAM, since the bootloader sets pessimistic values.
9) Modified SA1100 bootstrap to mark the exception vectors as cacheable
and as readable by all code and writeable by none.
10) Removed __MCGA__ hacks from KCARM. We now use __CPU_ARMV3 define to
determine whether to use architecture 3 or 4 MMU instructions.
11) EXE code chunks are now allocated at the top of virtual address space
in the same region as DLL code chunks. Also they don't move during a
reschedule. This means that split-cache machines need never flush the
ICache except following loading of new code to RAM.
12) When sharing a DLL code chunk, copy entry point from the library whose
code chunk is being shared.
13) Added "kerneltrace 0x80000000" to every HEADER.IBY file, so panics are
always traced in debug builds.
2) Morgan
1) Fixed a couple of warnings
2) Removed the 256 character limit from process command lines
Added Exec::ProcessCommandLineLength
Added RProcess::CommandLineLength()
Added RProcess::CommandLine(TDes&)
Changed UserSvr::ProcessCreate to take an additional cl HBufC parameter
Changed svProcessCreate and S::ProcessCreate[L] accordingly, and added
cleanup code.
Changed RLoader::LoadProcess RMessage to take additional cl parameter
Changed WINS getFileNameAndCommandLine initialisation function
DProcess::Create now takes and additional command line HBufC
3) Fixed PWM interface in TLinda
4) Added EStdKeyApplication<n> enumerations
5) Added KHARDWAREASSIST to the KTRACE #defines for switching on
hardware that can assist with kernel tracing
6) Mapped in CBA on EStdKeyDevice0..EStdKeyDevice3 on MMAD LB and LC
variants
7) Added hardware assist tracing to Variant::DebugOutput() on
MMAD platforms
8) Changed the XYInputType on MMAD platforms to EXYInputDeltaMouse,
and MCGA to EXYInputMouse by implementing ImpHal::XYInputType()
9) Integrated Matthew's new MMAD L1 variant
10) Integrated Matthew's WINS changes for mapping application keys
3) Simon
1) Use Cogent extended PCI space if available
Version 1.02.252
================
(Made by Simon 25-11-1999)
1) Morgan
1) Process create now correctly notifies the debugger of the new main
thread.
2) VMADLB and VMADLC report correct physical screen dimensions.
3) Updated the MMAD bootstrap to take new flash initialisation values
4) Pushed DPassiveDebugger Rom-library-hunting into 3rd stage kernel
initialisation. This is to allow the kernel heap to grow as required.
Also, reorganised strings in the DPassiveDebugger tables to take up
less room.
5) Added EVT100.MMP to build the vt100 display driver.
2) Alastair
1) Changed exception-handling for system threads under WINS/WINC so that
exceptions are passed on to the system debugger for handling rather
than producing the Plat 46 dialog.
3) Andrew T
1) Fixed regression defect EDNMDON-4DJK8E (from Defect tracking V3.0) as
suggested.
2) Added a further check on the message slot handle in
Kern::MessageComplete to verify that it lies within the kernel heap,
prior to the validity check. This prevents bogus message handles from
causing a kernel exception and crashing the kernel.
2a) Modified E32 t_svr test to test the new check.
4) Andrew B
1) Added virtual "RunError" function to CActive definition in E32BASE.H,
and modified CActive::Scheduler::Start() to use new CActive::RunError
function when RunL leaves. It is a source compatible but not binary
compatible change.
2) Modified U32STD.H to prevent machine-coded versions of CServer::RunL()
and CActiveScheduler::Start() being used until the implementations are
updated to reflect the changes to the C++ versions.
3) Fixed long-standing defect in CActive::Deque() which stopped active
objects being re-added to scheduler. Updated T_ACT.CPP to test
CActive::Deque() defect and new RunError function.
Version 1.02.251
================
(Made by Morgan, 25/10/99)
1) Alastair
1) Removed local function loadEnvironmentVariablesL() from
KPWINS\KP_INI.CPP. This change addresses ER5u software problem
EDNKDEY-4AAKEW "Long environment variables stop the emulator working".
The full emulator (from Mainline build 00019) still appears to work OK
without this function. Note that this change means that F32 will no
longer search the system path for DLLs to be loaded dynamically.
2) Added code to make it possible to set the User::JustInTime() value
from the EPOC.INI file for WINS debug builds, using the syntax
JustInTime 1 # turn on just-in-time debugging
JustInTime 0 # turn off just-in-time debugging
Presumably only the latter will ever be used since JustInTime
debugging is enabled in WINS debug builds by default. The keyword is
case-insensitive. This change addresses ER5 defect EDN414664 "Should
be possible to set User::JustInTime from the EPOC.INI file".
3) Refrozen EKERN.DLL for WINS/WINC so that the four functions referenced
by ordinal in source code appear at the start of the frozen .DEF file.
This means WINS/WINC executables linking to EKERN.LIB will need to be
rebuilt with the latest EKERN.LIB before they will run against the
latest EKERN.DLL.
2) Morgan
1) TMachineInfo::iXYInputPresent has become iXYInputType. Added
enum TXYInputType in e32hal.h. This can take one of the values
EXYInputNone, EXYInputPointer, EXYInputMouse (delivers absolute
values in mouse events), EXYInputDeltaMouse (delivers relative
values in mouse events).
2) Removed MouseButtonDown and SetMouseButtonDown from UserHal and
Hal classes. Binary incompatable change. Incompatability limited
to the functions added last release.
3) Removed unused events from TRawEvent: EFlipChange, ESimButton*
and EPointerMoveBy. Removed unused TFlipPos from TRawEvent.
4) Updated MMAD emulated-mouse driver to use new API
3) Alex
1) Added a preliminary version of MMC stack controller and MMC media
driver (currently disabled) to the "peripheral bus" drivers family.
2) Added Linda implementation of MMC stack ASSP layer.
4) Bob
1) Applied suggested fix to TLinda::ArtError and TLinda::IrError in
kamad\ka_linda.cpp
Reset the fifo only when error condition, not after every byte
5) Pete
Change to bootloader to support CL-PS7211.
Temporarily disabled ADC on Cirrus Logic board due to problems with it.
Version 1.02.250
================
(Made by Morgan, 27/9/99)
1) Morgan
1) Added the very random number generator Math::Random and Kern::Random.
Any device drivers that can derive random bits from their devices
should call Kern::RandomSalt(TUint aBitOfSalt) to mix up the kernel's
random pool. Only the LSB is used.
2) MAWD Arm::IrqDispatch adds random salt from TWind::RtcTickCount()
MEIG Arm::IrqDispatch adds random salt from TEiger::RtcTickCount()
MISA Arm::IrqDispatch adds random salt from TSa1100::OstData()
MCGA Arm::IrqDispatch adds random salt from TCogent::TimerCounter()
3) Added DPowerModel::NotifyEvent called from Kern::AddEvent. Override
this function in your power model to implement auto timeout behaviour.
eg
DMachinePowerModel::NotifyEvent()
{ iLcdPowerHandler->ResetAutoSwitchOffTimer(); }
4) Fixed HW IO mapping problem in the MMAD bootstrap
5) Fixed \e32\rmmad\header.iby. Now includes screen size.
2) Chris
1) Fixed bug in TDMA (generic dma) affecting receive transfers large
enough to require breaking down into multiple dma operations.
2) Changes to TLinda fns DmaSrcSize() and DmaDestSize().
3) Changed ImpDma::GetInterrupt() and added code to set up the correct
device widths of peripherals for dma on Linda.
4) Changed fast ir LDD to store ir frames on 4 byte boundaries.
5) Changed PDD/LDD fast ir interface to be more generic and added
Caps/Config.
6) Added incomplete Linda fast ir pdd(difilb). Supports 1M and 4M.
3) Jonathan
1) Fixed ER5u defect EDNGASR-46SD7V "Special keycodes conflict with
Unicode values" by making non-character keys start at 0xff80 and
special keys start at 0xff70, within the UNICODE private area.
inc\e32keys.h
4) Petteri
1) Added base mouse support.
[Note, this API has not been finalised. If you use these
APIs expect source and binary incompatable changes next
release]
Files changed:
Vmadlc\Vm_hw.cpp Usrc\Us_exec.cpp
Vmadlc\Vm_keyb.cpp Kpehal\Kph_inf.cpp
Vmadlb\Vm_hw.cpp Kamad\ka_inf.cpp
Vmadlb\Vm_keyb.cpp Kpepoc\Kp_dat.cpp
Inc\E32svr.h Bmarm\Euseru.def
Inc\E32hal.h Bmmad\Ekernu.def
Inc\U32std.h Bmawd\Ekernu.def
Inc\M32hal.h Bmcga\Ekernu.def
Inc\M32std.h Bmeig\Ekernu.def
Kaisa\Ka_inf.cpp Bmisa\Ekernu.def
Kacga\Ka_inf.cpp Bmros\Ekernu.def
Kaeig\Ka_inf.cpp Bwins\Euseru.def
Karos\Ka_inf.cpp
Keawd\Ka_inf.cpp
2) Added virtual cursor support for Linda
5) Simon
1) MCGA will now 'dual boot' on CMA120 and CMA102
6) Alastair
1) Changed GROUP\GENERIC.INF so that ELOCL.DLL is not built for
THUMB.
7) Malcolm
1) Added new feature to rom.bat find template files by scanning
the e32/r*/ directories for .oby files. The config file now
simply specifies which one is the default - if this is not
present then another template is picked. The new
--list-templates option lists the known templates, along with
a description. The description is picked up from a line in
the .oby file starting //#NAME:
2) Added ability to reuse rom.oby file in rom.bat (--reuse).
This is not recommended but is useful for quick .oby file
hacks. There is a heuristic employed to determine the ASSP of
the rom.oby file from its name, or it can be specified
directly.
3) Changed MAWD, MEIG, MISA, MAD, SROS and SARM bootstraps to
pick up the kernel trace mask from the rom header (requires
rombuild > 125 to write the info there).
8) Alex
1) Fixed multiplier for TMillisecondTimer on MMAD, and adjusted
delay in keyboard driver.
Version 1.02.197
================
(Made by Morgan, 26/8/99)
SOURCE-ONLY RELEASE
Built with MSVC6
1) Jason
1) Removed Casius MISA variant and all references to FPGA14 from MISA
code.
2) Uncached screen chunk in \KAISA\KA_INI.CPP to fix stripy cursors.
3) Update the MISA OST timer and match registers (KA_INI.CPP) over switch
off/on.
4) MISA Seting of RTC clock now wait for one 32KHz tick.
5) MISA Codec sample rate divider functions fixed.
6) MISA Tick code fixed.
7) InitSystemTime() implemented for MISA.
8) MISA Bootstrap now uses correct MMU permissions for page tables.
Pagetables unlocked and locked (KA_ISA.CPP) in MISA sleep code.
9) MISA Mini-Cache is now mappable and flushable, using new mappings of
EUserRwNotBuff, ESupRwNotBuff.
10) \VISABA\VI_HW.CPP variant tidied up with Eikon friendly constants.
11) \VISABA\VI_XYIN.CPP restructured.
12) Added OS Timer Watchdog Enable to MISA sleep code and cleared all
the OST status bits after wakeup.
13) Fixed possible MISA millisecond timer code bug.
2) Alastair
1) Removed ESOUND.LDD and ESDRV.PDD - these projects are now part of
E32TEST.
2) Used #defines in GROUP\GENERIC.INF to ensure that KC_EXE.LIB is not
built for THUMB.
3) Moved EUSER from BLD.INF to GENERIC.INF so that it's built only for
generic platforms rather than ASSP-specific platforms. Used #defines
so that it's not built for THUMB.
4) Added empty target "FINAL" to GROUP\BOOTROM.MKE.
5) Disabled VC6 warning C4414 - short jump to function converted to near,
in UPWINS\UP_I64.CPP and UPWINS\UP_REALX.CPP.
6) Fixed BOOTROM.MKE so that SROS builds correctly report their
releasable.
7) Added extension makefile KCARM\ABORTH.MKE to copy the correct abort
handler object file to \Epoc32\Build\...., and corresponding Perl file
KCARM\ABORTH.PL.
8) Changed IBY files in ROMBUILD directory to #include the E32TEST and
F32TEST IBY files generated by ABLD TEST ROMFILE.
9) Removed narrow frozen .DEF files.
10) Re-frozen all .DEF files in new format so that the C++ name
appears with the mangled name for all exports and windiff can be
used to compare frozen .DEF files with generated .DEF files.
3) Petteri
1) Added a new variant (Vmadlc) for Linda Macro m1.3BB rack.
Files changed:
Group\Bld.inf Kbmad\E32var.iby
Kbmad\Rom.cmd Kbmad\Rom.oby
Files added:
Vmadlc\Distrib.txt Vmadlc\Vm_com1.cpp
Vmadlc\Vm_com2.cpp Vmadlc\Vm_hw.cpp
Vmadlc\Vm_kdata.cpp Vmadlc\Vm_keyb.cpp
Vmadlc\Vm_pbus.cpp Vmadlc\Vm_xyin.cpp
Inc\V32madlc.h Group\Cmkdlc.mmp
Group\Cmkylc.mmp Group\Cmxylc.mmp
Group\Dmtxlc1.mmp Group\Dmtxlc2.mmp
Group\Vmadlc.mmp Bmmad\Vmadlc.def
Bmmad\Vmadlcu.def
4) Morgan
1) Improved the MMAD TIdler to perform tickQ correction and to take notice
of active millisecond timers
2) Wired in the TRtc class to the SetSystemTime function
3) Corrected ImpMmu::FlushShadow for MMAD
4) Added a flag to MilliSecondTimer so we can tell if the Millisecond
timers are being used while in Idle
5) Bug fix to TDma::GetLargestXfer which was delivering odd count values
6) Added initialisation function optimisation for pipe and copy commands
in ImpDma
7) Incorporated TLinda::SetStateDiscriminator into the ImpDma
initialisation functions
5) Pete
1) E32 provides the following function to facilitate notification
of media change events:-
TInt UserSvr::MediaChangeNotify(TMediaDevice aDevice,TRequesStatus *aStat);
This currently only supports a single request to be outstanding on any
socket at any given time. Hence, for platforms which have more than one
socket, it is only possible to be notified of a media change on one of
these sockets. This has been changesd to allow a request to be
outstanding on each socket.
2) Removed support for 2nd PC Card socket from VARMPD - no longer have a
rack with this h/w functional.
3) Modified function UserSvr::ForceRemountMedia(TMediaDevice aDevice) to
allow a fixed drive as well as a removable drive to be specified. It
can now be called after having installed a new media driver to force
a remount on the appropriate drives. This fixes a problem where a new
driver for a fixed device is loaded but there is no way to force F32
to remount the local drives associated with the media driver.
4) Modifications to Varmca variant:
- Alterations to reflect changed GPIO allocation for the LCD interface
on Rev.B evaluation board.
- Enabled diagnostic LED.
- Enabled SPI-ADC device.
6) Chris
1) Added mouse driver to Cogent + hardware cursor.
2) Changed name of serial driver on Cogent to that expected by Romkit.
3) Tidied up fast ir.
4) Changed unit masks for Com2 and Com3 on Brutus.
5) Modified Cogent serial drivers. Passes T_Serial.
7) Jonathan
1) Removed kc_exc.cpp and ke_exc.cpp from all distributions until IPR
issues are clarified.
8) Dennis
1) Added __SWITCH_TO_ARM and __END_ARM macros for use in test programs to
enable them to build in THUMB without rewriting assembler code.
2) Modified test ROM build script to work with new GCC.
3) Initialise .data and .bss for ROM-resident device drivers when driver
is loaded.
4) Corrected TLocDrv::Caps(TDes8& aCapsBuf) so it doesn't assume that the
descriptor parameter is a TBuf8.
5) Removed Kern::Printf() from Kern::PowerGood() - this causes the serial
driver to lock up since it gets called in the serial driver's ISR.
6) Modifications to ROM.BAT:
Added --inst option to specify instruction set. If not specified,
defaults to first instruction set listed for the ASSP in ROM.CFG.
Build (--build) can now be UDEB or UREL only. If not specified,
defaults to the first build listed in ROM.CFG (ie UDEB).
Changed format of ROM.CFG - [VARIANTS] section has been scrapped.
[ASSPS] section now lists for each ASSP the ROMBUILD flags to use, the
variants supported and the instruction sets supported.
9) Simon
1) Mouse is now optional, ie doesn't hang if no mouse connected
Version 1.02.196
================
(Made by William, 13.8.99)
SOURCE-ONLY RELEASE
Built with MSVC6 and ARMv4 (GCC 518).
CHANGES TO RELEASABLE
1) William
1) CAKD*.MMP files no longer specify ASSP_LIBRARY EKERN.LIB, so that they
can be built correctly for THUMB.
2) U32STD.H now defines __SUPPORT_THUMB_INTERWORKING for ARMv4T, using
#ifdef __ARM_ARCH_4T__ to distinguish between MAWD compiled with the
new GCC and MAWD compiled with the old toolchain.
3) The GCC "_call_via_rX" helper functions required by THUMB code are
hacked into up_dll.cpp and uc_exe.cpp. This should be removed and
replaced by the proper GCC.LIB mechanism.
4) RequestComplete tracing is now conditional on KTHREAD+KSEMAPHORE
5) BOOTROM.MKE CLEAN target now removes intermediate .o files
Version 1.02.195
================
(Made by Alastair, 2.8.99)
SOURCE-ONLY RELEASE
Built with MSVC6
CHANGES TO RELEASABLE
1) Alastair
1) E32 now releases zip files for ARMI, ARM4 and THUMB in the same style
as it's other releasables. Note that generic EUSER.LIB and EDISP.LIB
are still released with the ASSP-specific releasables, though all
other generic stuff is now contained in the 3 new zip files. To use
these releasables it's necessary to use E32TOOLP version 120 and the
new GCC compiler.
This change is academic for this release since it's source-only, also
it has, in fact, been built with the old gcc compiler.
1) Alastair
1) Hopefully fixed ER5u defect EDNDMAI-49UE4V
'"KERN RE-ENTRANT" Panic' in KPWINS\KP_UTL.CPP by converting the
UNICODE RDebug::Print text to NARROW 256 characters at a time using
a stack variable rather than allocating space on the heap.
2) Fixed ER5 defect EDNKDEY-45NHVH
"Unhandled exception checking for priority key (emulator only)" in
WSRC\KY_TRAN.CPP by making sure that capture key data is not left
uninitialised when Windows produces a character code that the EPOC
translation tables didn't.
3) Fixed ER5u defect EDNWROS-46YC3V "Plat fault or Plat panic?" in
KPWINS\KP_UTL.CPP so that the Fault/Panic distinction is part of the
text inside the alert box rather than just in the title where nobody
ever thinks to look.
4) Split BLD.INF into BLD.INF and GENERIC.INF with GENERIC.INF containing
details of those projects which are not ASSP-specific. This change
corresponds to changes in E32TOOLP version 120 and is designed to
support building E32 with the new GCC compiler for the new targets.
To build E32 it is now necessary to build the generic libraries, then
the ASSP-specific libraries, then the generic releasables, then the
ASSP-specific releasables.
Updated .OBY files so that, if E32 is built with the old GCC compiler,
they will look for the generic releasables in the right places. They
will need more updating to work with the new compiler though.
5) Changed EKERN.MMP and KC_EXE.MMP so that EKERN links to KC_EXE.LIB
rather than KE_EXE.LIB under MAWD.
6) Now building E(EXE|DLL).LIB rather than E(EXE|DLL).o under MARM and
E(EXE|DLL).obj under WINS. This means that using this version of
E32 requires E32TOOLP version 120.
7) Changed E32DEF.H so that WINS/WINC warning C4710, about functions not
being inlined, is disabled for MSVC versions 5 or later, rather than
just MSVC5.
8) Commented out user-side tracing macros under WINS/WINC builds in
INC\U32STD.H because they cause the kernel to go re-entrant. This
should be investigated further.
9) Integrated changes for compiling with VC6 from Ann Windsor and William
Roberts. Changes to EKERNU.DEF and EUSERU.DEF mean that this release
of E32 will not build with MSVC5 and the import libraries from this
release will not be compatible with MSVC5.
2) Malcolm
1) Enabled debug monitor for SROS, and protected some MMU
instructions for single builds.
2) Added new trace level, KMEMTRACE that dumps alloc/free/realloc and
chunk adjustments (chunks in SINGLE only) to the debug log
3) Morgan
1) Made Mmu::AllocPageTable public so it can be accessed by the debugger
2) Added MMAD-specific debugger implementation, and null debuggers for
those platforms without support
3) Moved useful ARM Mmu definitions into kcarm\kc_mmu.h
4) MMAD debugger now updates the thread id register, remaps the Rom
as small pages, and allocates some free pages for SW breakpointing.
5) Removed explicit references to variants from KC_UTL.CPP and removed
reference to the Eiger variant (V32ARM.H) from the global header
KC_STD.H. Pushed P::StartupBeep into the ASSP layer. Re-organised
P::OutputToCom1 functionality so the variant is only referenced in
ASSP layer. Changed P::ScreenInfo() to use the Hal function instead
of calling the variant directly.
6) Defined TExtInterrupt in KC_STD.H, but it should really be moved into
the Eiger platform which seems to be its only client.
7) Modified the Asic::Debug* functions for all ASSPs
8) Added MMAD interfaces for the Psu and Rtc to V32MAD.H and wired them
into the kernel
9) Implemented EDNWROS-49ZKUX "Unhelpful trace message"
4) Dennis
1) Added alignment checking on 16-bit descriptor functions in DEBUG mode.
2) Modified User::HandleException() to trap leaves by the exception
handler and pass them on after clearing the last chance flag and doing
User::WaitForAnyRequest();
5) Chris
1) Added slow ir pdd for Linda (dmtxlb2).
2) Added serial pdd for Cogent (datxcg1 and datxcg2).
3) Made small change to Brutus slow ir pdd (ditxba2).
Version 1.02.189
================
(Made by Kal Patel, 22nd July 1999)
1) Jonathan
1) TStringToDateTime::NextToken():
Fixed defect EDN830354: Allow am/pm designators to be non-alpha and >3
characters.
Reapplied and reworked an ER5 ICF (defect EDNANOE-49BFV2): Match
against abbreviated month names instead of leading substrings of
months.
usrc\us_parse.cpp
2) Morgan
1) Added an implementation of TMillisecondTimer for MMAD
kamad\ka_pic.cpp
2) Implemented workaround for ARM915T MMU MCR instruction bug
Interrupts are disabled over writes to the domain access control
register
kcarm\kc_int.cpp
kcarm\kc_sched.cpp
inc\kc_std.h
3) Fixed the definition of delta and tick TTimerModes
inc\v32linda.h
4) Added a new class TIdler, that switches off rescheduling and the tick
during idle, and reenables it shortly before a timer is due.
kamad\ka_idle.cpp
kamad\ka_std.h
5) Exported functions from DPowerModel for those power models that
are implemented outside of the platform kernel
inc\k32power.h
ksrc\ks_power.h
6) Moved the MMAD variant to VMADLB, and invented a custom layer suitable
for MMAD. VARMLB.DLL is now VMADLB.DLL. CA*LB.DLL is now CM*LB.DLL.
DATXLB1.DLL is now DMTXLB1.DLL.
varmlb\*
inc\v32mad.h
inc\v32madlb.h
group\ca*lb.mmp
group\varmlb.mmp
3) Alastair
1) Added RESOURCE target to GROUP\BOOTROM.MKE.
2) Removed defunct .DEF files from BSARM, BSCGA and BSROS.
3) Removed defunct UPEPOC\UP_CON.CPP.
4) Removed defunct BLD.CMD files from various directories.
5) Updated GROUP\E32.FTC to include the MCGA releasables.
6) Changed GROUP\BOOTROM.MKE to copy KBMCGA\COGENT.BIN to
\EPOC32\Release\MCGA\BOOTROM.BIN. Updated KBMCGA .OBY files
accordingly.
7) Changes to support building with new compiler (*.oby files,
/group/mnt.bat files, /group/bld.inf files etc)
4) Simon
1) Fixed problem with cogent timer interrupt going off for no good reason
kacga\ka_pic.cpp
2) Fixed problem in vcgac1\va_keyb.cpp that caused intermittent exceptions
5) Malcolm
1) Added new RAM Loaded code functionality
2) Modifications for Unicode SROS
3) Incorporated Kista-Patch-Baseport-3.00-990717A
kbros/rose.inc
vrosr1/va_xyin.cpp
karos/ka_rose.cpp
INC/D32COMM.H, INC/V32Rose.h
vrosr1/va_coms.cpp
group/DATXR11.MMP
group/bld.inf
6) Kal
1) Added the Aort handler functionality for flash filing system use
karos/ka_ini.cpp
karos/ka_excep.cpp
karos/ka_std.h
karos/ka_rose.cpp
WSRC/wd_rose4.cpp
group/EKERN.MMP
INC/V32Rose.h
2) Added Fast Timers on A1C
karos/ka_rose.cpp
karos/ka_pic.cpp
karos/ka_std.h
INC/distrib.txt
INC/V32FTick.h
group/bld.inf
Version 1.02.188
================
(Made by Dennis, 13th July 1999)
1) Morgan
1) Removed the SPI controller from MMAD platform
kamad\ka_spi.cpp
kamad\ekern.mmp
kamad\ka_psu.cpp
2) Used a more efficient method for draining the write buffer on MMAD
kcarm\kc_mmu.cpp
kamad\ka_ini.cpp
3) Included a missing call to POS in the slow swi dispatcher
kcarm\kc_int.cpp
4) Frozen BMMAD
bmmad\*.def
5) Added a gcc-helper static library (EGCC.LIB) which currently
only contains the __fixuns* helper functions
upepoc\up_gcc.cpp
group\egcc.mmp
6) Implemented RTC emulation
kamad\ka_utl.cpp
kamad\ka_std.h
kamad\ka_pic.cpp
7) Added state discriminator functions to TLinda and updated Linda Dma
kamad\ka_dma.cpp
kamad\ka_linda.cpp
inc\v32linda.h
2) Petteri
1) Added an improved version of
varmlb\va_keyb.cpp
3) Alastair
1) Added Graham Asher's updates to his change to UMATH\UM_DTOR.CPP so that
it builds in narrow variants.
2) Added GROUP\BOOTROM.MKE - a bldmake-compatible custom-build makefile
for building bootstraps.
3) Removed some hacks from MNT.BAT now that MAKMAKE from E32TOOLP version
109 builds static libraries to \EPOC32\Release\MARM rather than
\EPOC32\Release\MEIG.
4) Moved \e32\inc\conswins.def to \e32\inc\econs.def and listed it for
export to \epoc32\release\wins\econs.def. Made a corresponding change
to \e32\inc\consmarm.def and removed \e32\inc\consmisa.def.
5) Moved the implementation of the RConsole and TConsoleKey classes into
EWSRV.DLL from ECONS.DLL. Stopped exporting all functions from the
CConsoleTextWin Class under WINS/MARM except the function to create a
new console. Removed the dummy export from the text window server.
This means there is no longer a mutual link-time dependency between
ECONS.DLL and EWSRV.DLL - ECONS.DLL merely depends upon EWSRV.DLL, and
the WINS ECONS.DLL has the same API as the WINC one. and not vice
versa.
6) Added fetcher definition file, E32.FTC, to the group directory.
7) Fixed ER5U defect EDNABRY-48YFUC "Compiling E32 with MSVC6 reveals
problems with TPtr8 and TPtr16 copy constructors."
Fixed in USRC\US_DES8.CPP by taking the contents of the function
TPtr8::Set(TPtr8 &aPtr) function and adding it to function
TPtr8::TPtr8(const TPtr8& aTPtr). This change is not binary compatible
backwards with code which calls the TPtr8 copy constructor either
explicitly or implicitly and relies upon the previous behaviour of the
copy constructor. The previous behaviour merely made sure that the
copied TPtr pointed to the same descriptor as the original TPtr, while
the new behaviour also makes sure that the TPtr's iType is set
correctly.
These changes were necessary for TPtr8s to work correctly when compiled
with MSVC6. I have made corresponding changes to the TPtr16 copy
constructor.
8) Changed KPWINS\KP_GUI.CPP so that the Windows character code
translation is suppressed if the Ctrl, Alt and Shift keys are all
depressed. This means that the heap-checking code for APPs which used
the Ctrl-Alt-Shift-A combination will now work again, as the EPOC key
translation will not be overridden by the Windows translation.
4) Chris
1) Added export to mmu to enable creation of DHardware chunk from Ram.
2) Slight change to TDma to allow it to break up non-contigous transfer
buffers.
3) Added fast infra-red LDD(Efir) to misa and mmad and a fast infra-red
PDD(Difiba) to misa.
4) Changes to TSa1100 variant class to implement infra red and dma on
misa.
ImpDma class impemented also for misa.
5) Added 572000,1152000 and 4000000 baud defs to d32comm.h.
5) Dennis
1) Added routine ImpExc::AdjustRegisters() to restore registers on ARM
processors to allow an aborted instruction to be retried.
2) Added TException::Bind(), TException::UnBind() exported functions to
allow device drivers to bind to exceptions.
3) Various Snowdrop-specific fixes which didn't make it for ER5.
(Euro, Digitiser factory settings, Windermere DRAM refresh, ROM size,
digitiser EEPROM calibration)
4) Prefetch aborts now have exception ID EExcCodeAbort instead of
EExcGeneral.
5) Added ExecHandler::RomHeaderAddress() to windermere kernel.
6) Rearranged VAWDB1U.DEF so that VariantInitialise__Fv is at ordinal 1
(this is necessary or else nothing works).
7) Fixed bug in new RTest where RDebug::Printf(_L("<string>")) would panic
if <string> contained a % character. This was due to <string> being
passed into AppendFormatList which was then interpreting the % as a
format specification.
8) Modified assembler code in EUSER to allow thumb interworking by making
all subroutine returns and indirect function calls use the BX
instruction. Macros have been used so that the ARM-only version with
no BX instructions can still be built - this is necessary for
StrongARM builds.
Macros employed are:
__JUMP(cc,r) = BXcc r or MOVcc PC, r
__POPRET(rlist) = LDMFD SP!, {rlist,lr} \ BX lr or LDMFD SP!,{rlist,pc}
__CPOPRET(cc,rlist) = LDMccFD SP!, {rlist,lr} \ BXcc lr or LDMccFD SP!, {rlist,pc}
NOTE: Thumb interworking is still disabled by default, since the new GCC
is not yet fully deployed.
9) Made minimal modification to EKERN to permit thumb user code to execute
correctly. This involves changing two instances of "mov pc, lr" in the
SWI handler to __JUMP(,lr) and also involves changing
DArmPlatThread::CallFunction to use separate routines depending on
whether an ARM or THUMB context is being modified. Also, when saving
context following a SWI call, the saved PC points to a BX instruction
instead of to the return address from the Exec:: function.
NOTE: All supervisor mode code is expected to be ARM. Much more
extensive modification of the kernel would be required to permit THUMB
device drivers.
10) Compiled and tested E32 with the new version of GCC. This produces
several warnings, mostly "comparison of signed and unsigned", "ANSI
C++ does not permit declaration without type", "Taking address of
temporary" and "XXX declared but not used" (for variables or functions
only used from within assembler code). Modified the source to remove
these warnings.
11) Compiled and tested E32 using THUMB test executables. These all work
apart from those which contain ARM assembler code. Disabled
breakpoint exception since this can crash the kernel with an alignment
fault if an undefined instruction is encountered in THUMB code.
Fixing this properly would require a lot of work on the debugger to
fully support THUMB.
NOTE: To build THUMB executables, the _call_via_r0() helper functions
are required. These were added to EEXE.O for testing purposes, but will
eventually be in the GCC helper library.
12) Modified TDes::AppendFormatList() so that variable precision
specifications are now allowed, and so that the precision
specification is also applied to strings.
6) Simon
1) Improved ps/2 keyboard initialisation within kacga
7) Mark
1) Enabled unicode WINS/WINC to run on Windows 9x. Introduced euniw.dll
to convert between unicode and relevant narrow Win32 functions.
Added exported set of functions to euser.dll that return a pointer
to either the relevant 'W' Win32 function or a wrapper function in
euniw.dll. These functions and the initialisiation of the function
pointers is implemented in upwins\up_uansi.cpp.
2) Changed unicode to narrow WINS/WINC conversion from UTF-8 to
CP_ACP in WinCOutput::Write and Debug::DebugFunction.
Version 1.02.187
================
(Made by Alastair, 9.6.99)
1) Jason
1) Added sleep and wakeup code for MISA
2) Enabled LCD and Keyboard for Brutus wakeup.
3) Added MCP controller accessor functions for MISA
4) Modified power model to share MCP clock
5) Added definitions for the Brutus UCB1200 codec chip.
6) Added touch screen controller for Brutus, including touch to wakeup.
7) Fixed Brutus keyboard controller to not enable interrupt edges that it
does not use.
8) Added the missing function TSa1100::UartTxBusy() to MISA
\inc\v32s1100.h
\v32ucb12.h
\kaisa\ka_isa.cpp
\ka_ini.cpp
\ka_power.cpp
\ka_power.h
\kbisa\sa1100.inc
\sa1100.s
\visaba\vi_hw.cpp
\vi_keycn.cpp
\vi_xyin.cpp
2) Morgan
1) Made Mmu::UnlockPageTables and Mmu::LockPageTables public so
code that calls Mmu::LogicalToPhysical() can unlock and
access the page tables.
\inc\m32hal.h
2) Unlocked the page tables in TDma::NextBlock() function
\kpepoc\kp_dma.cpp
3) Petteri
1) Added Linda serial driver.
2) Added 230.4K speed to d32comm.h and modified old serial drivers
to dislike it.
\group\datxlb1.mmp
\inc\d32comm.h
\v32linda.h
\kamad\ka_linda.cpp
\varmca\va_com1.cpp
\va_com2.cpp
\varmcl\va_com1.cpp
\va_com2.cpp
\varmlb\va_com1.cpp
\varmp2\va_com1.cpp
\varmpb\va_com1.cpp
\varmpc\va_com1.cpp
\va_com2.cpp
\varmpd\va_com1.cpp
\va_com2.cpp
\vawdb1\va_com1.cpp
\va_com2.cpp
4) Graham Asher (merged by Jonathan)
1) Implement standard Unicode collation and add new collation functions
to allow loose matching.
2) Fill up all the available TLanguage slots (00 to 99); codes added
include those requested for Roxette; this is a provisional solution
pending the introduction of a saner language and locale number API.
3) Fix problems in TLex16::Val(TRealX&,TChar) &
TLex16::Val(TReal64&,TChar) in Unicode-to-8-bit conversion (defect
EDN769607).
4) Obsolete functions yet to be removed:
TInt TDesC16::CompareC(const TDesC16& aDes,const TInt16*
aCollationRules) const;
TInt TDesC16::CompareC(const TDesC16& aDes,TUint32
aDesiredCollationRulesId,TUint32&
aActualCollationRulesId) const;
static TInt Mem::CompareC(const TUint16* aLeft,TInt aLeftL,const
TUint16* aRight,TInt aRightL,const TInt16*
aCollationRules);
static TInt Mem::CompareC(const TUint16* aLeft,TInt aLeftL,const
TUint16* aRight,TInt aRightL,TUint32
aDesiredCollationRulesId,TUint32&
aActualCollationRulesId);
static TInt Mem::CollationRuleSets();
static TInt Mem::CollationRuleSetId(TInt aIndex);
static const TInt16* Mem::CollationRuleSetByIndex(TInt aIndex);
static const TInt16* Mem::CollationRuleSetById(TUint32
aDesiredId,TUint32&
aActualId);
5) Jonathan
1) Fixed "ambiguous overload for `bool ? TChar : char'" errors from new
gcc compiler.
umath\um_rtod.cpp
6) Alastair
1) To build this release of e32tools you'll need the latest version - 108
- of E32toolp. If you're going to use this release at all, you'll
need to be building your component with the latest version of
e32toolp, since import libraries are only released in the MARM release
and WINS debug directories and also because EDLL.O and EEXE.O won't
link properly with older versions of e32toolp.
2) Renamed MARM platform to MEIG and SARM platform to SEIG just as far as
E32 is concerned. Other components will still build for the MARM (and
SARM) platforms. This change means that rombuild obey files will need
to change to reflect the new location of e32 releasables in
\EPOC32\Release\Meig instead of \EPOC32\Release\Marm.
3) Changed zips of releasables put onto the network. There is now one zip
file for each platform. There is also a zip file for exported header
files. Hence, the contents of S:\e32\zip includes
export.<ver>, wins.<ver>, meig.<ver>, misa.<ver> ,mawd.<ver> winc.<ver>.
Each of the meig, misa and mawd zip files should contain everything
necessary for building components which depend on E32 for marm.
The files within these zip files now also have full pathnames so ensure
you unzip them into the root of your EPOC drive with any flags required
to recreate the directory structure.
4) Added new MAKMAKE keyword ASSPEXPORTS to various .MMP files so that
they search ASSP-specific deffile directories rather than CPU-specific
deffile directories by default. E.G. EKERN.DLL built for narrow MISA
REL will refer to \E32\BMISA\EKERN.DEF rather than
\E32\BMARM\EKERN.DEF. These .MMP files are for EKERN, EPBUS, VARMCL,
VARMLA, VARMLB, VARMP2, VARMPB, VARMPC, VARMPD, VAWDB1, VISABA,
VISACA, VROSR1, VCGAC1, VARMCA. This keyword means that the import
library for a project build for MEIG will go into
\EPOC32\Release\MEIG\<rel|urel>\ rather than
\EPOC32\Release\MARM\<rel|urel>\.
Where .MMP files have links to the import libraries for these
components I have listed the libraries with new keyword ASSPLIBRARY
and taken them out of any existing LIBRARY statements. This ensures
that the generated- makefile will search in the correct place for the
import library. Any other components linking to these libraries will
have to do the same thing.
5) Kernel include headers are now exported to \EPOC32\Include\Kernel
rather than \EPOC32\Include, so if your component includes these
headers you'll need to add \EPOC32\Include\Kernel as a SYSTEMINCLUDE
file in your .MMP file.
6) Added new command, MNT CHECKREL, to check that all releasables are
present before doing an MNT PUTREL.
Before doing MNT CHECKREL or MNT PUTREL call BLDMAKE -v RELFILES to
create the lists of releasables.
7) Changed edll, exdll, eexe and kc_exe so that they all build as static
libraries rather than object files in accordance with ER5u makmake
changes.
8) Changed second uids in device driver .MMP files to zero so that makmake
will apply the correct ones automatically.
9) Changed .MMP files to take advantage of changes in makmake .MMP
#defines.
10) Replaced all B[plat].PRJ files for use with BLDMAKE with BLD.INF in
accordance with latest BLDMAKE changes.
11) Moved ETIMR and T_DEVC to project E32TEST.
12) Removed all E*.REL files from GROUP directory and changed MNT.BAT so
that MNT PUTREL looks for .REL files generated by BLDMAKE instead.
Updated BLD.INF accordingly.
13) Changed #defines in the following files now that __MEIG__ is being used
to mean __MARM__ and __MARM__ is being used to mean ARM CPU:
INC\U32STD.H, INC\M32STD.H, PSRC\PS_PCCD.CPP,
KCARM\KC_INT.CPP, DPEPOC\D_MEDINT.CPP, DPEPOC\D_MEDCRR.CPP,
DPEPOC\D_MEDCRM.CPP, DPEPOC\D_MEDATA.CPP.
14) Removed EVALID.PL and EVALID.BAT from GROUP dir now that this version
of EVALID is being released as part of E32TOOLP.
15) Created directory \E32\BMEIG. Moved .DEF files for the following
projects from \E32\BMARM\ to \E32\BMEIG:
EKERN, EPBUS, VARMCL, VARMP2, VARMPB, VARMPC, VARMPD.
16) Removed unnessary __XCON__ #defines and swapped them with __WINC__
instead where necessary.
17) Removed XWSRV.MMP, XPBUS.MMP, XCONS.MMP, EXYIN.MMP and EKEYB.MMP - they
were no longer required now that libraries can be built separately.
Note that this means the import libraries must be built before building
the other releasables because of the mutual imports between some E32
Dlls.
18) Changed variant .MMP files to link to the respective variant versions
of exyin.lib and ekeyb.lib now that exyin.lib and ekeyb.lib are no
longer built as import libraries.
19) Removed WINS #defines from around the dummy export for the text window
server so that it has a dummy export for other builds. Frozen the dummy
export in \E32\BMARM\EWSRV.DEF.
20) Removed export command from MNT.BAT and EXPORT.PL from group directory
now that and equivalent command is provided by BLDMAKE.
20) CONSWINS.DEF, CONSMARM.DEF and CONSMISA.DEF are now exported to
directory \EPOC32\Release\<Platform>\ rather than \EPOC32\Include.
21) Changed #defines in K32ADDR.H, U32STD.H, V32COG.H in accordance with
makmake #define changes for __SROS__ and __SCGA__.
22) Adjusted BLD.INF so that kernel headers are exported to
\EPOC32\Include\Kernel\ rather than \EPOC32\Include. This means that
any projects requiring the kernel headers will have to have
\EPOC32\Include\Kernel added to the list of SYSTEMINCLUDE paths within
their .MMP files.
23) Removed all .DEF files from the B<plat> directories which are now
referenced in the BMARM directory. Renamed BSROS BMROS and removed
BSARM and BSCGA.
24) Added extra commands to MNT.BAT to copy edll.o and eexe.o from the MEIG
release directories to the MARM ones pro tem, and to zip them up for
MEIG, MAWD and MISA.
25) Changed rom.oby files in KBARM and KBSARM directories to incorporate
changes resulting from the new way E32 is built. A few changes in
other rom.oby files may also be required.
26) Excluded Graham Asher's change to UMATH\UM_DTOR.CPP since they won't
build in narrow variants.
27) Fixed up MEIG EKERN.DEF following Pete's DMedia changes.
28) Changed P::Print so that in release builds it uses Win32's
OutputDebugString() rather than putting up a message box. This has
always been the behaviour in debug builds. As a result of this change,
test output will no longer appear in an annoying sequence of message
boxes.
7) Pete
1) Modification to DMediaDriver class so a media driver
can be configured to allow read/write/format requests simultaneously
with each other. By default, a driver only allows one
request to be outstanding at any time but by setting the
DMediaDriver member iFlags to KMediaDrvMultipleReqs,
a read/write and format command may each be outstanding at a given
time.
\ksrc\ks_locd.cpp
\inc\k32std.h
\inc\k32std.inl
Version 1.02.186
================
(Made by Malcolm, 21st May 1999)
Petteri
1) Added a new variant (Varmca) for the Rev.A of the new Cirrus
Logic 711X evaluation board. This port is not complete: digitiser
driver, most of ADC code, second serial port and some other
small things are missing. Also, the board is still evolving.
New files added:
Varmca\Va_c6700.cpp Group\Cakdca.mmp
Varmca\Va_com1.cpp Group\Cakyca.mmp
Varmca\Va_com2.cpp Group\Caxyca.mmp
Varmca\Va_hw.cpp Group\Dasnca.mmp
Varmca\Va_kdata.cpp Group\Datxca1.mmp
Varmca\Va_keyb.cpp Group\Datxca2.mmp
Varmca\Va_pbus.cpp Group\Varmca.mmp
Varmca\Va_sdrv.cpp Inc\V32armca.h
Varmca\Va_spi.cpp
Varmca\Va_xyin.cpp
Varmca\Va_std.h
Old files modified:
Group\Bmarm.prj
Group\Emarm.rel
Kbarm\E32var.iby
Kbarm\Rom.oby
Kbarm\Setvars.cmd
( and also:
Kamad\Ka_linda.cpp
Inc\V32linda.h )
Jason
1) MISA Idle code fix.
\kaisa\ka_utl.cpp
\kcarm\kc_int.cpp
\kbisa\sa1100.s
Jonathan
1) Added Protea, Cassius and inc{c|k} files to distrib.txt files
bmarm\distrib.txt
bmisa\distrib.txt
inc\distrib.txt
group\distrib.txt
Version 1.02.185
================
(Made by Malcolm, 14th May 1999)
Malcolm et al.
1) Prepared E32 for automatic building and testing. Each kbXXX
directory should now have the following files:
rom.cmd that takes an .oby file as the first parameter (and
then the standard build/variant as before).
test.oby that builds a rom with all the test code for that
platform. Test.oby should also include batch files called
z:\test\e32auto.bat, z:\test\f32auto.bat and
z:\test\allauto.bat that run respectively the e32, f32 and all
tests for this platform. For now, these are taken from
\e32test\group./
bld.cmd that creates udeb and urel roms, given that all of
e32, f32 and the test suites have been built. Typically this
makes the bootstrap code then calls rom.cmd.
This change has been implemented for misa, marm, mcga & sros.
Alastair
1) Changed RDebug::Print for WINS/WINC so that output is appended to file
EPOCWIND.OUT in the PC's temporary directory, as well as being sent
where it is currently. In UNICODE builds, the output is converted to
UTF-8 before being appended to the file.
2) Changed WINC Console output under UNICODE builds so that it can be
redirected to a file. The output is converted to UTF-8 before being
sent to the console.
Simon
1) Merged in Cogent
\kacga\*
\bmcga\*
\vcgac1\*
\wsrc\wd_vgacga.cpp
\wsrc\wd_vtcgakb.cpp
2) Modified coproc related bits for ARM4 on Cogent
\kcarm\kc_sched
\kcarm\kc_mmu
Petteri
1) Minor Linda screen and keyboard related changes.
\kamad\ka_ini.cpp
\kamad\ka_linda.cpp
\inc\v32linda.h
\varmlb\va_hw.cpp
\varmlb\va_keyb.cpp
\wsrc\wd_mad.cpp
Malcolm
1) Changes to mnt.bat. Directories are now enummerated in
dir.prj rather than being hard-coded into mnt.bat all over the
place. Two perl helper scripts have been created to interface
to PVCS.
\group\mnt.bat
\group\dopvcs.pl
\group\lock.pl
\group\dir.prj
Petteri
1) Minor changes in order to tidy up DisplayOn()
\kamad\ka_ini.cpp
\inc\v32linda.h
\varmlb\va_hw.cpp
\wsrc\wd_mad.cpp
Petteri
1) Speed improvements to Linda screen driver.
\wsrc\wd_mad.cpp
2) Modified keyboard related files so that Linda keyboard
driver works properly.
\varmlb\va_keyb.cpp
\varmlb\va_kdata.cpp
\group\cakylb.mmp
Malcolm
1) Upgraded the MNT DISTRIB command to cope with per-file
inclusion/exclusion. Now uses perl to parse distrib.txt
files. These files have changed in format. The format is
now lines of the format:
<filename> <licensee>
If the filename is Default, then all the files in this
directory will be included. If the licensee text contains
"Epoc" then this is part of the generic release.
To always exclude a file I suggest using a licensee of "Never".
Comments can be started with the # character and last to the
end of the line. \inc\distrib.txt and \group\distrib.txt files
are good examples.
The distrib.txt files themselves are never included.
At the moment, this script requires pkzip version 2.5, called
pkzip25 to be in the path. This is due to limitations with
the previous versions of pkzip.
\group\distrib.pl
\group\mnt.bat
\*\distrib.txt
2) Fixed single process scheduler bug
\kcarm\kc_sched.cpp
3) Merged in Simon's automatic test changes.
\usrc\us_test.cpp
\inc\e32test.h
4) Added export.pl that will export E32 headers appropriately.
\group\export.pl
Petteri
1) Added text screen driver for Linda
\wsrc\wd_mad.cpp
\group\edisp.mmp
Malcolm
1) Removed all the li.prj files & moved the distribution comments
to distrib.txt files. Updated mnt.bat to deal with this.
\group\mnt.bat
*\li.prj
*\distrib.txt
2) Boilerplated Roxette sources
\vrosr1\*
\karos\*
\kbros\*
Malcolm
1) Major reorganisation of the E32 tree. Tags: Pre-ER5u-Reorg is
before this, Post-ER5u-Reorg is after it.
What was upmarm and upmx86 has had the common parts extracted
into upepoc and the architecture dependant bits moved to
ucmarm and ucmx86 respectively.
\upmarm\*
\upmx86\*
\ucmarm\*
\ucmx86\*
\upepoc\*
group\ekern.mmp
group\eexe.mmp
group\xcons.mmp
2) Ucdt has been moved over to Usrc
\ucdt\*
\usrc\*
group\euser.mmp
3) Roxette (SROS) has been merged in
\karos\*
\kbros\*
\vrosr1\*
\bsros\*
group\ekern.mmp
group\bsros.prj
group\esros.rel
group\euser.mmp
group\ekern.mmp
group\edisp.mmp
group\eexe.mmp
group\ekdata.mmp
group\inck.rel
group\vrosr1.mmp
wsrc\wd_rose*
4) Removed EPBUS reference in epbus
group\epbus.mmp
5) Added support for screen dimension keys (flip keys)
inc\e32keys.h
inc\e32panic.h
usrc\us_evnt.cpp
6) Changes to timers to disambiguate periodic and locked timers for the
lower layers by encoding a value in the repeat field
ksrc\ks_tim.cpp
inc\k32std.h
7) New function UserSvr::RomHeaderAddress(), replacing the use of
KRomLinAddr constant. This is so the F32 is single-process agnostic.
All address constants have been moved to k32addr.h
inc\k32addr.h
kpepoc\kp_ini.cpp
inc\u32std.h
inc\e32rom.h
inc\e32svr.h
inc\m32hal.h
Jason
1) Added debug monitor for MISA
\KAISA\KA_MON.CPP
\INC\M32STD.H
\GROUP\EKERN.MMP
Morgan
1) Upgraded Dma abstraction to cope with transfers across page boundaries
\INC\M32STD.H
\KAMAD\KA_DMA.CPP
\KPEPOC\KP_DMA.CPP
2) Fixed function prototype for DPowerHandler::SetRequirement(TUint &aState)
\inc\k32power.h
\ksrc\ks_power.cpp
\b*\ekern*.def
3) Implemented Hal::ModifyLedMask()
\kpehal\kph_inf.cpp
4) Fixed key translator to use User::LowerCase instead of User::Fold
for EMatchKeyCaseInsens
\wsrc\ky_tran.cpp
5) Merged in changes for MMAD
\inc\u32std.h
\inc\v32linda.h
\kbmad\*
\kamad\*
\varmlb\*
6) Corrected remote serial screen cursor positioning
\wsrc\wd_vt100.cpp
7) Fixed mismatched #defines of
__CPU_SPLIT_TLBS and __CPU_SPLIT_TLB
__CPU_CACHE_CONFIGURABLE and __CPU_CACHE_SELECTABLE
\kcarm\kc_mmu.cpp
8) Removed NotBuffered attribute from the read-only EKernelCode and
EUserCode chunks
\kcarm\kc_mmu.cpp
9) Added Platform dependent constants for page table attributes
\kcarm\kc_mmu.cpp
10) Integrated the debug monitor into MMAD
\kamad\ka_mon.cpp
\inc\m32std.h
11) Uncommented the two lines of code that flush the D-Cache on
split cache processors
\kcarm\kc_sched.cpp
\kcarm\kc_mmu.cpp
12) More bug fixes for MMAD
\kamad\ka_linda.cpp
13) Implemented Rom groping in the bootstrap
Jonathan
1) Fixed fix for EDN430762 in 170; trap handler was not being correctly
zeroed.
kpwins\kp_utl.cpp
2) Reinstated unused functions SetLine and GetLine cos they're pure
virtual in the base class and so need to exist.
wsrc\wd_wins.cpp
3) Made RTest::Getch() pause for input even in non-manual mode.
usrc\us_test.cpp
Version 1.02.181
================
(Made by Pete, 5th May 1999)
1) Pete
1) Added the (exported) function:-
TBusLocalDrive::Format(TInt aPos,TInt aLength)
so that it is possible to format just a part of a
drive.
2) Changed the local drive allocation for Brutus/WINS as follows:-
Local-Drive-Num Assignment
(Let-EPOC/WINS)
0 (C:/Y:) EFixedMedia0 (Internal Ram)
1 (D:/X:) ERemovableMedia0 (1st partition on PC Card Socket0)
2 (E:) ERemovableMedia1 (1st partition on PC Card Socket1)
3 (F:) ERemovableMedia0 (2nd partition on PC Card Socket0)
4 (G:) ERemovableMedia1 (2nd partition on PC Card Socket1)
5 (H:) ERemovableMedia0 (3rd partition on PC Card Socket0)
6 (I:) ERemovableMedia1 (3rd partition on PC Card Socket1)
7 (J:) Not used
8 (K:/W:) EFixedMedia1 (Flash File System)
3) Backed out the change made in V180 to TTrapK::Trap() in kpwins\kp_utl.cpp as
this is suspected to be causing problems in WINS Unicode builds.
4) Fixed a problem with the function ImpHal::Idle() on ISA builds
(KAISA\KA_UTL.CPP).
5) Fixed a problem with EPBUS.DLL which resulted in an exception
if an attempt was made to open a media driver for a peripheral
bus device (ie derived from DPBusMediaDriver) on an
internal drive. This typically only causes a problem on machines
which have a local drive designated as an internal drive in addition
to the standard Internal Ram drive (ie EFixedMedia1). This isn't a
problem on Snowdrop/Protea. There generally isn't a problem on the
internal Ram drive (ie EFixedMedia0) since the IRAM media driver
(MEDINT.PDD) opens successfully on this device before any drivers for
removable devices. (It would have caused a problem if ATA media driver was
loaded before the IRAM media driver).
6) Modified E32VAR.IBY and ROM.OBY in \KBISA to allow ISA UNICODE rom's
to be built successfully.
7) Added a LFFS media driver (MEDLFS.PDD) to the WINS and Brutus platforms.
The WINS version emulates a media device by performing reads/writes to the
file <temp>LFSLDRV.BIN (e.g. C:\TEMP\LFSLDRV.BIN). The Brutus version uses
2Mb of flash in Static Memory bank 1 and thus requires a pair of 1M x 16 flash
chips to be fitted to this bank. These devices aren't fitted on a standard Brutus
rack as shiped from Intel. The Brutus media driver is a read-only implementation
in this release.
Version 1.02.180
================
(Made by Pete, 29th April 1999)
This is an ER5U release
1) Jonathan
1) Fixed EDN430762 (E32TEST T_REG.EXE fails in WINS REL).
TTrapK::Trap() in kpwins\kp_utl.cpp mixed assembler and C++ and was
being broken by MSVC5's aggressive optimisations when built for
WINS/WINC REL/UREL. The fixed code is still vulnerable to compiler
changes because it still contains one C++ statement and could
therefore be confused by the compiler setting up a stack frame or
trashing the cx register.
TTrap::Trap() in upwins\up_trp.cpp and upmx86\up_trp.cpp would contain
the same problem but we can't build the user library under MSVC5 with
optimisations enabled for other reasons so the problem does not
appear.
2) Pete
1) Modifications to Brutus variant (VISABA) to fix a problem with the PC Card
interface CD signals on GPIO7 (socket1) and GPIO4 (socket0). These were being
reconfigured to their alternate function (upper port of LCD interface) within
the function Variant::DisplayOn().
2) Change to the way the ISA PC Card Controller handles a media change interrupt so
that it now queues a 20ms millisecond callback to handle switch debounce rather
than doing this directly from the interrupt service routine.
3) In the ISA PC Card Controller abstraction, removed some redundant functions calls
called during media change and socket interrupt handling. These functions had been
carried over from the MARM platform.
4) Disabled idle mode for now in the ISA platform (ImpHal::Idle()). There appears to be a
problem with PC Card IREQ interrupts (implemnted using GPIO edge triggered interrupt)
bringing the machine out of idle such that the machine eventually hangs.
5) Implemented a new Pc Card Controller to Variant interface for ISA platforms (TPcCardControllerIsaInterface
in V32PCCDI.H). This includes the following new functions:-
- const TDesC8& SocketIntSource(TSocket aSocket,TPccdEvent anEvent);
- void InitSocketInt(TSocket aSocket,TPccdEvent anEvent);
- void ClearSocketInt(TSocket aSocket,TPccdEvent anEvent);
This is allows the socket interrupt implementation on ISA platforms to performed
at the variant layer
3) Alex
1) Modifications to ISA bootstrap (which is really tailored for the reference Brutus
platform) to support running code from RAM rather than FLASH. This means that images larger
than 4Mb (the previous limit on this platform due to the size of the flash bank) can be
handled. Use with E32UTILS REPROB V027.
4) Pete
(inc\E32SVR.H)
Modification to TLocalDriveCapsV2 to add the data member
iEraseBlockSize. This is to support an F32 Flash File System.
Version 1.02.166
================
(Made by Jonathan, 23rd February 1999)
1) Jason
1) Implemented Millisecond timer for MISA.
2) Made the ATA Media driver as part of the ROM for MISA.
2) Dennis
1) Replaced Snowdrop digitiser default calibration values with values
supplied by Amazon.
2) Modified Windermere LCD controller Timing2 register setting as
requested by Amazon.
3) Changed Snowdrop current consumption and battery threshold values
to those supplied by Amazon.
3) Morgan
1) Replaced the code that stops the machine turning off if an absolute
timer is due soon.
4) Jonathan & Co
1) Boilerplated source.
2) Removed historical epocfns.txt, sizes.txt, sizes.xls from .\group.
5) Alastair
1) Replaced hard-coded R: with %s% in MNT.BAT.
2) Changed MNT PUTSRC to use T:\Tools\Zip.exe rather than
T:\Tools\PKZip.exe.
3) Changed MNT GETREL to get the WINC debugging releaseables for DEB and
UDEB builds.
4) Removed non-existent V32ARMS1.H, V32SASIC.H and duplicate listing of
K32POWER.H from \E32\INC\INCK.PRJ.
5) Removed non-existent D32FTIM.H, D32FTIM.INL and *.FRZ from
\E32\INC\INCC.PRJ.
6) Added CONSWINS.DEF, CONSMARM.DEF and CONSMISA.DEF to \E32\INC\INCK.PRJ.
7) Removed CAKDP2 Series5 keyboard variants from EMARM.REL.
8) Removed ELOCL variants from EMARM.REL, EWINS.REL and EWINC.REL.
9) Moved \E32\INC\INCC.PRJ to \E32\GROUP\INCC.REL and \E32\INC\INCK.PRJ to
\E32\GROUP\INCK.REL and changed MNT.BAT so that these .REL files are
treated in the same way as all the other .REL files.
10) Updated validation process to use William's new EVALID.BAT (added to
E32\Group pro tem.).
11) Removed empty file \E32\Inc\M32hal.inl.
Version 1.02.165
================
(Made by Pete, 16th February 1999)
1) Jason
1) Removed fixed Rom address from MMU initialisation bootstrap code.
2) Morgan
1) Fix for defect EDN964446 to prevent WINS standby going re-entrant.
3) Mark
1) Implemented PC card driver for MISA.
4) Dennis
1) Applied Jason Robinson's patch for defect EDN061952 (cannot force a
cold reset by holding down both shift keys).
2) Fixed problem EDN106813 (snowdrop pathological failure mode).
5) Pete
1) Added range checking to the Pc Card h/w chunk allocation functions
(derived versions of RPccdChunkBase::CreateL()) in MARM, MISA and MAWD
builds to prevent this allocating memory chunks beyond the physical
region assigned to the Pc Card memory.
Version 1.02.164
================
(Made by Jonathan, 10th February 1999)
1) Jonathan
1) Disabled the crash debug monitor.
2) Fixed problem EDN941329 "RThread::GetRamSizes() Crashes the Kernel" by
making RThread::GetRamSizes() return 0 for the heap size in combined
stack+heap chunks.
3) Applied Dennis' fix for EDN157244 "Process creation can leak memory"
by promoting DPlatProcess::FirstThread() to DProcess::FirstThread()
and checking for case where OOM occurs after thread creation.
2) Dennis
1) Fixed problem EDN256123 (adding a thread to a dead process crashes the
kernel). Create empty process handles array after deleting the
original one, and when creating a new thread check that the owning
process is not dead.
2) COM061952: Put in Jason Robinson's bootstrap fix for Windermere so
that cold resets (both shift keys down) should now work on Snowdrop.
3) Morgan
1) User::LoadLogicalDevice and User::LoadPhysicalDevice now supply
match-Uid's KLogicalDeviceDriverUid and KPhysicalDeviceDriverUid on
their calls to RLoader::LoadLibrary
4) Pete
1) Added the function TPBusCallBack::Clear() (exported from EPBUS.DLL) to
clear the source of a Peripheral Bus event (e.g. IREQ interrupt from
PC card). This is a 'generic' version of the temporary fix applied in
E32-162 for defect 'CF Card interrupts being missed on Snowdrop
machines'. Also, removed the functions
DPcCardController::EnableEvent() and DPcCardController::DisableEvent()
and replaced them with TPBusCallBack::Enable() and
TPBusCallBack::Disable() respectively.
2) Added the functions DPcCardController::PwrUpProfile() and
DPcCardController::SetPwrUpProfile() to read/modify the power up
profile of the PC Card Controller (ie time reset applied, pause after
card becomes ready, timeout period when waiting for card to become
ready). Removed the parameter 'aResetProfile' from
DPeriphBusController::PowerUpBus(), DPcCardController::PowerUpCard(),
and DPcCardController::RestoreCardPower() as this information is now
superfluous.
3) Increased synchronous busy timeout period on ARM ATA driver from 15mS
to 20mS to support large Lexar CF cards.
4) Enabled CF card rail (Vpc) monitoring in Snowdrop variant. Also
modified this so that checking is performed periodically as long as
the rail is on (in addition to once when first turned).
5) Change to ARM ATA driver so it checks for 'card not busy' if it times
out on a command. If the card isn't busy then it processes this as if
it had received a normal card interrupt.
Version 1.02.163
================
(Made by Pete, 3rd February 1999)
1) Morgan
1) Fixed a problem that was causing Dll entrypoints to be called
with EDllProcessAttach twice.
2) Jason
1) Restored the RAM drive to MISA.
3) Dennis
1) Fixed problem EDN591058 (remote thread write to end of chunk can
fail). Use sizeof(TDes8) instead of sizeof(TBuf8<1>)-1 for checking
to avoid alignment problems.
2) Fixed problem EDN468376 (RHeap::Compress can leave heap
corrupted). In the situations where a free cell header would have
been chopped in half, an extra page of RAM is now left allocated to
the heap.
3) Fixed problem EDN102617 (undefined instruction exception kills the
kernel). Modified undefined instruction handler to run Exc::Dispatch
in mode_und rather than mode_abt.
4) Modified super page signature so that it includes the E32 version
number. This means that when a machine is reprogrammed to a
different version of E32, a cold reset will be forced when the
machine is first booted even if the user attempts to do a warm
reset.
4) Jonathan
1) Fixed problem EDN671244 (RDebug::ReadMemory can reset the machine)
by trapping calls from Debug::DebugFunction to Debug::ReadMemory and
Debug::WriteMemory.
2) Fixed problem EDN471656 (underlying cause of which was RAM disk
size not being a multiple of page size) by applying Andrew/Pete's
modified fix.
5) Pete
1) Renamed current implementation of the class TLocalDrive as
TBusLocalDrive. Also, changed TBusLocalDrive::Caps() from the form:-
TInt Caps(TLocalDriveCaps &anInfo);
to
TInt Caps(TDes8& anInfo);
with the later taking a TLocalDriveCapsBuf.
Re-introduced a TLocalDrive class which is BC with the E32-114
version. The TLocalDrive class will be maintained to support disk
utilities which need a level of direct disk access. However,
TLocalDrive functions: Enlarge(), ReduceSize() and Format() now
return KErrNotSupported. TBusLocalDrive is intended to be used only
by F32 and there is no BC commitment with this. (Fixes EDN545357).
2) Added EPBUS.MAP to MARM,MISA,MAWD release files.
3) Modification to prevent CF card from being powered down during a
write operation when the machine is turned off. This involves a
change to DPcCardController::PowerStandby() so that it waits a short
period for any critical operation to complete. If still critical
after that period then it goes ahead and powers down the sockets,
but generates an emergency reset event so that clients can attempt to
recover. (Fixes EDN201114).
4) Modification to IRAM media driver (EPOC Platform) so that when it is
first mounted, it takes its initial size directly from the super
page rather than the IRAM chunk size (which is in multiples of a
page size).
Version 1.02.162
================
(Made by Morgan, 27th January 1999)
1) Dennis
1) Fixed problem EDN153887 (using infra-red lowers RS232 RTS line) -
modified VAWDB1\VA_COM1.CPP to ensure that UART1 SIR enable bit is
always cleared.
2) Store garbage values in K::SvThread and K::SvProcess on completion of
a kernel server function to guard against inadvertent use of these in
executive calls or DFCs.
3) Fixed problem EDN741588. Modified S::ChunkCompressAll() in KS_CHK.CPP
so that it only attempts to compress the kernel heap if its critical
section is not blocked.
4) Added extra command 'R' to crash debugger to print the values of all
processor registers across all processor modes at the point where the
debugger was entered.
2) Jason
1) Restored link to MISA Idle code with-in the bootstrap.
2) MISA DRAM initialisation made to match the documentation.
3) Jonathan
1) Added missing "Distribution:" comments to PSRC\LI.PRJ and
KBAWD\LI.PRJ. Modified "mnt check" to check that all LI.PRJs contain
"Distribution:" comments.
2) Added new "mnt distrib" verb for zipping up a copy of E32 source for
distribution to a named licensee. This verb is intended to be used
on a clean freshly-got copy of the source.
"mnt distrib acme" will produce \E32-acme.zip for acme.
"mnt distrib generic" will produce an unencumbered \E32-generic.zip.
4) Pete
1) Fixed EDN590829 (CF Card interrupts being missed on snowdrop
machines). Fixed by clearing the interrupt directly from the media
driver interrupt callback rather than relying on it to be cleared by
the PC Card controller before the callback. This affects CF cards
which 'claim' to support pulse mode interrupts but actually seem to
implement level mode interrupts.
Version 1.02.161
================
(Made by MarkD, 19 January 1999)
1) Dennis
1) New Snowdrop digitiser and SPI code from Mark Ball.
2) Battery low interrupt now disables UART and Codec interrupts on
EIGER to prevent watchdog death due to permanently asserted
interrupt from UART when power is removed abruptly.
3) Reinstated __COMMS_MACHINE_CODED__ in VA_COM1.CPP for P2 and PD
variants, after fixing problem caused by hard-coded vtable offset.
2) Pete
1) Fixed two problems with the ATA command timeout
implementation on the ARM ATA driver. (The timeout catches
situations where a request is made on the card which ought to be
signalled by an interrupt from the card when complete, but where the
card fails to generate an interrupt):-
a) Changed to use a ticklink rather than a
TMilliSecondCallBack to implement the timeout.
b) Fixed a problem where the timeout could be requeued
before the previous timeout had completed.
2) Increased synchronous busy timeout period on ARM ATA driver from
8mS to 15mS to support KingMax CF cards.
3) Modification to function DMediaDriver::RequestSetup()
so it now returns KErrInUse if the data member iReqStat isn't NULL.
This prevents the possibility of more than one request at a time on a
single media driver.
4) Stopped releasing WINS .BMP files (ie killed SWINS.REL).
3) Morgan
1) Turned off emulation of the WINS backlight
Version 1.02.160
================
(Made by Jason, 12th January 1999)
1) Mark
1) Fixed a problem with MISA such that the screen wasn't being turned
on.
2) Dennis
1) Added kernel crash debugger to MARM and MAWD builds. When a kernel
fault occurs, the debugger will start instead of the machine just
restarting. The crash debugger is enabled by compiling with
__ENABLE_DEBUG_MONITOR__ defined in M32STD.H.
2) Got the C++ build going again. Compiling with
__MINIMUM_MACHINE_CODE__ defined in U32STD.H will result in a build
with all non-essential machine code removed. All tests pass on EIGER
in debug and release builds.
3) Assembler-coded most TWind functions (KE_WIND.CPP).
4) Made RPointerArray<T>::Count() and RPointerArray<T>::Find*() const.
5) Added check in svProcessTerminate in KS_SVR.CPP so that calling
RProcess().Terminate() does not crash the kernel.
3) Jason
1 ) MISA five layer split done created \e32\kaisa\ removed \e32\keisa\.
4) Morgan
1) Added Dll::FileName() which will return the drive, path, and filename
of the library it is called from. (Added UserSvr::DllFileName and
associated EXEC functions to support this). Dll's that exist on the
ROM drive and have not been RLibrary::Load()ed will return only the
drive, (ie. "Z:").
2) Fixed bugs in LoadLogicalDevice and LoadPhysicalDevice that was causing
unbalanced calls to the entrypoint of drivers (with EProcessDetatch and
EThreadAttach).
3) Removed cleanup code from user side code RLoader::LoadLibrary. Cleanup
of half loaded dll's is now performed loader side as it should be.
4) Fixed a problem with switch-off-on-case-close.
5) S::LoadLibraryExact now creates a handle into the Loader thread rather
than into the loading client. DLibrary::LoadedL transfers handles and
created dependencies as required. See Note F32 126.2.2
Version 1.02.159
================
(Made by Pete, 21st December 1998)
THIS RELEASE OF E32 REQUIRES F32 125
1) Jonathan
1) Added TLanguage enums { ELangTaiwanChinese, ELangHongKongChinese,
ELangPrcChinese, ELangJapanese, ELangThai }.
2) Morgan
1) Removed old static power functions that are no longer used from
classes P, K, and ImpPsu.
2) Removed TKeyboard::SwitchOn() and TXYInput::SwitchOn(). And for those
variants that required it, upgraded the keyboards and digitisers to be
first class power handlers.
3) Changed KLogicalDeviceDriverUid for Unicode and Narrow builds because
the Ldd interface has changed. This change stops old device drivers
loading on the new kernel.
4) Uniquely identified each architecture of the kernel with a Uid. This
change stops libraries that link to the kernel from loading on the
wrong architecture.
3) MarkD
1) Performed the PC Card reorganisation for MISA.
2) Fixed a problem in KEISA\KE_INI where the requested video chunk size wasn't
rounded to page size.
3) Added a serial driver for Brutus using serial ports 1 (VISABA\VI_COM1.CPP)
and 3 (VISABA\VI_COM2.CPP).
4) Alastair
1) Fixed ER5 defect EDN381842 "WINS 'large' fascia problem under Win95/98".
If not running under Windows_NT SetupEmulatorPaths() function in upwins\up_path.cpp
takes account of the fact that Win32 GetModuleFileName() will report a full path
rather than a virtual path if the Emulator is running on a subst'ed drive from a
DOS prompt.
5) Petteri
1) Changes to VARMCL variant to fully enable the PC Card Controller. All PC Card tests
now pass on this variant.
6) Dennis
1) Merged in more Amazon changes to Windermere port.
2) Modified Plat::ScreenInfo for Windermere to return the address of the screen RAM
bitmap rather than the palette.
3) Fixed a bug in the text window server introduced in 158 which stops pointer drag
from working.
7) Pete
1) Various changes to facilitates a better partitiioning of
functions between EKERN and EPBUS and to allow ROMS to be built without an EPBUS
component. Functions which previously called either TPBusCallBack or
Kern::PBusController() in the indepedant layer have now been moved to the Asic
layer:-
Modification of class DPrimaryMedia into an Indepedent layer class
DPrimaryMediaBase and a Asic layer class DPrimaryMedia.
Modification of class DMediaChangeNotifier into an Indepedent layer class
DMediaChangeNotifierBase and a Asic layer class DPrimaryMedia.
Functions K::PowerUpPeriphBus(), K::BusDevPowerStatus() are now platform
dependent (hence moved to class P). Also creation of the functions P::ForceMediaRemount(),
ImpHal::TotalSupportedBuses() and ImpHal::TotalSupportedDrives().
Version 1.02.158
================
(Made by Pete, 7th December 1998)
1) Morgan
1) Bug fix for MARM and MAWD Emergency power down. (Screen not powered up
after emergency power down). Effects KEAWD\KE_POWER.CPP and
KAEIG\KA_POWER.CPP
2) Pointer-switch-on now behaves as it did in E32(156).
3) Added MISA power model.
2) Pete
1) Split out the PC Card Controller from the kernel into a new
component - EPBUS.DLL. The independant layer code, previously in \KSRC,
files KS_PCCD.CPP and KS_PSOCK.CPP has been moved into \PSRC.
The architecture layer code files have been renamed from K?_PCCD.CPP
to P?_PCCD.CPP (e.g. \KAEIG\KA_PCCD.CPP renamed PA_PCCD.CPP).
As far as the interface with the kernel is conserned, EPBUS.DLL
is now a 'generic' Peripheral Bus Controller rather than specifically a
PC Card Controller. Machines which have a MultiMedia card interface or
a USB interface rather than a PC Card interface will have a Peripheral
Bus Controller supplying services for these interfaces instead. This has
involved quite extensive modifications to the classes which previously
implemented the PC Card media change (DMediaChange) and supply voltage
(TPcCardVcc) since large parts of these implementations are common for
any Peripheral Bus Controller.
The classes associated with the 'generic' Peripheral Bus Controller
are defined in P32STD.H. Of these functions, the code for those asociated with
media change and supply voltage classes is in PS_PSU.CPP and the code for the
Controller interface itself is in PS_PBUS.CPP. The independant layer code for
the PC Card Controller implementation in now in PS_PCCD.CPP and PS_PSOCK.CPP
(defined in P32PCCD.H).
The variant layer code for the Peripheral Bus Controller is still supplied
by the variant DLL. However, the bulk of the PC Card Controller functions have
been removed from the main Custom class and moved to a TPcCardControllerInterface
class (defined in V32PCCD.H). The custom now has a single function:-
TAny* Custom::CreatePeriphBusControllerInterface()
which returns a pointer to this class. This will allow variant layer code for other
types of Peripheral Bus Controller to be supplied by the variant DLL without bloating
the basic Custom class with these functions.
Removed the majority of the exported functions of the class UserPcCardController
(all apart from PwrDown() and NotifyChange()) from EUSER.DLL. Also, constructors for the
classes TPccdChnk, TPccdConfigInfo, TPccdRegionInfo and TPccdType. The DEF file entries for
these functions have been replaced with NotSupported entries.
Similarly, fixed up the MARM/WINS EKERN DEF files to replace all the entries for
exported PC Card Controller functions with NotSupported entries.
[Note: No Pc Card reorganisation for MISA.]
2) The class TPccdCallback has become TPBusCallBack. A single callback can now be
registed for mutiple events, with the event now specified by a mask rather than an enum.
This has simplified the implemenation of the classes DPrimaryMedia and DMediaChangeNotifier.
3) Modified the variant function PcCardMemPhysicalAddress() to take an extra
parameter - 'TPccdMemType'. Prior to this, the variant just returned
the physical address per socket, with the kernel adding an offset
dependant on the memory type. Unfortunatley, the PS7111 has a
different PC Card memory offset scheme to that used in the PS7110.
Hence the need for it to be calculated in the variant (since 7111 and
7110 share the same kernel).
Version 1.02.157
================
(Made by Dennis, 1st December 1998)
NOTE: Must be used with F32 version.
No ISA or Windermere binaries.
Outstanding problem with machine-code serial PDDs (non-machine code
version has been released) and with Windermere power-off.
Bldmake-generated batch files are no longer released as source so
bldmake <all> must be run to create the batch files before any building
can be done.
1) Morgan
1) Added uid-type-safety overloads to RLibrary::Load() and
RProcess::Create() to only load Dlls and Exes that match
the supplied Uids.
eg
lib.Load(_L("\\system\\plugins\\PLUGIN.DLL");
should change to
lib.Load(_L("\\system\plugins\\PLUGIN.DLL"),
TUidType(KNullUid, KPluginUid, KNullUid);
where KPluginUid is either KPluginUid8 or KPluginUid16.
2) SARMBE-RIP
3) Added a new power management framework in INC\K32POWER.H. Here is a
quick overview:
A DPowerHandler performs power related functions previously resident
in DLogicalChannel, and also provides mechanisms for communicating
with the machine's power model. A DPowerModel, (DEigerPowerModel on
the Series5, DWinsPowerModel on WINS), logs all DPowerHandlers in
the system and their power requirements. The power model controls
power up and power down behaviour of all shared power units. This
allows it to dictate the machine's power management policy. (See
document POWER001 in the Base database for more grusome details).
These changes break binary compatability for DLogicalChannels, and
existing device drivers that require power management.
* Here is some guidance on how to update existing
DLogicalChannels to use E32(157):
// 1. given an old Ldd "Tomfoolery":
class DTomfooleryLdd : public DLogicalChannel
{
public:
~DTomfooleryLdd();
[...]
// override DLogicalChannel pure virtual functions
virtual void DoPowerUp();
virtual void DPowerDown();
virtual void DoEmergencyPowerDown();
}
// 2. modify the class declaration to insert a power handler
class DTomfooleryPowerHandler;
class DTomfooleryLdd : public DLogicalChannel
{
public:
~DTomfooleryLdd();
[...]
// these power functions no longer need to be virtual
// but you may wish to keep them virtual to maintain
// Ldd-Pdd compatability.
virtual void DoPowerUp();
virtual void DoPowerDown();
virtual void DoEmergencyPowerDown();
public:
// add power handling to this channel
DTomfooleryPowerHandler *iPowerHandler;
}
// 3. add a new power handler to the TOMFOOL.CPP file
class DTomfooleryPowerHandler : public DPowerHandler
{
public:
DTomfooleryPowerHandler(DTomfooleryLdd *aLdd) : iLdd(aLdd) {}
virtual TInt DoPowerOn() { return iLdd->DoPowerUp; }
virtual void DoPowerStandby() { iLdd->DoPowerDown(); }
virtual void DoPowerRestart() { iLdd->DoPowerDown(); }
virtual void DoPowerEmergencyStandby() { iLdd->DoEmergencyStandby(); }
public:
DTomfooleryLdd *aLdd;
}
// 4. change DTomfooleryLdd::DoCreateL and destructor
void DTomfooleryLdd::DoCreateL(...)
{
[...]
iPowerHandler=new (ELeave) DTomfooleryPowerHandler(this);
// register the power handler so we get power events
User::LeaveIfError(Power::AddPowerHandler(iPowerHandler));
[...]
// ask the PowerManager to power us up
iPowerHandler->PowerOn();
}
DTomfooleryLdd::~DTomfooleryLdd()
{
[...]
// ask the PowerManager to power us down
iPowerHandler->PowerStandby();
// remove the power handler from the system
Power::RemovePowerHandler(iPowerHandler);
delete iPowerHandler;
}
// 5. Finally, redirect calls to DLogicalChannel::PowerGood()
// and SetPowerConsumption() through the new iPowerHandler and
// remove all references of RegisterEmergencyPowerDownHandlerL()
It should also be noted that DLogicalChannel::PowerOn() and
DLogicalChannel::PowerDown() are no longer called called during
S::CreateLogicalChannel() and DLogicalChannel::Close().
4) Moved WINS, MAWD and MARM over to the new power models. Changed
DPcCardCntrl, and DLddSound to use the new facilities.
Also Altered DComm, DChannelComm, and DEigerComm.
[Note: Models not added for MMAD, MISA.]
5) Removed duplicate implementations of P::PowerOff, P::PowerOn,
P::Standby(), and P::CheckSupplies in WINS.
2) Jo
1) Fixed EPOC software problem SW1-266 "TLocale isn't updated in
WINC/WINS when the time zone is changed"
Added a line to KPWINS\KP_INI to update locale data on EStartupCold
when the time zone on the PC is changed.
3) Jane
1) Split kearm directory into kcarm for cpu only code and kaeig for
asic code.
Made the kcarm code generic for any arm processor, so that all arm
based ports can eventually share it.
Added a set of __CPU_ #defines for "cpu properties" such as whether
cache is write-back or write-through, whether there is a write
buffer, and so forth. Used these to make the kcarm directory
generic.
These properties are set up in u32std.h from the build #define.
Moved the MAD port to the new scheme - it shares the kcarm directory
and has its own asic dependent directory, kamad.
The MARM and MAD ports have new .MMP files for ekern (ekernx),
ekdata (ekdatx) and ke_exe (kc_exe).
I am particularly pleased with the new TMadPanic - it made it all
worthwhile...
4) Alastair
1) Changed PP::TheMachineName to "Epoc". Take note SDK people, this
means the default .INI file loaded from the emulator's data
directory will be EPOC.INI rather than SYSTEM.INI. I've also
removed the facility to specify the fascia bitmap within the
<machine>.ini file - instead the emulator will expect the fascia
bitmap to have the same base name as it's corresponding ini file -
so if the emulator is invoked with the -Mgeofox1 switch it will try
to load geofox1.bmp. By default the emulator will try to load
epoc.bmp. I've updated E32's SWINS release component accordingly.
2) Updated EKERN.MMP and EUSER.MMP to take advantage of MAKMAKE's new
FIRSTOBJECT keyword (E32TOOLP 097). Merged Jane's new EKERNX.MMP
into EKERN.MMP, and old KE_EXE.MMP into Jane's new KC_EXE.MMP
following these changes.
3) Exporting the following functions from ekern under WINS/WINC by
ordinal rather than name
EXPORTS E32KernelDispatchAddress @279 NONAME
EXPORTS _E32Initialise @280 NONAME
EXPORTS _E32DeInitialise @281 NONAME
EXPORTS _E32ExitProcess @282 NONAME
Euser.dll has been changed to look up these functions by ordinal.
The latter 3 functions were previously only exported under WINC, and
do nothing and are not called under WINS. The hack in MAKMAKE to
handle the linking of these functions by ordinal has been removed
(E32TOOLP O97).
4) Removed Plat::EnterCS() and Plat::LeaveCS() from ESDRV.CPP and
ECDRV.CPP
- these fixes should no longer be required to avoid deadlock since a
generic fix has been applied to E32 version 155.
5) Added 2 new exports to EUSER.DLL in E32WINS.H
IMPORT_C void SetEmulatorColorDepth(TUint& aDepths);
IMPORT_C void EmulatorColorDepth(TUint& aDepths);
SetEmulatorColorDepth() is called by EKERN.DLL which will set colour
depths supported by the emulator according to the specification of
the ColorDepth keyword in the System.ini file. Syntax is
ColorDepth {Gray2} {Gray4} {Gray16} {Color16} {Color256}
{Color4K} {Color16M}
If the ColorDepth keyword is not specified supported colour depths
will default to Gray2,Gray4 and Gray16 for backward compatibility.
Users of EmulatorColorDepth() will need to pass a bitmap reference
to the function which will be set based on the following constants
defined in E32WINS.H
const TUint KEmulGray2= 0x00000001;
const TUint KEmulGray4= 0x00000002;
const TUint KEmulGray16= 0x00000004;
const TUint KEmulGray256= 0x00000008;
const TUint KEmulColor16= 0x00000010;
const TUint KEmulColor256= 0x00000020;
const TUint KEmulColor4K= 0x00000040;
const TUint KEmulColor64K= 0x00000080;
const TUint KEmulColor16M= 0x00000100;
6) Changed RThread::Panic() so that in WINS DEBUG builds it calls a new
function, ThreadPanicBreakpoint2, in upwins\up_debug.cpp, with
information about the thread being panicked and also the name of the
killing thread. This fixes Epoc S/W problem 356 "The __DEBUGGER
macro that catches panics should be un-commented out." To get the
Windows ID of the panicking thread in RThread::Panic() I changed the
code which keeps a list of Epoc threads in EUSER.DLL so that it
contains the Epoc thread ID as well as the Windows one and added a
function to upwins\up_thrd.cpp, TUint32 WinsEpocThreadWinID(TUint
aEpocID), which returns the Windows ID corresponding to the Epoc ID
passed in as a parameter.
7) Split header inc\e32wins.h into 2 headers, e32wins.h and u32wins.h.
U32wins.h contains euser functions that should not need to be used
by any component except E32.
8) Removed all the logical and physical device driver deffiles from
\E32\INC, since makmake always ensures the right function is
exported at ordinal one for LDD and PDD targettypes.
9) Changed the Emulator's path scheme. Now, if a directory called
'Data\' is found in the same directory as the executable which
started the Emulator, the Emulator's data directory will be
considered to be this directory and expected to contain .INI files
and any corresponding bitmaps. Also, directories 'C\' and 'Z\' in
the executable's directory will be mapped to the emulated C: and Z:
drives. If a 'Data\' directory is not found in the executable's
directory, the old scheme will be assumed where the Emulator's data
directory is '\Epoc32\Data\' and the emulated C: drive is mapped to
'Epoc32\WINS\C\'.
10) Fixed Epoc S/W problem 466
"Plat: 46 fault when running EXEs from a different directory".
The emulator now looks in the directory containing the emulated Z
directory for filenames specified without a drive, rather than in
the directory containing the executable that started up the
emulator; so if Z is mapped to \Epoc32\Release\WINS\DEB\Z\, the
emulator will look in \Epoc32\Release\WINS\DEB\ for these files.
Note that mappings for emulated C and Z drives will be overwritten
if specified in the environment, but can safely be set in the
EPOC.INI file using the _EPOC_DRIVE_? keyword. Any attempted
mapping for the Z drive which does not specify a directory ending in
\Z or \Z\ will fail.
11) Removed references to all bldmake-generated batch files from LI.PRJ
files containing them, and updated MNT.BAT so that directories \BWINC,
\BVC4 and \BVC4WINC are not archived (they contain nothing but
bldmake-generated files anyway). This means that to build E32 from
source bldmake must always be called first to generate the batch files,
and ensures these batch files are more likely to be up-to-date.
5) Jonathan
1) Retired KEARM directory following Jane's changes. The MAWD and MISA
builds depended on some files in KEARM, so these files were copied:
KEISA: ke_edbg.cpp, ke_edbg.h, ke_dma.cpp
KEAWD: ke_edbg.cpp, ke_edbg.h, ke_dma.cpp,
ke_exc.cpp, ke_thrd.cpp,
ke_exe.cpp, ke_kdata.cpp
2) Updated MNT.BAT to reflect all of the above directory changes.
3) Hacked a workaround to MSVC++ 5.0 (sp3) assembler bug, where MSVC
incorrectly fixes up conditional jumps when the destination is a C++
function. Files affected: upwins\up_realx.cpp, upwins\up_i64.cpp.
6) Dennis
1) Fixed bug in serial comms driver relating to zero-length reads. If
the receive buffer was empty when a zero-length read was requested,
the driver would enter an inconsistent state and the request would
not be completed unless a terminating character was specified.
7) Pete
1) Added the class RBusDevCom which is intended as a replacement
for RDevCom (although the latter is still supported). This new class
allows the support of serial devices such as PC Card modems which
require the asynchronous power up of the card. The changes included
in E32-120 allowed these types of cards to be initially powered up
just before a channel was opened on the device. They didn't however
support the repowering of an open channel (which again needs to be
asynchronous) after the machine has been turned off. The RBusDevCom
now provides the means to support for this scenario. If a channel is
opened on a serial device which requires asynchronous powering then
all DoControl() and DoRequest() calls are preceded by a fast exec
call to check whether the device needs repowering. (Channels open on
standard serial devices don't suffer the penatly of this
exec. call).
Added the class RBusLogicalChannel (RBusDevCom is derived from
this class) which is intended as a replacement for RLogicalChannel -
to be used for devices which may need to be asynchronously powered
either before opening or while the channel is use. RLogicalChannel
would continue to be the choice for classes of devices which don't
require this behaviour.
Modifications to the TLocalDrive class. This now makes use of the
MBusDev class - created as part of the implementation of the
RBusLogicalChannel class.
Fixed a problem with the TLocalDrive class CheckMount() function
so that it can't lock the file system doing continuous re-mounts
when a CF card is inserted that never asserts its RDY signal.
2) Added a member 'iHiddenSectors' to TLocalDriveCaps
to report the number of sectors on a media device reserved before
the start of the first partition.
3) Added a new version of the
DPcCardCntrl::RegisterEvent() function taking an extra parameter
'TUint aFlag'. This allows the better support of PC cards which use
level mode interrupt requests rather than pulse mode. The flag is
set when level mode is required meaning the PC Card Controller can
avoid failing to clear the interrupt in the PC Card Controller
hardware.
4) Merged various changes to the MAWD architecture layer, the MAWD
B1 variant layer and the MARM P2 variant layer including a new SPI
implementation for MAWD, support for ETNA Rev3 etc.
Added a function Plat::WaitAtLeastAMicroSecond() for use by the
ATA media driver.
Version 1.02.156
================
(Made by Jonathan, 27th October 1998)
N.B. WINS DEB/UDEB will only work with F32 122 OR LATER.
1) Dennis
1) Reintroduced debug/release interoperability for WINS. Removed
CBase::iName and SObjectIxArray::iPadding. Deleted all debug DEF
files.
2) Merged in Andrew Thoelke's E32 proposals:
i) SW1-77 Compiler-generated constant descriptors.
ii) SW1-14 C++ range-checking template wrapper for fixed arrays.
iii) SW1-87 CleanupClosePushL and related cleanup-stack things.
3) Globally disabled warning about not inlining functions in MSVC++ 5.0.
2) Jonathan
1) Fixed version bug in mnt getbld.
2) Fixed pvcs paramater error for bsarm and bsarmbe dirs in mnt *lock.
3) Alastair
1) Added the following Unicode Uid values
KLogicalDeviceDriverUidValue 0x100039cf
KPhysicalDeviceDriverUidValue 0x100039d0
KKernelUidValue 0x100039e2
KUserDllUidValue 0x100039e5
KLocaleDllUidValue 0x100039e6
KConsoleDllUidValue 0x100039e7
KDisplayDllUidValue 0x100039eb
KCustomDllUidValue 0x100039e8
KKeyboardDllUidValue 0x100039e9
KKeyboardDataUidValue 0x100039e0
KKeyboardTranUidValue 0x100039e1
KXYInputDllUidValue 0x100039ea
N.B. some of these values are defined in the file E32UID.IBY (from
\e32\kbarm\,\e32\kbisa\, etc). If this file is to be used in creating
UNICODE roms then the preprocessing stage prior to rombuilding should
define the _UNICODE macro.
2) Updated .MMP files in accordance with the UNICODE plan.
3) Changed MNT.BAT to get E32TOOLP version 096.
Version 1.02.155
================
(Made by Morgan, 20th October 1998)
NB: REQUIRES F32 VERSION 121 OR ABOVE, WSERV VERSION 100 OR ABOVE
0) Jonathan
1) Added Distribution lines to the LI.PRJ files in all subdirectories to
identify licensee-specific source.
1) Graham Asher, 13/10/98
These changes affect the Unicode builds only. They make it possible to use
several different sets of collation rules in the same locale, which is
needed for East Asian locales; and they make it easier to write collation
rules for these and other locales.
\inc\collate.h
introduced TCollationRepertoire - stores a series of rule sets so that one
can choose, say, between sorting on stroke count and radical, or JIS code,
without changing locale. added new collation operators to make it easier
to write complex collation rules reorganised TCollate constructors to make
them easier for Mem functions to call
\inc\e32des16.h
added new TDesC16::CompareC overloads to allow selection of rule set
\inc\e32panic.h
added EBadCollationRulesIndex panic number
\inc\e32std,h
added Mem functions to enumerate collation rule sets and select them when
comparing; these are new CompareC overloads
\inc\u32std.h
changed LCharSet to include a collation repertoire (instead of just a ptr
to the rules) and a collation attribute repertoire
(TUnicodeAttributeRepertoire) for storing locale-specific character
attribute tables like radical and stroke count
\inc\unicode.h
added the new structures used by TCollationRepertoire, and added
TUnicodeAttributeRepertoire and its constituents; added
TUnicode::GetAttribute, so that collation can use locale-specific
attributes, and abolished TUnicode::TranslateFromUnicode and
TUnicode::TranslateToUnicode
\lsrc\ls_unic.cpp
now contains collation repertoire ptr, not rules ptr, and an attribute
repertoire ptr for any attributes supported by the locale
\ucdt\uc_des16.cpp
implementation of new TDesC16::CompareC overloads
\ucdt\uc_exec.cpp
TChar::TranslateFromUnicode and TChar::TranslateToUnicode now do nothing;
have not abolished them like the TUnicode functions of the same names
because of binary compatibility
\ucdt\uc_func.cpp
added new Mem functions to enumerate and retrieve collation rules; and
implemented new Mem::CompareC overloads
\unicode\collate.cpp
reorganised constructor arguments; implemented new operators including
those that retrieve locale-specific attributes; increased subkey size to
16 bits
\unicode\unicode.cpp
abolished TUnicode::TranslateFromUnicode and TUnicode::TranslateToUnicode
2) Dennis
1) Machine coded most of the TEiger functions because things like keyboard
scanning were taking a ridiculously long time (nearly 500us).
2) Fixed bug SW1-256 - TInt64::TInt64(TReal) won't compile under VC5.
3) Fixed bug SW1-738 - Scheduler bug may leave processes unprotected.
4) Added extra function calls to serial comms PDD VA_COM1.CPP to cope
with new chained interrupts.
3) Alastair
1) Changed Emulator title bar to read "EPOC Emulator".
2) Changed \e32\dpwins\d_medint.cpp and \e32\kpwins\kp_pccd.cpp
to use Win32 function GetTempPath() to get the system
temporary path rather than manually checking the "temp" environmental
variable. Fixes Epoc Software problem SW1-112.
3) Changed WINS F11 key case closed behaviour so that "case
closed" is added to the WINS title bar rather than the case
bitmap being displayed.
4) Removed possibility of specifying the case bitmap within
WINS's system.ini file, and all references to the case bitmap.
5) Disabled Emulator Window maximise button since the button
served no purpose.
6) Added new header \E32\INC\E32WINS.H containing the following
WINS-specific functions to be exported from EUSER.DLL
IMPORT_C TInt SetupEmulatorPaths();
IMPORT_C TPtrC EmulatorPath();
IMPORT_C TPtrC EmulatorDataPath();
IMPORT_C TInt SetupEmulatedDrive(const TChar aDrive,const TDesC& aPath);
IMPORT_C TInt MapEmulatedFileName(TDes& aBuffer,const TDesC& aFileName);
These functions are defined in new file
\E32\UPWINS\UP_PATH.CPP, and replace various drive-mapping
activities in different places in E32 and F32. They also
incorporate changes to make the Emulator runnable from
anywhere. If the Emulator is running from a traditional
\Epoc32\Release\WINS\<build>\ directory, then emulated C: and Z:
drives and the Emulator data directory will be as before;
otherwise, emulated C: and Z: will be subdirectories 'C' and 'Z'
of the Emulator directory, and the Emulator data directory
will be the 'data' subdirectory of the Emulator directory.
7) Fixed Epoc Software problem SW1-153 "Allow applications to simulate
running from C: or D: on WINS". F32 has been changed so that
an Epoc path, rather than a full Win32 path, is passed to
the kernel's DPlatLibrary::DoLoad() function. The path is mapped
to a Win32 path using MapEmulatedFileName() for the Win32 call to
LoadLibrary(), but DPlatLibrary.iFileName is set to the Epoc
path rather than the full Win32 path. It is iFileName that function
RLibrary.FileName() returns. Previously F32 would
pass in the full Win32 path and DPlatLibrary::DoLoad() would
convert it to an Epoc path to set the iFileName value, but for
libraries on the emulated Z drive only.
8) In \E32\KPWINS\KP_GUI.CPP, replaced some old dos function
calls with newer, more UNICODE-friendly, Win32 ones.
9) Added 2 new, case-sensitive, command-line flags.
Use EPOC.EXE -C<emulated C drive> -- (that's 2 dashes) to
specify the emulated C drive.
Use EPOC.EXE -T -- to specify that the system temporary path
should be used as the emulated C drive.
These flags will override the default settings and any _EPOC_DRIVE_C
setting in the environment or in the System.ini file.
10) Removed obselete code defaulting maximum free RAM under WINS from
\E32\KPWINS\KP_HAL.CPP. The default is now applied by
\E32\KPWINS\KP_GUI.CPP.
11) Changes to support international keyboard variants - these changes
will mean that WSERV version 100 (or above) and it's corresponding
changes are required to provide sensible keyboard behaviour.
a) Changed WINS EKERN.DLL so that character codes are passed onto the
Window Server in the 2 high bytes of the TRawEvent iScanCode
member variable.
b) Changed WINS EKTRAN.DLL to translate Epoc scan codes to the
character code provided in the 2 high bytes of the aScanCode
parameter if this code is available.
c) Changed EWSRV.DLL so that the 2 high bytes of the TRawEvent
iScanCode are ignored where appropriate.
d) Changed WINC ECONS.DLL to support international keyboard
input.
e) Removed \E32\KPWINS\KP_KYBD.CPP - this file used to provide
limited international keyboard support - UK/US variants only.
12) Added KConsoleDllUid, 0x100000C5, to \E32\INC\E32UID.H.
13) Made changes to \E32\WSRC\CO_TWIN.CPP to resolve the ECONS.DLL
problem in line with the version of Epoc S/W Proposal SW1-84
revised 27/8/98. Some changes to the Eikon console will be
required for the solution to be fully effective. The changes
don't go quite as far as the proposal - the text console only
attempts to load ECONSEIK.DLL, not ECONS?*.DLL, since the
dll-loading code does not handle wildcards.
14) Changed \E32\KPWINS\KP_GUI.CPP so that under WINS the pointer
name (TMachineInfoV1.iXYInputName) is always either _L("PEN"),
_L("MOUSE") or _L("NONE"). This value can be set via
\Epoc32\Data\System.ini using keyword "PointerType", and
defaults to _L("PEN"). E.G. "PointerType mouse".
15) Changed \E32\KPWINS\KP_GUI.CPP to allow Emulator windows to be
created which are larger than the PC screen.
16) Changed \E32\GROUP\SWINS.REL to include the new symbian fascia.bmp and
friends from R:\SDK\ZIP\SDKMODELS.007.
17) Added new function and an enum to E32WINS.H
IMPORT_C TInt EmulatorFlip(TEmulatorFlip aEmulatorFlip);
enum TEmulatorFlip
{EEmulatorFlipRestore,EEmulatorFlipInvert,EEmulatorFlipLeft,EEmulatorFlipRight};
Calling this function, defined in \E32\UPWINS\UP_GUI.CPP, will change
the size and orientation of the emulator's parent and child windows
and bitmap.
18) Implemented Epoc Proposal SW1-93 "Help for debugging Panics on WINS".
In WINS DEBUG mode, when a thread is panicked, a function in
\E32\UPWINS\UP_DEBUG.CPP will be called which will break into the
debugger and provide comprehensive information about the panic. Source
file UP_DEBUG.CPP will be needed for this to work properly. I've
removed the __DEBUGGER() macro from RThread::Panic() since it should no
longer be required.
20) Added 2 new functions to E32WINS.H - AddToWinsEpocThreadList() and
RemoveFromWinsEpocThreadList(). These enable the kernel to create and
maintain a list of "real" Epoc threads (as opposed to fake WINS
hardware threads) within EUSER.DLL. New function
UpWins::__EpocThread() in UP_STD.H is called by EDLL.OBJ (linked into
every WINS Epoc dll) to check whether the current thread is in this
list, so that EUSER's E32Dll() routine is only called when real Epoc
threads attach to and detach from loaded Epoc dlls. As a result of
this change dlls linked to the new version of EDLL.OBJ will not run
against older versions of EUSER.DLL. All these new functions are
defined in new file \E32\UPWINS\UP_THRD.CPP. This change addresses
Epoc Proposal SW1-19, though I haven't removed the calls to E32Dll()
with parameters EDllProcessAttach and EDllProcessDetach yet since the
window server, and perhaps other components, make use of these.
4) Morgan
1) Added interrupt chaining to TInterrupt. This breaks binary
compatability for this class, but maintains source compatability.
Attempts to Bind the old TInterrupt class with the new kernel will
fail with KErrNotSupported.
Version 1.02.151
================
(Made by Pete, 12 October 1998)
1) Morgan
1) Updated TLinda and KEMAD\KE_PIC.CPP to take the new interrupts
2) Added some kernel access functions so device drivers can
find DPhysicalDevices, DLogicalDevices, DChunks, and DLibraries
3) Added TDma::Fill()
4) Fixed a bug in the ImpDma interface
5) Added hooks for automatic chaining of Dma buffers
2) Pete
1) Re-organisation of the SPI bus / ADC channel
measurement code in MARM and MAWD builds:-
TSpiController is now an abstract class. A
TSpiController derived class is defined and instanciated in each
variant. During initialisation, the kernel calls
TSpiController* Custom::CreateSpiController() to create the
appropriate SPI controller device.
TSpiController now includes the following
pure virtual functions which (hopefully) encompass the variant
specific aspects of this device:-
- void TSpiController::InitialiseSpiDevice();
- void TSpiController::StartAveragedReading();
- void TSpiController::StartOneShotReading();
Created the file VA_SPI.CPP in each MARM/MAWD
variant to implement the above functions (the code for which
has been essentially extracted from the appropriate KE_SPI.CPP
file). Also moved the following SPI related functions out of
VA_HW.CPP into VA_SPI.CPP:-
- TBool Custom::TestBootSequence()
- TInt Custom::BindSpiChannel(const TDesC8& aName)
- TBool Custom::EightChannelAdcFitted().
The TSpiController device no longer relies on
the digitizer driver to drive it to pull off and process
entries from its queue of ADC channels waiting for an ADC reading.
The Controller now has its own 8mS tick to perform
this. The later can be suspended/resumed by the variant using:-
- void TSpiController::Suspend();
- void TSpiController::Resume();
(For PB-PD/P2 MARM and B1 MAWD variants, the
digitizer driver does indeed suspend this operation and
drives processing of pending channels itself so as not to
change the operation of this driver).
2) Re-organisation of the way the PC Card Controller
hardware (e.g. Etna) is implemented for MARM builds to make
use of the fact that the variant DLL can now contain static
data. The h/w chunks are no longer allocated in the
architecture layer (KE_INI.CPP), but are
allocated within the variant as part of the Custom::Init3()
function. As such, the function
Custom::PcCardCntrlPhysicalAddress() has become redundant.
3) The function Hal::ColdStart() is now properly
exported.
3) Petteri
1) Changes to MARM display driver (WD_EIGER.CPP) so to handle
different screen sizes. Previous one assumed 640x240.
2) Changes to bootstrap and MARM variant layer to allocate an
additional h/w chunk for the extra registers in the CL-PS7111 device.
3) Various changes to the Cirrus Logic evaluation board
variant - to bring back as a supported variant.
4) Dennis
1) Put SCREENVARIANT code back into MARM bootstrap.
Version 1.02.150
================
(Made by Alastair, 23rd September 1998)
This release is not intended for ER4, though it could be used as part
of an ER4 SDK.
1) Alastair
1) Changed ECDRV.PDD, ESDRV.PDD and ESOUND.LDD as suggested by replies
to topic "WINS sound and comms cause deadlocks with STDLIB" under
category "Known Epoc Problems" in Notes database
"Symbian Tech Support General", except that the change to
ECDRV.PDD has been modified slightly so that it doesn't break test
T_SERIAL.EXE. The ECDRV.PDD change has been tested with a version of
T_SERIAL.EXE modified to simulate the conditions which
could previously cause deadlock.
These changes address the following bugs/proposals, but do not
represent a permanent solution:
Epoc Software problem SW1 - 176 "WINS sound driver
deadlock in ESTLIB E32Dll() function."
Series5 Software problem SW1 - 503 "ECDRV.PDD can cause
deadlocks in simple test programs".
Epoc proposal SW1 - 19 "Implement true EPOC32 handling of
E32Dll() under WINS".
The change to ESOUND.LDD fixes Epoc Software problem SW1 - 179
"ESOUND.LDD plays silence indefinitely for short sound samples".
Version 1.02.144
================
(Made by Dennis, 7th August 1998)
1) Matthew
1) Added code to MISA platform so that the cpu goes into idle mode when
in the idle thread.
2) Added \e32\keisa\todo.txt - a to-do list for the MISA platform.
2) Dennis
1) Fixed bug in comms device driver D_COMM.CPP which left unwanted DFCs
queued after a power-down. These then attempted to complete requests
twice. Power down now cancels any pending DFCs.
3) Jonathan
1) Removed tests for redundant files from valid command in mnt.bat.
2) Updated build.txt to add dire warnings about checking e32ver.h and
advice about MNT VALIDating releases.
Version 1.02.143
================
(Made by Pete, 20th July 1998)
1) Dennis
1) Fixed SW1-586 incorrect handling of signed zeros.
2) Morgan
1) Updated V32Linda.h to reflect the latest hw
2) Added TDma class and supporting classes Dma, ImpDma
3) Changed MMAD bootstrap to use the same modular scheme as MARM
3) Alastair
1) Fixed Epoc Software problem SW1-107 'WINS RThread::Resume problem on
Win95' by not faulting the platform unless Win32 API function
GetLastError() reports an error as well as ResumeThread().
4) Pete
1) Fixed a problem with ATA media driver such that it sometimes failed
to reduce machine current consumption - having raised it due to a
read or write to the CF card.
2) Fixed a problem with ATA media driver. As part of the exec. call to
read/write/format the card, the driver sends a command to the card,
to read/write the appropriate number of sectors. Each time a sector
is complete, the card generates an interrupt so the driver can
either read the data from the sector or supply the data for the next
sector to be written. There was a problem with the driver such that,
if the first interrupt from the card occurred while still in the
initial exec. call, the interrupt could be prematurely cleared. The
driver then only detects that the sector has been processed when a 2
second time-out occurs on the operation - making the operation
appear very slow. This only seems to have been a problem for Viking
and Panasonic CF cards.
3) Alteration to the ATA media driver to improve speed of transfer,
particularly on reads from the card. Before, the driver queued a DFC
for the completion of each sector read from the card (to write it
back the thread making the request). The media driver's buffer has
now been increased so that this can be filled under interrupt. A DFC
in now only queued when the buffer is full.
Version 1.02.142
================
(Made by Pete, 1st July 1998)
1) Matthew
1) Changed MISA bootstraps to use the same modular scheme as MARM.
2) Added functions to TSa1100 for new hardware registers in revision D.
1) Dennis
1) Added thread write function DThread::WriteNoCheck() which doesn't
perform the strict checking that DThread::Write() does.
2) Changed TLex::Val(TReal*) to use TRealX in its intermediate
calculations in order to increase the precision of the final
result. Added a new function Math::MultPow10X which multiplies a
TRealX argument by an integer power of 10. This is basically a
higher precision version of Math::Pow10.
1) Pete
1) Changed MARM ATA and CROM media driver to use
DThread::WriteNoCheck(). Fixes SW1-482.
Version 1.02.141
================
(Made by Pete, 10th June 1998)
1) Jonathan
1) Removed private assignment operators from TSglQueIterBase and
TDblQueIterBase as per EPOC32 Proposal SW1-53.
2) Made inline RSubSessionBase::SubSessionHandle() public as per EPOC32
Proposal SW1-45.
3) Bumped up the E32 KMediaDriverInterface*VersionNumber.
4) Changed the default WINS memory emulation from 4MB to 64MB as per
EPOC32 Proposal SW1-88.
5) New code page 1252 and Unicode character information tables derived
from release 2.1 of the character database from Unicode Inc.
Fixes EPOC32 Software Problems SW1-42 and also adds:
80 & U+20AC New euro currency symbol
8E LATIN CAPITAL LETTER Z WITH CARON (= U+017D)
9E LATIN SMALL LETTER Z WITH CARON (= U+017E)
U+FFFC OBJECT REPLACEMENT CHARACTER
6) From Graham Asher:
The enumerated type TChar::TCategory in e32std.h, used only in the
Unicode build, has been changed to accommodate the new character
categories in unidata2.txt.
2) Matthew
1) Changed the TSa1100 class - removed SetHalt(), which had been
copied over from TEiger, and renamed IntLevels() to IntsPending()
and IntTypes() to IntLevels() to conform with the terminology in
the SA1100 documentation. Breaks misa kernel-side compatability.
2) Removed lccr followers from MISA, which were working around a bug
in the SA1100.
3) Changed MISA ScreenInfo function to return the address of the
beginning of the palette (rather than the pixel data for 8bpp).
The screen driver will have to change to take account of this.
4) Removed TSa1100 palette functions - the screen driver should write
to memory instead.
5) Removed Cassius-A releasables from the releasables, because we had
the hardware taken from us.
6) Changed Windamere(AWD) and SARMBE architectures to set year to
rombuild year on a cold boot, which I forgot in the last release
(see 3.13 in release 140).
7) Fixed Epoc32 defect SW1-33 ("Problem in Plat::Fault in Unicode
builds") by changing Length() calls to Size() calls.
8) Changed sound ldd to use DThread::Read() and Write() rather than
doing its own thing this fixes S5 defect SW1-231 ("Machine warm
reset when playing sound while spy running").
9) Changed svChangeLocale() function so that it triggers
RChangeNotifiers.
10) Changed keyboard translator dll so that the default library is
closed when not in use.
11) Incremented EPOC comms-driver minor version number (but not WINS
one) and put a check into the pdds so that they will not be used
with early versions of the ldd. Partially fixes Bluebell defect
SW1-5 ("Triple beep reset when turning on the link").
12) Added an explicit call to compress the kernel heap to
S::ChunkCompressAll(). This fixes the E32 bit of Series-5 defect
SW1-356 ("Large uncompressible heaps in system components").
13) Fixed bug in sound ldd which caused sine waves to not be
cancelled in WINS on PCs which did not support aLaw.
3) Dennis
1) Fixed bug in ARM710.S in EIGER bootstrap code. In function
EigerSetCSnWidth register R1 is accidentally overwritten, causing
the ROM to be set up incorrectly if its bus width is not 32 bits.
2) Implemented EPOC32 proposal SW1-69. User::StartThread modified to do
the DLL attach and detach in separate functions, so that the 1K of
stack used in these functions can be reused during actual running of
the thread.
3) Fixed problem SW1-51 - renamed TPointerArray<T> to RPointerArray<T>
and TSimpleArray<T> to RArray<T>. Replaced TArray(U)Int with
RArray<T(U)Int>. Replaced the destructor with a Close() function to
do memory deallocation. Frozen DEF files modified so that renamed
functions are at same ordinal as before, with Close() functions at
the same ordinals as the destructors were.
4) Fixed problem SW1-47 - modified code in DebugFunction ProfileResult
to get the tick period from Hal::TickPeriod instead of hardcoding it
to 15625us.
5) Fixed problem SW1-622 - modified heap code so that all free cells
are at least 16 bytes in debug mode, since this is the minimum
allocated cell size.
6) Modified RHeap::ReAlloc() so that the nestingLevel field in debug
mode is preserved. This prevents test programs failing a kernel
heap check due to one of the kernel's arrays being reallocated
during the test.
7) Modified handlers for vectors 0x00 and 0x14 (reset and reserved) to
fault with a simulated exception EExcInvalidVector rather than
looping forever. iCodeAddress=0x00 or 0x14, iDataAddress=value of
lr on jumping to 0x00 or 0x14.
8) Added functions RChunk::IsReadable() and RChunk::IsWritable() so
that user code can determine whether or not a chunk is mapped into
its process address space.
9) Fixed problem SW1-370 (Math::Mod is not sufficiently
accurate). Changed the algorithm from x%y=x-y*INT(x/y) to a
bit-by-bit shift and subtract algorithm. Added operator%,
operator%=, Mod() and ModEq() functions to TRealX class to implement
the new algorithm.
4) Petteri
1) Fixed a bug in Math::Round(). (SW1-402)
2) Fixed a couple of bugs in the text window server.
3) Changed Ekern.mmp as required by changes in Makmake.
5) Alastair
1) Changed mnt.bat so that mnt getsrc no longer attempts to make
the Epoc work directories.
2) Changed WinCOutput::Write(const TDesC &aDes) so that WINC
programs can write output to STDOUT for redirection. This change
applies to ascii builds only.
3) Changed the kernel so that the Windows Alt-F4 keyboard
shortcut for closing applications works for WINS.
4) Changed #define in kpwins\kp_chunk.cpp so that the code which
checks that requests for more memory won't cause the emulated
memory allocation limit to be exceeded applies for WINS only, not
WINC. This won't change WINC behaviour because the emulated
memory limit under WINC was always zero, which meant that the
check wasn't applied anyway.
5) Changed kpwins\kp_gui.cpp in line with Epoc Proposal SW1-21,
so that emulated drive assignment is possible from
\Epoc32\Data\System.ini.
Syntax is
_EPOC_DRIVE_<letter> <path>
6) Jo
1) Fixed Series 5 software problem SW1-440 ("PDD returns different errors
in WINS and ARM"). Both WINS and ARM now return KErrNotSupported.
2) Fixed Series 5 software problem SW1-943 ("XXX_CAST macros in E32DEF.H
are written incorrectly")
7) Pete
1) Implemented asynchronous rather than synchronous system
for read,write and format operations on local media devices.
This affects the TLocDrv and DMediaDriver classes.
2) Changed API on for local media devices so that for any given
operation (eg read,write,format,reduce size) the position on the
device is specified as a TInt64 rather than TInt. This will allow
very large media devcies to be supported. This affects the TLocDrv,
DMedia and DMediaDriver classes.
Taking changes 1 & 2 for DMediaDriver, the functions
TInt DMediaDriver::ReduceSize(TInt aPos,TInt aLength);
TInt DMediaDriver::Read(TInt aPos,TInt &aLength,const TAny* aTrg,TInt aHandle,TInt anOffset);
TInt DMediaDriver::Write(TInt aPos,TInt &aLength,const TAny* aSrc,TInt aHandle,TInt anOffset);
TInt DMediaDriver::Format(TInt aPos,TInt &aLen);
become:-
TInt DMediaDriver::ReduceSize(TInt64 &aPos,TInt aLength);
void DMediaDriver::Read(TInt64 &aPos,TInt *aLength,TLocalDriveMessageData &aTrg,DThread *aThread,TRequestStatus *aStatus);
void DMediaDriver::Write(TInt64 &aPos,TInt *aLength,TLocalDriveMessageData &aSrc,DThread *aThread,TRequestStatus *aStatus);
void DMediaDriver::Format(TInt64 &aPos,TInt *aLength,DThread *aThread,TRequestStatus *aStatus);
3) Withered the UserPcCardCntrl class. Now all functions are 'not supported'
apart from:-
void UserPcCardCntrl::PwrDown(TSocket aSocket);
TInt UserPcCardCntrl::NotifyChange(TSocket aSocket,TRequestStatus *aReqStat);
which are implemented using the corresponding UserSvr functions
described below.
The media device functions previously provided by UserPcCardCntrl
are now provided by D_DRVIF.LDD in E32UTILS.
The PC Card controller functions previously provided by UserPcCardCntrl
are now provided by D_PCCDIF.LDD in E32UTILS.
4) Added the following UserSvr local media functions:
void UserSvr::ForceRemountMedia(TMediaDevice aDevice);
Causes remount on next access to specifed device (ie
media change simulation).
TInt UserSvr::MediaChangeNotify(TMediaDevice aDevice,TRequestStatus *aReqStat);
Request notification of power of powerup and media change
events on the specified media device.
5) In MARM build the function:-
TInt DArmPlatPcCardSocket::EventCallBackEnable(TPccdEvent anEvent)
no longer performs a clear of any pending events before enabling an
event callback type. Also, it now performs an additional check that
a power down of a PC Card hasn't occured (ie Kern::PowerGood()) before
enabling PC Card IREQ events.
Version 1.02.140
================
(Made by Morgan, 14th May 1998)
1) Graham
1) Added P3 variant to the rom building capabilities in KBARM
2) Dennis
1) Added support for multiple kernels/variants in the same ROM.
This requires F32 096 and ROMBUILD version 093.
2) Added TSimpleArray<>, TPointerArray<>, TArrayInt simple array classes.
3) Changed occurrences of CArray* in the kernel to TSimpleArray<>.
4) Rearranged ARM boot code into a form which is easier to adapt to other
hardware and which facilitates multiple-boot ROMs.
5) EKERN.EXE no longer links to the variant DLL. Instead, the variant DLL
is found by searching a list of possible variants.
6) Added executive call UserSvr::RomRootDirectoryAddress() to enable F32 to
obtain the address of the ROM file system root directory. This address is
now determined at boot time from a list of possible root directories, one
for each variant which the ROM supports.
7) Added code to enable profiling of threads (measures CPU time used by each
thread in the system). To use this, rebuild the MARM REL version with the
symbol __PROFILE__ defined at the top of M32STD.H. You will also need test
program T_PROF.EXE and device driver D_PROF.LDD from E32TEST.
8) Added two new format options %O and %o to Kern::Printf. %o prints the short
name of a CObject and %O prints the full name. Also modified Kern::Printf
to print (null) if a NULL pointer is passed into %S, %O or %o.
9) Modified statements of the form Kern::Printf(_L("%S"),&obj->FullName())
to Kern::Printf(_L("%O"),obj).
10) Added a generic algorithm for determining the size and configuration of
DRAM devices to the ARM bootstrap code.
11) Modified ARM/ISA/X86 bootstrap to map in the PageTableInfo array at
0x41080000. The fixed offset from the page directory simplifies remapping
during a reschedule.
12) Added fields iHomePdes, iPdes and iNumPdes to the definition of DPlatChunk.
These indicate directly which PDEs are used by the chunk and simplify
moving a chunk around. Modified the scheduler to use these fields when
switching processes. Added a function DPlatChunk::SetPdeInfo to set up
these fields.
13) Removed the current consumption setting code from the scheduler. Added
a function K::TotalCurrentConsumptionInMilliAmps() which calculates the
machine current by adding K::TotalCurrentMilliAmps to the machine current,
determined by simply looking to see if the null thread is running.
14) Modified DPlatProcess::LookupChunk to do a binary search on the chunk list
instead of a straight entry-by-entry search.
15) Fixed a bug in DPlatChunk::ReallocateHomeAddress which would result in a
chunk being left without a home address if all linear addresses in the
home section were exhausted.
16) Modified text window server so that it loads EDISP.DLL from Z:\SYSTEM\LIBS
and invokes ordinal 1 in order to create the screen device driver, rather
than being statically linked to EDISP.DLL. This is necessary for multi-boot
ROMs since EDISP.DLL is hardware dependent.
17) Added WINDERMERE architecture (\E32\KEAWD), Bluebell V1 variant (\E32\VAWDB1),
and dual-boot EIGER/WINDERMERE test ROM (\E32\KBAWD).
This builds and runs on Rack D but is obviously completely untested on
Windermere. There are some outstanding issues with the Windermere port:
i) Standby code may be faulty - problem with restoring state when machine
powers back up.
ii) PC card/CF card code requires modification to use LDRH/STRH 16 bit
instructions rather than relying on EIGER 'mad-mad mode'.
iii) Bootstrap needs modifying to detect Windermere.
iv) SPI controller and LCD controller setup may be incorrect.
3) Matthew
1) Got rid of MARM P1 (banana) variant.
2) Bug fixes to MISA so it can be run in 4bpp and 16bpp modes.
3) Changed misa to use the hardware rtc to keep track of the time, instead of
counting ticks.
Unfortunately the 32MHz crystal is very slow to warm up, so a cold boot is now
much slower than it was because it has to wait for the crystal to stabilise.
4) Changed misa bootstraps to be fractionally more like the marm one.
5) Moved the WINS-specific setting of the daylight-saving mode out of the
independent layer and into KPWINS. Removed the resetting of the
daylight-saving from the change-locale function. These mean that S5
defect SW1-558 ("Remove windows dependency") has been fixed.
6) Fixed bug in DLogicalChannel::Request(), which previously, in WINS,
could have sent a request from a thread which had no right to do a request
on that channel.
7) Integrated Andrew Baldwin's wonderful new WINS sound pdd, which will not
offend your ears. Many thanks to Andrew for this.
8) Modified sound ldd so that it can pass multiple samples to the pdd. Modified
pdds to use this new functionality. This reduces the amount of time spent in
the service routine.
9) Fixed S5 defect SW1-228 ("Dial setup errors") in sound LDD.
10)Incrememented sound driver minor version number, to stop people mixing old
and new pdds/ldds.
11)Put an __DEBUGGER() macro into K::PanicCurrentThread() - previously these
panics were just stopping WINS without giving you a chance to jump in with
a debugger.
12)Added int3's to WINS DEBUG versions Plat::Panic() and Plat::Fault() so they
break into the debugger whatever the state of the JustInTime flag.
13)Changed MISA and MARM cold-boot to read the year from the rom header and set
the time to 10:10 January 1st of that year. Fixes Bluebell defect SW1-134.
14)Made the private function KernelCompressAll() into the public
User::CompressAllHeaps(). This is to allow Shell to trigger heap compression
more easilly (see Bluebell defect SW1-299).
4) Morgan
1) Integrated the MADLinda architecture and build system
2) Bug fix to KESARMBE\KE_PIC.CPP
3) Changed occurences of DisableIrqs and EnableIrqs to DisableIrqsToLevel2 and
RestoreIrqs in SARMBE architecture
4) Added callback hook for the idle loop
5) Added Kern::PhysicalDeviceFromHandle
6) Added an external debugger interface (K32DBG.H). Used it to bolt on an
InfoOutput debugger for MSDEV. On the MARM platforms bolted on a logging
debugger for use by an external JTAG debugger, (like TI's). No debugger
for X86.
5) Jonathan
1) Made Eiger and Windemere text drivers return correct screen size
from CScreenDriverMarm::Init() instead of assuming 80x24.
Removed old #ifdefed-out SetMode() code from Eiger driver.
================
Big version number increment to skip over Liffey release.
================
Version 1.02.128
================
(Made by Jonathan Harris, 8th May 1998)
1) Jonathan
1) P::SetMachineConfiguration(): Don't update the bits of the SuperPage that
belong to the boot code (including the exception info), apart from the
display contrast.
Version 1.02.127
================
(Made by Graham Darnell, 26th March 1998)
1) Dennis
1) Added a new variant function Variant::SetSoundDriverEnabled(TBool) for use
with Snowball in order to allow user code to enable/disable the speaker
using UserHal::SetSoundDriverEnabled().
2) Added some code to Variant::Init3 for P2 variant to enable correct operation
with either a single ROM device, 4Mb on CS0 and 2Mb on CS1, or 4Mb on both.
2) Matthew, Pete and Rob Pym
1) Converted the MISA build from being for a Digital IT board to being for
SA-1100 based hardware. This has an identical user-side API to MARM, so
MARM releasables will run unchanged. To build a rom use the MARM F32.
2) Added variants VISABA for a Digital's "Brutus" board and VISACA for a
Cassius rack.
Note: TO BUILD A TEXT-SHELL ROM FOR BRUTUS YOU WILL NEED THE ESHELL.EXE
FROM F32 096 OR HIGHER. PRIOR TO THIS, THE SHELL TRIES TO CREATE
A CONSOLE WINDOW LARGER THAN THE BRUTUS SCREEN AND CRASHES.
3) Matthew
1) Changed all interrupt-binding and startup-beep internals to use Narrow
descriptors in the Unicode build.
2) Added code to read extra digitiser information in E2 on P1, P2 and PD
variants. Changed the digitiser drivers on P2 and PD machines to use this
extra information, so different digitisers can be used on these machines.
If the new E2 information is invalid due to a new rom has been put into
an old machine, then this is detected due to the x rise-time being zero,
and the driver defaults to the previous good values.
If you wish to program your E2 with values suitable for the standard
digitiser use XYSpread/16=6; X-Rise=1; Y-Rise=1; Pen-down discard=0.
3) Moved TVideoMode enum from d32video.h to e32twin.h, and stopped e32twin.h
including d32video.h, thus fixing SW1-921.
4) Changed sound LDD to make sure that the internal state is implies no
request is pending when a play request is completed. Thanks to Andrew
Baldwin for finding this.
5) Changed some RChangeNotifier internals so that the internal state implies
no request is pending when a request is completed.
4) Graham/Matthew
1) Changed the WINC memory information function so that it doesn't emulate a
machine with 4 megs of ram.
2) Removed some critical-section switching in the WINS thread-startup code.
This fixes a bug which occasionally caused WINC to hang on fast machines
if a thread did an exec call very soon after being resumed for the first
time.
3) Removed another 'dance of the semaphores' during WINS thread
startup. This seemed to prevent a resumer proceeding
until all resumee dll entry points have been called. Since
there seems to be no reason for this and since this was
causing a problem when threads were resumed inside
dll entry code, there seemed no point in keeping it.
However, this might be something to watch out for.
3) On WINS/WINC, the call to tick the tick-queue is now sandwiched between a
Plat::EnterCS() and a Plat::LeaveCS(). This will make these platforms far
more robust, but might break work-arounds that may or may not exist in
user code.
5) Morgan
1) Fixed Bluebell defect SW1-43.
2) Added Dll::FreeData(). This should be called in the EProcessDetatch
of those Dlls sporting static data.
6) Graham
1) Added comms and sound device drivers to the WINC
releasables.
Version 1.02.126
================
(Made by Jonathan, 26th February 1998)
1) Matthew
1) Tweaked MMP files in preparation for misa platform.
2) Added lots of useful constants to k32std.h - these will be used in the
misa platform.
3) Removed the obsolete DriveName and PccdSlotHame() functions from the
variant layers.
2) Graham
1) Added K32KEYS, K32COMM, and K32SND header files to INCK release
2) Split off the S1 variant into its own project
3) Removed S1 variant from E32 project
4) Fixed a bug in the MARM architecture that assumed that an eight channel
ADC was fitted when powering up.
3) Dennis
1) Modified RHeap definition so that it is now derived from RHeapBase,
which contains all the non-debug data members. This is to force GCC
to put the vptr in the same place that it always was in release builds.
This is to enable test code to run on a real machine with EUSER.DLL
replaced from RAM.
2) Changed UP_CON.CPP in UPMARM, UPMX86 and UPWINS to only include <e32def.h>
instead of up_std.h. Previously, modifying k32std.h would cause up_con.cpp
to be rebuilt but not the real econs.dll.
4) Alastair
1) Added edll.pdb and eexe.pdb to ewinsdb.rel because following the move
to using makmake edll.obj and eexe.obj no longer contain their own
debugging information.
2) Updated .MMP files previously using the START MARM .. END block keyword
DLLNAME so that they use the new LINKAS keyword instead. Updated MNT.BAT
to get e32tools 091 and e32toolp 091.
5) Jonathan
1) Added new SwitchOn() digitizer driver call. Needed by the Snowball
variant to reinit the digitizer after power-off.
Version 1.02.125
================
(Made by Graham, 16th February 1998)
1) Morgan
1) Allowed static data for Rom Ldds/Pdds. These require the 'fixed'
keyword in the obey file.
2) Graham
1) Removed debug/release interoperability from WINS/WINC.
Version 1.02.124
================
(Made by Jonathan, 10th February 1998)
1) Jonathan
1) Incremented KMediaDriverInterfaceMinorVersionNumber because the
media interface has changed (actually, it changed back in 120).
2) Added new TPasswordToken member to TMachineConfiguration on WINS,
updated on setting the password or machine configuration.
3) For internal consistency, WINS now actually limits the amount of
available memory on the 'machine' to the parameter set in
system.ini, and defaults to 3M if no value is set. Previously WINS
merely _reported_ 3M if no default was set, but allowed you to
allocate past 3M. This broke test code.
4) Fixed generation of event on Off keypress on Snowball 1.
5) Incorporated Pete's change: Snowball 1 variant no longer waits for
400ms for SanDisk to come out of reset. Instead, the media driver
polls the SanDisk on first use.
2) Alastair
1) Updated e32base.h and ub_sec.cpp with Andrew Thoelke's changes to
implement EPOC32 proposal PR-0077, that a new function be provided
to return the maximum possible length that an encrypted piece of
data could become under the encryption scheme in use given the
initial length of the data.
2) Changed mnt getrel so that it doesn't attempt to get the non-existent
.PDB files for release builds.
3) Basher
1) Changed K::EmergencyPowerDown() and K::EmergencyPowerDownDfcFn()
functions (ks_power.cpp).
2) Changed Variant::EmergencyStandby() - on the folowing varients
varmcl, varmpd, varmsa and varmsb.
3) \varms1\va_mati.cpp changed - implementing safe EmergencyPowerDwn
control. EmergencyCallBack function added and the SectorWrite function
changed to control emergency system shutdown to prevent Liffy's
internal CF card from corruption.
4) Morgan
1) Added VARMLA variant and bigendian support
5) Graham
1) Changed variant structure for VARMCL, VARMPB, VARMPC,
VARMPD, VARMP1, VARMP2, VARMS1, VARMLA.
The variant object is now created on the kernel heap.
This allows the variant code to have state and will
result in many simplifications of code that interacts
between variant and architecture layers. It will also
allow for improved customisation possibilities for
our licensees.
Questions concerning historical and cross-platform
binary compatibility are yet to be resolved.
2) Cleaned up E32STD.H. This now follows the new standard:
CBase *Function(TDes &aParameter);
becomes
CBase* Function(TDes& aParameter);
3) Snowball PTR2 varmsb and Delaware varmpg removed.
6) Petteri
Changes to the text window server:
1) Four different window classes have been reduced into just one.
2) The notifier server now has a thread of its own and uses text window
server API for its output.
3) ASCII font has been changed to get the window borders back.
4) There is now a constant KCONSFULLSCREEN, which can be used to create
a full-size window whatever the size of the screen.
5) Windows can be moved, resized and scrolled using the mouse or a pen.
6) OnTop flag has been added. If the flag is set, the window stays on top
of other windows.
7) The size of notifier windows now depends on the length of the text
which is being displayed. Buttons can have more than just one character
and they are centred. One button option now works properly. Pressing
ESCAPE returns value 0, ENTER returns 1. The notifier window stays on
top of other windows.
8) Info prints are also variable-sized and they stay on top of other windows.
9) System.ini files are now read correctly in Unicode build. (Files written
in Unicode cannot be read.)
10) Colour support has been added. WINS supports a mode EColor256, where a
palette of 256 colours is available. SetTextAttribute() provides an easy
way to display text in colour. The following attributes are available:
ETextAttributeNormal, ETextAttributeBold, ETextAttributeInverse and
ETextAttributeHighlight. Palettes (if supported) can be manipulated and
read with SetPaletteEntry() and GetPaletteEntry(). SetTextColors() changes
colours for text foreground and background. Colours for window background,
window borders and screen background are set with SetUIColors().
11) The text window server API has 8 new functions:
TInt SetWindowPosAbs(const TPoint &aPosition) (Sets window position.)
TInt ScreenSize(TSize &aSize) (Returns screensize in characters.)
TInt SetMode(TVideoMode aMode)
void SetPaletteEntry(TUint anIndex,TUint8 aRed,TUint8 aGreen,TUint8 aBlue)
void GetPaletteEntry(TUint anIndex,TUint8 &aRed,TUint8 &aGreen,TUint8 &aBlue)
void SetTextColors(TUint anFgColor,TUint aBgColor)
void SetUIColors(TUint aWindowBgColor,TUint aBorderColor,TUint aScreenColor)
void SetTextAttribute(TTextAttribute anAttribute)
Version 1.02.123
================
(Made by Jonathan, 27th January 1998)
1) Alastair
1) Changed MNT.BAT so that no attempt is made to release PDB files for
WINS and WINC release builds, because MAKMAKE generated makefiles do
not create them by default.
2) Removed references to defunct directory \e32\dmedia from MNT.BAT.
2) Jonathan
1) Drain the Snowball 1 digitizer FIFO before enabling its interrupt to
prevent it from generating spurious and unwelcome penup/downs on
startup.
2) P::SetMachineConfiguration() : delete the current password and update
the password from the new configuration.
3) Dropping DTR on Snowball 1's 2nd serial port (the phone port)
asserts the ONKEY signal to the phone, allowing users of that serial
port to turn the phone on/off.
4) Corrected size returned by Custom::XYInputSize() on Snowball().
5) Hugely simplified the Snowball 1 key data tables.
6) Added special support for the Snowball 1's Off key in the keyboard
driver. But this doesn't work.
7) Belatedly updated kbarm files with support for Snowball 1.
Version 1.02.122
================
(Made by Graham, 23rd January 1998)
1) Jonathan
1) Snowball 1. Don't reset the ASIC on startup.
2) Dennis
1) New serial comms LDD and modified PDDs for all variants.
2) WINS comms LDD is now separate from the real comms LDDs. WINS LDD lives in
DPWINS directory with the WINS PDD, and is currently the same as the old comms LDD.
3) Added hooks to KEARM\KE_INT.CPP to allow another operating system to be bolted on to EPOC32.
4) Added test program T_PTNOS.CPP with LDD D_PTNOS.CPP to test the partner OS hooks.
5) Added a check to KPEPOC\KP_PROC.CPP to prevent two copies of a fixed-address
process from being created. DPlatProcess::DoCreate will leave with
KErrAlreadyExists if it finds a matching EXE code chunk belonging to a fixed
address process.
6) Added some more facilities to T_TERM.CPP, including file upload and download
and loopback.
7) Fixed typo in ARM boot code which caused problems by failing to map in the
CS1 ROM if ROM address 0x10000ec6 (physical) contained zero.
8) Fixed bug which could cause processes to be run with incorrect domain access
if an interrupt occurs during a reschedule. This caused machine to reset
during heavy keyboard use.
9) Added missing __NAKED__ declaration to ARM assembler versions of
TDes8::AppendNumUC() and TDes8::AppendNumFixedWidthUC().
10) Fixed problem in DThread::Write() (all 3 variants) - it was returning an error
code if the source descriptor had zero length and a null pointer.
3) Graham
1) Created a new public header file - E32PANIC.H - which
contains the base panic numbers.
2) Split the test programs off into a new E32TEST
project.
3) Removed full exception handling from WINS and WINC if running under Windows '95.
E32's exception handling system relies on being able to asynchronously
meddle with another threads context and stack in order to inject a call
to an exception handler into that thread's normal train of execution. This
technique works with NT but Windows 95 is not up to it. It is clear that
not every operating system would be able to handle this. Consider, for example,
the possibility that the thread is inside an OS call when the call is injected.
4) Alastair
1) Moved build system over to MAKMAKE. The batch files for building E32 are
created by e32tools's BLDMAKE. From the GROUP directory, type BLD or CLEAN
or PREPARE without any arguments for help on how to use the new batch
commands. MAKMAKE has not yet been applied to the build system for MISA,
MX86. CLEAN.BAT uses NMAKE to do its cleaning, so a PREPARE.BAT
needs to have been done first. PREPARE.BAT will make the makefiles and
build the working directories.
2) Renamed freeze files from .FRZ to .DEF, including CONSMARM.FRZ, CONSMISA.FRZ
and CONSWINS.FRZ.
3) Removed WINS_UID statements from all source files.
4) Changed EDLL.O, EXDLL.O, EEXE.O so they are built by separate makefiles
rather than that of EUSER for MARM.
5) Changed KE_EXE.O so that it is built by a separate makefile rather than
that of EKERN for MARM.
6) Added SARMBE platform to the build process so big-endian single-process ARM
platform can be built.
Version 1.02.121
================
(Made by Graham, 10th Dec 1997)
1) Dennis
1) Fixed bug whereby CObjectIx::~CObjectIx could crash if Close()ing an object
in the index caused other objects to be removed from the index and thereby
caused the array to be ReAlloc()ed.
2) Speeded up TInt64 multiply a bit more on the ARM.
3) Added a mechanism whereby every DFC knows whether or not it is pending. Kern::Add
will now only queue the DFC if it is not already queued. DFCs are flagged unqueued
just before being run. A Queued() function is provided to discover whether a DFC
is currently queued or not, and a Cancel() function is provided to cancel a DFC
which is currently pending.
4) Added missing break statements to case EConsoleSetTitle and case EConsoleSetSize
in ws_main.cpp
5) Fixed bug in KBARM\BOOTROM1.S and KBSARM\BOOTROM1.S where a register was being
corrupted (subroutine WordMove corrupts r3) leading to the kernel BSS section not
being correctly zeroed on reset.
6) Fixed bug in TInt64::GetTReal() ARM machine code version - wrong shift count in one
instruction.
7) Added new function KFormat() to KS_UTL.CPP to do limited printf-style formatting
without using any EXEC calls. Modified Kern::Printf to use this function instead
of TDes::AppendFormatList(). This enables Kern::Printf to be used in fast exec
calls, interrupts etc. Use a static buffer to receive the formatted string instead
of an automatic one to avoid gobbling a large amount of stack.
8) Added a new flag ExecMutateFlag which is set by the IRQ and FIQ dispatchers if
an interrupt occurs in SVC mode. The fast executive dispatcher tests this flag on
return from the exec function and if it is set, DFCs and/or a reschedule will be
executed in the same way as for a slow exec call. This fills a hole in the interrupt
scheme whereby if an FIQ occurred during a fast executive call and queued a DFC,
the DFC would not be run before user code was resumed. This flag can also be set
by a fast executive call in order to allow rescheduling to occur.
9) Changed some executive calls from slow to fast to reduce overhead in the case where
a reschedule is not needed. These are ChunkBase, ChunkSize, ChunkBottom, ChunkTop,
ChunkMaxSize, MutexCount, MutexWait, MutexSignal, ProcessId, ProcessExitReason,
ProcessExitType, ProcessExitCategory, ProcessPriority, ProcessFlags, SemaphoreCount,
SemaphoreWait, SemaphoreSignal1, ServerReceive, SessionSend, ThreadId,
ThreadPriority, ThreadProcessPriority, ThreadFlags, ThreadExitType, ThreadExitReason,
ThreadExitCategory, ThreadRequestCount, ThreadRequestComplete, WaitForAnyRequest
and SvSendReceive.
10) Use a different stack for IRQs (IrqStack) rather than the reentrant stack. This
allows IRQs to be enabled during a fast executive call. ThreadRequestComplete,
SessionSend, SvSendReceive, ServerReceive enable IRQs during their execution.
11) Modified the exception handling mechanism. All exceptions are now placed into
one of three categories:
Fatal (exceptions in IRQ, FIQ or ABT mode) - these always cause a kernel fault
Critical (SVC mode or UND mode with the kernel locked) - these cause a kernel
fault unless exception trapping is enabled (DThread::iExceptionErrorCode)
Noncritical (user mode or UND mode with the kernel unlocked) - these are handled by
exception trapping, thread exception handler, global exception handler
in that order. If none of these is active, the current thread is paniced,
and if that thread has the system flag set a kernel fault results.
12) If an exception occurs while the kernel is locked, DFCs will not be run at the end
of the exception handler.
13) PD Variant::Init3() now sets CS1 ROM size to 4Mb and total ROM size to 8Mb.
2) Morgan
1) Renamed Dll::Data to Dll::InitialiseData()
2) Fixed zeroing bss for Dll data in ROM
Version 1.02.120
================
(Made by Jonathan, 24th Nov 1997)
1) Pete
A) Various changes to PC Card Controller to fully support I/O cards as well as memory cards:-
1) Added a new (exported) PC card controller function -
TInt DPcCardCntrl::RestoreCardPower(TSocket aSocket, TInt aResetProfile).
This re-applies power to a PC Card which has previously been successfully powered by the system.
If a media change has occurred on the socket since it was last powered then function will
immediately return KErrGeneral. The power up process is the same as carried out by the controller
function PowerUpCard() - wait up to 2.5Secs for card to become ready using specified reset
profile. However, this function doesn't implement a TRequestStatus mechanism when complete.
It is left to the caller to poll the card status. If the card had previously been configured when
powered and the configuration options allow the configuration to be restored (see 3) then the
card will be reconfigured automatically when it is re-powered.
2) Modified the PC card controller function DPcCardCntrl::PowerUpCard() so that, like RestoreCardPower()
it re-configures PC cards which were previously configured when the card was powered down if a media
change hasn't happened since. Also, the optional last parameter (was TInt aResetLen, now TInt
aResetProfile) now specifies both the reset length and a pause after the card becomes ready. The upper
16bit word specifies a pause period (in 20mS units) after the card signals it is ready before the
controller updates the socket status (and TRequestStatus is signalled). The lower 16bit word specified
the length of the reset pulse (also in 20mS units) applied to the card.
3) Added a new version of the PC card controller function DPcCardCntrl::RequestConfig(). The new
version has an additional parameter 'TUint aFlag' (the old version is now obsolete). The only
flag currently defined is 'KPccdConfigRestorable' which is set if the config may be restored
automatically by the controller if the card is re-powered (see 1 and 2).
4) Added new values to TPccdSocketStatus (to support 1,2 and 14). This can now have the following
values:-
- ESocketFullyOff: Card not present or present but not yet powered.
- ESocketPoweredDown: Card present, not currently powered but has been powered
and could be restored to previous configuration (ie no media change
since it was last powered).
- ESocketBatTooLow: Card present, but not currently powered. A previous attempt to
power the card failed because the main battery voltage was too low.
- ESocketNotReset: Card present and powered, waiting for it to become ready.
- ESocketReady: Card present, powered and ready.
- ESocketCorruptCard: Card present but not powered since it cannot be recognised by
controller (not used yet).
5) Changed the PC card controller event type that causes the mount status of TLocalDrive objects
(associated with PC card media) to be updated. Before, the status was updated on a power-up
event (EPccdEvPwrUp) meaning that any subsequent access to the TLocalDrive object would
be preceded by a remount. Having it on power-up rather than power-down meant the media drive
system only had to bind to one event rather than EPccdEvPwrDown and EPccdEvEmergencyPwrDown.
This however meant it was not possible to power-down cards during periods of inactivity. The
media drive system now binds to power-down events.
6) Change to ATA media driver (MEDATA) on ARM architectures brought about by the emergency power
down changes in E32-V115. The driver was bound to the PC card controller emergency power down
event. Since the driver's event callback is now called on a DFC, changes have been necessary
to handle card writes aborted by emergency power down.
7) Added a new (exported) PC card controller function -
TInt DPcCardCntrl::SetEvent(TSocket aSocket, TPccdEvent anEvent, TInt anInfo);
This allows drivers etc to generate PC card events. It also allows extra info to be passed to
callback functions via 'anInfo' (see 8 below).
8) TPccdCallBack has an extra member 'TInt iCallBackInfo' which can be used to provide extra info.
on a PC card controller event. Extra info on the reason for card power down is now provided in
iCallBackInfo for EPccdEvPwrDown events.
9) The following functions have been added to the custom DLL:-
TPtrC PcCardMediaChangeIntSource(TInt aMediaChange)
void ClearPcCardMediaChangeInt(TInt aMediaChange)
TMediaState PcCardMediaState(TInt aMediaChange);
Prior to these changes the PC card controller media change implementation was completely
implemented in the architecture level and above, meaning that variations to the media change
system couldn't be handled without a new architecture.
Also added an additional member 'TInt iMediaDoorCloseDelay' to 'TPccdCntrlMachineInfo' (returned by the
custom function PcCardMachineInfo()) which allows the media door switch de-bounce parameter to be specified
in the custom.
10) Support for dual voltage PC Card sockets added. These are sockets where the VCC voltage can be
altered depending on the type of card detected (typically 3.3V or 5V). The system implemented,
initially sets the socket VCC depending on the voltage setting indicated by the cards VS (voltage sense)
signals. Dynamically changing the socket VCC once the card is powered (in response to information in
a card's CIS etc) is not supported.
11) Added a new (exported) PC card controller function -
TPccdSocketVcc DPcCardCntrl::SocketVcc(TSocket aSocket);
This returns the current VCC setting for the specified socket. Note that this function
returns info on its current VCC setting even when the supply is turned off.
12) Generally tidy up of the ARM PC card controller VCC implementation. Additions of the following
function to custom DLL:-
PcCardVccInfo(TInt aPsu,TPccdCntrlVccInfo &aninfo).
TPccdCntrlVccInfo is defined:-
class TPccdCntrlVccInfo
{
public:
TUint iVoltageSupported;
TInt iMaxCurrentInMicroAmps;
TUint iVoltCheckInterval;
TPccdPsuVoltChkMthd iVoltCheckMethod;
};
This specifies the voltage(s) that the supply supports (5V,3.3V etc), the maximum current
it can supply, when the o/p of the supply should be checked (once when first turned on,
or continuously while on) and how the voltage should be check (via the ADC channel reserved
for the PC card controller or via a variant layer function).
13) TPcCardPsu renamed to TPcCardVcc since it now has functionality which could
only be attributed to a VCC supply (eg 10&12 above) rather than a generic PC Card supply.
14) Added an additional member 'TInt iDisableOnLowBattery' to 'TPccdCntrlMachineInfo' (returned by the
custom function PcCardMachineInfo()). This can be used to set a battery level (see TSupplyStatus) such that
if the main battery level is below this level, the PC card controller will no longer power up
any PC cards. Set to EZero to disable this feature.
15) Fixed problem clearing PC Card IREQ interrupts on ARM. On ARM platforms the PC card controller
IREQ interrupt service routine was clearing the interrupt in the controller hardware (ETNA)
before calling any ISRs bound by drivers. Since it is generally the driver ISR which clears
the source of the interrupt on the card you end up with a second bogus IREQ interrupt. This
only occurs when 'level mode' interrupts are enabled, not 'pulse mode'. Pulse mode interrupts
are selected if supported which is why the problem was only discovered so late in the day.
16) Changed the reset timing when powering up a PC card. Now:- Apply reset for 100mS, wait up to 2.5Seconds
for card to become ready, delay any access to the card for a further 100mS after ready. (Was:- apply reset
for 60mS, wait 2.5Seconds for ready and no delay on subsequent access).
17) Fixed problem in PC card serial port PDD where the destructor could be called before the member
'iSocket' was initiated. The destructor calls PcCardCntrl::PowerDownCard(iSocket). This was
a particular problem on rack D where the PC card socket is socket 1 (CF card socket is socket 0)
and the rack hw doesn't fully isolate the two sockets. Certain comms programs attempt to open a channel
on the PC card serial port while a channel is already open on this device. These subsequent attempts fail
calling the PDD destructor which then was incorrectly powering off the wrong socket. Due to the h/w
implementation, this was actually resulting in the serial PC card being reset.
18) Fixed a problem affecting EXTFIQ. Once you bound a TInterrupt to EXTFIQ it was not possible to unbind
again.
19) Added the following test programs to TPCCD:-
i)T_MEDCH (and associated LDD MEDCH.LDD): Soak test of Compact Flash (ATA) - h/w media changes.
ii)T_EXTFIQ (and associated LDD EXTFIQ.LDD): Continuously generates EXTFIQ on rack D using EXTFIQ.LDD.
iii)T_BEXFIQ (and associated LDD BEXFIQ.LDD): Generates EXTFIQ on rack D, associated LDD binds and clears
FIQ.
Also modified DRVSOAK to better support emergency power down testing.
B) Modification to serial comms in order to support PC card serial devices:-
20) Added mechanism for opening a channel on a PC Card I/O device. These devices requires an asynchronous
power-up of the card before the standard channel open mechanism can take place. In the case of some PC
Cards (e.g. Serial port cards) there needs to be a further asynchronous phase after creating the PDD
before the channel is fully open.
Added a kernel slow exec function:-
TInt RLogicalChannel::CheckOpenMode(const TDesC &aLogicalDevice,const TVersion &aVer,TInt aUnit);
This is called once each time a channel is opened. If the return value is <0 then the open proceeds as
normal. Otherwise, it indicates that a 1 or 2 phase asynchronous open is required. (This function would
normally ripple down to the custom DLL).
Added a kernel supervisor function:-
TInt RLogicalChannel::DoSlowOpen(TInt aMode,TInt anInfo,TRequestStatus &aStatus);
This initiates the asynchronous parts of the operation. 'aMode' is either KChanSlowOpenPhase1 or
KChanSlowOpenPhase1 to indicate whether its the aynchronous phase before or after the normal open. 'anInfo'
is derived from the value returned from CheckOpenMode() and normally indicates the PC Card socket in
question. TInt RLogicalChannel::DoCreate() has been modified to include these extra operations.
An extra pure virtual function:-
TInt DComm::CompleteSlowOpen(DThread *aThread,TRequestStatus *aReqStat);
had to be added to DComm in order to implement the 2nd asynchronous open phase.
21) Modified PC card serial port PDD to take advantage of the above PDD open scheme (20) so that the PDD now
fully controls the PC card. (Before it relied on the media system having already powered up the PC Card and
didn't properly perform the 2nd part of the initialisation). Also modified the PDD so that it re-applies
power and re-configures the Serial PC Card each time the system comes out of standby (eg machine switched
off, emergency power down etc).
22) Changes to LDD to handle PC Card media change events (ie media door open or card removal - dependant on
platform).
As far as I can gather, in the serial LDD, iStatus==EClosed never occurs. I now force the LDD into
this state from a PC Card PDD when a media change is detected. The serial port now needs to be disabled
(for good) because it has been powered down (and in all likelyhood removed). Once in this state
you never should to change to any other state. Any write requests return with KErrNotReady which hopefully
will give any client a clue that they shouldn't have removed the PC card serial port while using it. This
is an intermediate solution. The eventual plan (involving a the invention of a new RDevCom type class) will
handle the media change and re-power the serial PC card (if still there) before any requests get down to
the LDD. However, you need an asychronous supervisor kernel call to restore a PC card after media change
which can't be acheived with the present scheme. It is possible to re-power the PC card when coming out of
standby (machine turned off etc) because you know the same PC card is still present and hence you don't
need to alter any memory allocation associated with the card.
23) Modified PC card serial port PDD to enable serial interrupts for modem signal status changes (CTS,DCD,DSR,
RI). Prior to this, h/w flow control wasn't supported on this serial device.
24) Modified PC card serial port PDD to update system current consumption info. This info is derived from the
PC card CIS where possible.
25) Modified PC card serial port PDD to determine its baudrate capabilities from 'max baudrate supported' field
(if present) in the CIS. Also, limit baudrate (capabilities) to 19200 if serial card doesn't contain a FIFO.
26) Added the following test programs to TCOMM:-
i)T_MODEM1: Test code for PC Card Modem Serial Ports (analogue loopback).
ii)T_COMSOAK1: Serial port soak test program (requires loopback connector).
iii)T_AMPV: Approval test code for PC Card Adapter.
iv) T_MODEM2: T_SERIAL for PC card serial port. Instead of looping COM1 to COM2(Etna) it loops
COM1 to COM3 expecting a PC Card Socket I/O Serial card.
Also modified T_TERM so it can be used to open a channel on COM3. (Also added extra error reporting).
2) Jonathan
1) Old Snowball variant SA retired.
2) New Snowball variant S1 for Prototype 3 units. Major changes from SB:
- Combined PDD for Eiger and ASIC serial ports using shared modem
status interrupt.
- Variant-specific LDD for use on ASIC serial port only - implements
Spark phone's weird CTS handshaking.
- QuickEmergencyStandby handler.
3) New PhysicalScreenWidth and PhysicalScreenHeight values for
\epoc32\data\system.ini, see kpwins\kp_gui.cpp .
4) Prevented *\va_sdrv.cpp from trying to Disable or UnBind when unbound
from its interrupt.
Version 1.02.119
================
(Made by Morgan, 7th Nov 1997)
1) Alastair
1) SARM
Integrated Single-process code into e32 source allowing SARM roms to be
created. Build commands are mnt sarm, sarmall, sarmrel etc. There are no
releaseables and no facilities for building test programs. SARM builds
use the "__SINGLE__" macro for distinguishing Single-process-specific
code. Work directories are \epoc32\build\e32\sarm\[build] and
\epoc32\release\sarm\[build]. SARM makefiles are generated into
\e32\bsarm using perl to process makefiles from \e32\bmarm as a
temporary measure prior to the use of makmake for creating e32
makefiles. SARM roms are built from directory \e32\kbsarm, and require
a special version of rombuild - the makefile for this special version
will be released with e32tools version 082.
Major changes
a) \e32\kbsarm - contains special versions of bootrom1.s and rom.oby.
b) \e32\inc - changes to e32rom.h, k32std.h, m32mmu.h, m32std.h and
v32eiger.h so that different linear address constants are defined
for __SINGLE__ builds.
__SINGLE__ (MULTI)
KRomHeaderLinAddr 0x00000000 0x50000000
KSuperPageLinAddr 0xC0000000 0x40000000
KHomeBase 0xC0000000 0x80000000
KHomeEnd KHomebase+0x3fffff 0xffffffff
KHwLinBase 0xa0000000 0x60000000
KHwLinEnd 0xbfffffff 0x7fffffff
KEigerBaseAddress 0x80000000 0x58000000
c) \e32\kpepoc\kp_chk.cpp - __SINGLE__ chunks are allocated in the kernel's
heap - they cannot change in size and don't move. Since SARM roms do not
utilise the MMU. The actual size of a chunk is a compromise between the
initial and maximum sizes requested when a chunk is created.
File changes
d) bsarm\*
dpepoc\d_medint
group\mnt.cmd
inc\ - e32rom.h, k32std.h, m32mmu.h, m32std.h, v32eiger.h
kbsarm\*
kearm\ - ke_ini, ke_int, ke_mmu, ke_utl
kpehal\ - kph_inf, kph_pic
kpemmu\ - kpm_mmu.cpp
kpepoc\ - kp_chk, kp_ini, kp_proc, kp_reg, kp_std.h, kp_thrd, kp_utl
ksrc\ - ks_svr, ks_utl
varmpd\va_hw
wsrc\wd_eiger
2) Added UNICODE.H to e32\inc\incc.prj so that the file is released.
3) Changed WINS command line processing such that only switches specified
before "--" is encountered are processed. Switches after the "--" switch,
or all switches if the "--" switch is not specified, are ignored.
4) Added -L<language Index> switch to WINS command line so that
different Epoc locales can be specified. Eg "WSEXE -L5 --" will
mean that elocl5.dll rather than elocl.dll is loaded.
2) Dennis
1) Rewrote MMU code. Major changes are:
i) Linear address map has changed - see file KEARM\KE_MMU.CPP
ii) RAM drive is at fixed linear address but no longer composed of consecutive
physical RAM pages.
iii) The free page pool has been removed.
iv) The ROM is mapped with section descriptors on the ARM instead of 4K pages.
v) Chunks can be adjusted in place rather than only in the home section.
vi) On the ARM extra protection has been added for page tables, registry
and RAM drive.
vii) ROM layout is different - the kernel data is at 80000000, followed by
static data for fixed-address ROM processes (see below). The kernel
stack follows the last fixed-address data chunk, and the home section
starts with the kernel stack chunk.
2) Modified process handling and scheduling:
i) Now have two classes of process. One class has its chunks mapped down
into the data section while running, the other class has its chunks
at the same linear address all the time. The latter class is used for
system servers. It reduces the need for cache flushing - this is only
required if any chunks have moved - and thus gives a considerable speed
increase.
ii) ROM fixed address processes specified in .OBY file
RAM fixed address processes specified by setting KImageFixedAddressExe flag
iii) On the ARM, a domain will be allocated to every fixed-address process.
All the process' local chunks will be located in this domain. In addition,
every global chunk created by a fixed-address process will be allocated
a domain. The use of domains removes the need for page directory
manipulation when switching between these processes.
iv) The scheduler has been machine coded for ARM and ISA. Actions performed
on switching between processes now depend on the attributes of these
processes.
3) Added ARM machine coded message passing and semaphore code.
4) Modified inter-process reading and writing code. Two functions have been added:
i) TAny* DPlatThread::CurrentAddress(TAny *anAddress);
This function returns the current linear address corresponding to an
address in the thread's address space. No translation is done for addresses
above 0x40000000 or if the thread's process is currently running.
This function is used to convert addresses for reading.
ii) TAny* DPlatThread::CurrentAddress(TAny *anAddress, TInt& aMaxSize);
This function returns the current linear address corresponding to an
address in the thread's address space and also the maximum size of a write
to the thread's address space (end of chunk - specified address).
Chunk lookup is always performed.
This function is used to convert addresses for writing.
5) Kernel faults now restart the system from the reset vector. The MMU backup
page has been removed.
6) Added double-ended chunks. These are regions of memory where the committed
region can start at any address in the reserved range, rather than always starting
at the base of the reserved range. Added functions
i) RChunk::CreateDoubleEndedLocal()
Create a local double-ended chunk with a specified maximum size and
a specified initial committed region.
ii) RChunk::CreateDoubleEndedGlobal()
Create a global named double-ended chunk with a specified maximum size and
a specified initial committed region.
iii) RChunk::AdjustDoubleEnded()
Adjust the position and/or size of the committed region. If the initial
and final regions intersect, the contents of the intersection are
unchanged. Other parts of the committed region have undefined contents.
iv) RChunk::Bottom()
Returns the offset of the base of the committed region from the base of
the reserved region (RChunk::Base()).
v) RChunk::Top()
Returns the offset of the top of the committed region from the base of
the reserved region. ( Top() = Bottom()+Size() )
RChunk::Size() always returns the size of the committed region.
7) Extended the CBitMapAllocator class. Functions added are:
i) TInt Alloc(TInt aCount, TInt& aConsecutive)
Allocates from the first free position as many consecutive positions as
possible, up to aCount. Returns the first free position, and aConsecutive
equal to the number of positions allocated.
ii) TInt AllocAligned(TInt anAlignment)
Allocates a position whose number is an exact multiple of 2^anAlignment.
iii) TInt AllocAlignedBlock(TInt anAlignment)
Allocates a block of 2^anAlignment consecutive positions such that the
first position is an exact multiple of 2^anAlignment. Returns the
first position.
iv) AllocAt(TInt aPos, TInt aCount)
Allocates aCount positions starting at aPos.
v) Free(TInt aPos, TInt aCount)
Frees aCount positions starting at aPos.
iv) TBool IsFree(TInt aPos, TInt aCount)
Returns TRUE if and only if positions [aPos,aPos+aCount) are all free.
8) Modified Math::Sin, Math::Cos and Math::Tan functions to return exact answers
when input values are exact multiples of pi/2. This is done by adding tests of
the form
IF ( ABS(x MOD pi) < 2^-52 * ABS(x) )
return exact answer
ELSE
do calculation as before
ENDIF
9) Modified TTime::Convert(const TDateTime&) and TTime::DateTime() in order
to minimise the number of divisions involved and to use 32 bit arithmetic
rather than 64 bit wherever possible. The latter of these functions gets
called frequently by the window server on a periodic timer.
10) Added functions TDes8/TDes16 :: (Append)NumFixedWidth(UC)
These convert 32-bit integers to descriptors in a specified radix, adding leading
zeros up to the specified field width. These are intended to replace calls of
the form
des.Format(_L("%08x"),value)
which are very inefficient. All Format() calls in E32 have been replaced, apart
from the ones which use an overflow handler.
11) Fixed problem with comms driver causing reset if an interrupt occurs while the
kernel server is closing a comms channel. This was caused by the interrupt queuing
a DFC which refers to the comms channel being closed. The DFC runs after the
kernel server has deleted the channel, and resets the machine when it tries to
access the nonexistent channel.
12) Files changed:
dcomm\ d_comm.cpp
dpepoc\ d_medint.cpp
dvideo\ ws_disp.cpp
inc\ e32base.h, e32des8.h, e32des16.h, e32rom.h, e32std.h, e32svr.h,
k32std.h, k32std.inl, m32std.h, m32std.inl, m32hal.h, u32std.h, v32eiger.h
m32mmu.h and m32mmu.inl have been removed
kbarm\ bootrom1.s, rom.oby
kbx86\ boot486.asm, bootrom.asm, build.cmd, e32d.oby, e32r.oby, m486.bat,
romdefs.inc, romhead.inc
kbsarm\ bootrom1.s
kearm\ ke_dat.cpp, ke_dbg.cpp, ke_ini.cpp, ke_int.cpp, ke_mmu.cpp, ke_pccd.cpp,
ke_pic.cpp, ke_psu.cpp, ke_std.h, ke_thrd.cpp, ke_utl.cpp
ke_all.cpp deleted, ke_sched.cpp added
keisa\ ke_dat.cpp, ke_dbg.cpp, ke_ini.cpp, ke_int.cpp, ke_mmu.cpp, ke_pccd.cpp,
ke_std.h, ke_thrd.cpp, ke_utl.cpp
ke_all.cpp deleted, ke_sched.cpp added
kex86\ ke_exc.cpp, ke_ini.cpp, ke_int.cpp, ke_mmu.cpp, ke_std.h, ke_thrd.cpp,
ke_utl.cpp
ke_all.cpp deleted
kpehal\ kph_dbg.cpp, kph_inf.cpp, kph_pic.cpp
kpemmu\ kpm_mmu.cpp
kpm_all.cpp, kpm_regn.cpp, kpm_sect.cpp deleted
kpepoc\ kp_chk.cpp, kp_dat.cpp, kp_dev.cpp, kp_ini.cpp, kp_proc.cpp, kp_reg.cpp,
kp_sched.cpp, kp_sem.cpp, kp_thrd.cpp, kp_utl.cpp
kpwins\ kp_chk.cpp, kp_ini.cpp, kp_proc.cpp, kp_std.h, kp_thrd.cpp, kp_utl.cpp
ksrc\ ks_chk.cpp, ks_exec.cpp, ks_ldd.cpp, ks_lib.cpp, ks_mes.cpp, ks_pdd.cpp,
ks_proc.cpp, ks_svr.cpp, ks_thrd.cpp, ks_utl.cpp
ubas\ ub_bma.cpp, ub_obj.cpp, ub_std.h
ucdt\ uc_des8.cpp, uc_des16.cpp, uc_exec.cpp, uc_func.cpp, uc_ksvr.cpp,
uc_reg.cpp, uc_std.h, uc_time.cpp
umath\ um_rtod.cpp, um_sin.cpp, um_tan.cpp
upmarm\ up_des8.cpp, up_exec.cpp, up_utl.cpp
upmx86\ up_exec.cpp
upwins\ up_exec.cpp
vx86pc\ vx_vga.cpp
3) Morgan
1) Added dll process attach and detach for ARM and X86 builds
2) Added RThread::Context(TDes8 &aDes) to retrieve the register contents of
a sleeping thread.
3) Added RChunk::ReserveAt(TUint8 *) to force allocation of a chunk at the
specified linear address.
4) Ldd/Pdds with static data was broken. Now fixed.
5) Loading Dlls with writable static data now allocates a Data/Bss chunk
and offers it to F32 to be fixed up.
6) Added TInt Dll::Data() to initialise Dll writable static data
Version 1.02.118
================
(Made by Jonathan, 15th October 1997)
1) Dennis
1) Rewrote CObjectIx, CObjectCon and CObjectConIx classes to do their own
array handling instead of using CArrayFixFlat.
2) Added ARM machine-coded versions of CObjectIx::At, CObjectIx::operator[],
CObjectCon::At and CObjectCon::operator[].
3) Added ARM machine-coded versions of CActiveScheduler::Start() and
CServer::RunL().
4) Removed CArrayFixFlat from DPlatProcess. Custom array handling code is now
used to store the chunks being used by a process.
5) Added ARM machine-coded versions of some commonly used fast Exec:: calls and
of DPlatProcess::LookupChunk().
2) Morgan
1) Added -M<machineName> switch to WINS command line to pick up
alternate System ini files from \epoc32\Data. eg WSEXE -Mfungus
will use \epoc32\data\fungus.ini
2) Froze the Custom Dll against V1.01 E32(114)
3) Froze the Variant Dlls (P1,P2,PB,PC,PD,PG,SA,SB,CL) against V1.01 E32(114)
3) Jonathan
1) Changed Snowball A & B physical screen size to 4.4"x1.375".
2) New TSAsic::SetCrystalSpeed function in varmsb\va_sasic.cpp.
3) Added cakysbd keyboard driver for Snowball B which has a, b, z and :
instead of arrow keys.
4) Snowball B variant autodetects 4MB or 8MB ROM, 1MB or 4MB RAM
5) New Hal::StartupReason() type EStartupSafeReset. Currently this is only
returned by Snowballs when "Home" and "Back" are pressed at boot.
6) Replaced Variant::ColdReset with more general Variant::StartupReason.
This breaks Morgan's variant & custom freezes against 114 for this one
function, but that's OK because the kernel really is the only component
that should be calling this.
7) New UserSvr::ResetMachine(TMachineStartupType) function. Currently only
allows a reset type of EStartupWarmReset. Implemented by generating a
TPlatFault::ESoftwareWarmReset. After the reset the kernel may
actually report a reason other than EStartupWarmReset if either:
- EStartupWarmReset isn't supported (mx86/misa/wins)
- The variant supports munging of reset types, ie by holding down
keys at boot, and those keys are held down (various marm variants).
8) New custom and parent functions AutoSwitchOffType, which returns
ESwitchOffEvent on Snowballs A & B, ESwitchOffHard on other variants.
9) New TRawEvent::ESwitchOff. The kernel generates this at auto-switchoff
time instead of just switching off if the above function returns
ESwitchOffEvent. The window server (or one of its clients) must call
UserHal::SwitchOff fairly soon after receiving this event. Made the
text window server do this. Auto-switchoff is still disabled by default
on Snowballs A & B becuase wakeup is still broken.
4) Matthew
1) Enabled hardware filtering on SA and SB digitisers. Also boosted
sampling rate to 112 pps.
2) Changed SB variant so that the san-disk is mapped to InternalMedia0
(ie C:). Make sure you get rid of MEDINT.PDD from your .oby file when
building roms, or F32 will pick this up and you will still have the
ram disk as C:.
Version 1.02.117
================
(Made by Jonathan, 5th September 1997)
1) Dennis
1) Rewrote Math:: transcendental functions to use simpler algorithms
and to run faster. All functions now use polynomial approximations
instead of rational functions.
2) Added Math::PolyX function to do fast polynomial evaluation using
TRealX for argument, coefficients and result.
3) Updated T_R64BM to benchmark more functions and to use a range of
different argument values.
4) Added new test program T_MATH2.EXE to test the accuracy of the
transcendental functions.
5) Fixed SW-21.
Changed way in which DLLs statically linked to an EXE are handled.
Instead of opening a process-relative handle on the DLL, the process'
code chunk now holds a list of DLLs on which it depends. This list
is only deleted when the chunk itself is deleted, thus solving the
problem of two instances of the same EXE running concurrently.
Added function UserSvr::ExeAddDependency to add a DLL to the process
code chunk's dependency list.
2) Matthew
1) Added software filtering to Snowball digitiser drivers.
2) Moved initial calibration of digitiser into the TDigitiserXxx::Init3().
This has also meant that some of the E2Prom functions needed to be
exported - I exported all the public functions.
This change has allowed Hal::Init3 to be rearranged to how it was in 114.
3) Fixed small bug in Snowball B Comm2 driver, which was acting as though
it supported 57600bps.
3) Rob Pym
1) Added support for ARM 7115 - this chip has a few more peripherals
than the ARM 7110. New functions in ke_eiger.cpp and ke_pic.cpp.
2) Added CL variant for the Cirrus Logic ARM 7115 evaluation board.
[Jonathan:] Releasables not released because it doesn't build.
Version 1.02.116
================
(Made by Jonathan, 26th August 1997)
1) Dennis
1) Added new extended-precision real class TRealX, defined in
e32math.h. This class provides 64 bit precision and a dynamic
range of approx. 1E-9863 to 1E+9863. All member functions are
assembler coded for speed.
2) Changed GCC compiler helper functions to use TRealX instead
of TReal96 to speed things up. Also modified all UM_xxx files
to use TRealX instead of TReal96, apart from UM_DTOR and
UM_RTOD.
3) Added new test programs T_TREALX, T_R64BM, T_RXBM. T_TREALX
tests the TRealX member functions. T_R64BM does a benchmark
test for TReal64 field operations and transcendental functions.
T_RXBM does a benchmark test for TRealX field operations.
4) Added machine coded versions of Math::Sqrt() and some other
Math:: functions for ARM.
2) Jonathan
1) Fixed data TX on varmsa/va_com2.cpp and varmpd/va_com3.cpp when
Fifos are disabled; no longer trys to output >1 byte on TX interrupt.
2) Variant::Init3() on Snowball A & B sets AutoSwitchOffBehavior to
ESwitchOffDisabled because power management isn't yet implemented.
3) Changed table in Snowball B Variant::SetLcdContrast to correct for
strange hardware.
4) To reduce noise in the output logs, all .cmd files to build E32 now
invoke NMAKE with the -nologo flag.
3) Pete
1) Added Internal ATA media driver (MATISB.PDD) for Lavender prototype B
build.
2) Change to internal ram media driver on WINS/ARM so that it only
opens on media device type EFixedMedia0 rather than any fixed media
type.
4) Matthew
1) Fixed bug in Snowball digitiser drivers which caused execeptions when
the pen was down. Fixed by moving the queueing of the pen-up timer from
the interrupt service routine into the Dfc.
2) Added code to read the CTS signal in the Snowball prototype B com2 PDD.
3) Temporarilly made the Snowball prototype B com2 PDD ignore framing
errors at 38400 bps. This is to allow people downstream to use the port.
4) Further modifications to T_SERIAL for Snowball compatibility.
Version 1.02.115
================
(Made by Jonathan, 16th August 1997)
1) Graham
1) Changed in RAM standby code to have a delay loop
rather than the previous faulty inmplementation
which attempted to validate the ROM by
continually reading it until it returned a known
good value - this was erroneous because the ROM
reads were coming from the cache anyway.
Then I commented out this code and replaced it with
the traditional code that runs from ROM (this was
only introduced as a result of some hardware paranoia
when we were getting 'unable to switch on' bugs in
the run up to V1.00
2) Updated minor version number to 02.
2) Dennis
1) Modified emergency power-down FIQ handler so that it
only performs the bare minimum of tasks when the machine
is powered up again. Other more time-consuming tasks have
been moved into a DFC.
2) Added new machine code versions of TInt64 functions for MARM,
WINS and MX86 which don't use the TInt64A class.
3) Added machine coded versions of some 8-bit descriptor functions
for MARM in new file UPMARM\UP_DES8.CPP.
4) Added machine coded versions of RHeap::Alloc(), RHeap::Free()
for MARM REL.
5) Modified Mem::Copy() to run faster when source and destination
addresses are unaligned, or when a small copy is required.
3) Ann
1) Fixed rounding bug where the number of intervening zeros
after the decimal point in a descriptor was being ignored
when next non-zero digit is out of range of precision when
converting to real.
4) Matthew/Jonathan
1) Added Snowball B variant for use with the Snowball prototype.
2) With a TSAsic class to access the ASIC on the Snowball prototype.
5) Matthew
1) Added digitiser drivers for snowballs A and B.
2) Added a virtual SetCalibration() function to the TXYInput
class, so that future digitiser drivers can use hardware
calibration, if this is available.
Currently none of the drivers use this (including the Snowball
ones) and they return KErrNotSupported.
3) Added a comm pdd for the Snowball prototype asic. There are
several known bugs in this driver.
Made some modifications to T_SERIAL so that it does not test
things beyond the capabilities of the comm port when running
on a Snowball.
6) Jonathan
1) Fixed problem caused by reading IID register too often in
Snowball A 2nd comm pdd.
2) Added IR support to Snowball B 1st comm pdd (untested).
Failing on Snowball B prototype:
- tests t_power, t_timer, t_chunk, t_serial, t_idrv, t_pccd1, t_pccd2
- Power up after switch-off
Version 1.01.114
================
(Made by Graham, 29th July 1997)
1) Matthew
1) SW1-244 Fixed sound driver so that it no longer returns
KErrAlreadyExists if a prepare function is called
twice. Changed test code accordingly.
2) Morgan
1) SW3-1556 Removed dependency in M32HAL.H on M32DBG.H and
re-inserted dependency on M32DBG.H in appropriate .CPP
files.
Version 1.01.113
================
(Made by Graham, 25th July 1997)
1) Dennis
1) Fixed CSW3-1559, CSW3-1560, CSW3-1530, SW1-91, SW1-155, SW1-158
Added doubly-linked tree structure to DLibrary objects to record which
DLLs depend on which. The access count of a DLibrary object is now equal to
the number of thread/process handles open on it, plus the number of other
DLibrary objects which have a dependency on it. Added code to DLibrary::Close()
to check that a DLL is really in use (directly or indirectly) by traversing
the tree structure and to delete it if it is not. Added a new supervisor function
UserSvr::DllAddDependency() used by the loader to record DLL dependencies.
2) Matthew
1) Fixed bug in sound ldd which caused buffers to be orphaned on the kernel heap if
a prepare function was called twice. This now returns KErrAlreadyExists.
Added test code to t_sound.
3) Graham
1) Made further changes to the backup battery levels:
Good -> Low 2850
Low -> Replace 2800
Replace -> Low 2850
Low -> Good 2900
Not present 2000
2) SW1-201. Reduced the maximum voltage of the main battery
from 3100mV to 3000mV.
3) SW1-179. Removed redundant IMPORT_C declarations from
E32BASE.H on:
CServer::NewSessionL
CSession::ServiceL
4) Added Charles Wier's ASSERT macro.
5) Changed the battery voltage reading algorithm. I used
to do one one dummy read on the adc channel then wait
10mS then take the real reading. I now do 10 dummy
reads at the rate of one every millisecond and then
take the real reading.
6) Fixed the .REL files to release Dutch and French
localisation dlls and a french keyboard table for MARM P2.
7) Added Scandinavian localisation dll in WINS and MARM
builds.
8) Added DANISH/NORWEGIAN keyboard table (CAKDP2.DN) and
SWEDISH/FINNISH keyboard table (CAKDP2.SF) for P2
MARM builds.
Version 1.01.112
================
(Made by Graham, 17th July 1997)
1) Dennis
1) Fixed CSW-2710, SW1-114
Changed four kernel faults to K::PanicCurrentThread with new KERN-EXEC
panic numbers; these are KK::EMesAlreadyPending, KK::EEvntRequestPending
and two instances of PP::EIllegalWsProcess.
2) Fixed CSW3-880
Corrected checking of filename length in RLoader::LoadProcess() and added
a check for the command line length.
3) Fixed CSW3-1340
Changed the code to allow both heap min size and heap max size to be zero.
However if heap max size < 256, then a value of 256 will actually be used.
4) Fixed CSW3-1601
Set up the value of K::TickCounter in the RTC tick ISR rather than in code
which runs asynchronously to the RTC tick. Reinitialise K::TickCounter when
the system time is changed.
5) Fixed CSW3-1670
Added function TBool TTickQ::CheckMidnightCrossover(TInt aSecs) to check if
a midnight crossover has occurred and set iTomorrowStarts accordingly. Added
overloaded function void TSecondQ::SystemTimeChanged(TUint& aChanges)
to abort all absolute and locked timers and set the EChangesMidnightCrossover
bit in aChanges if a system time change results in a midnight crossover.
TSecondQ::SystemTimeChanged() now calls this function, as does
ExecHandler::LocaleSet(). Updated T_CHNOT.CPP to test the new RChangeNotifier
behaviour.
6) Modified prefetch abort handler to set iDataAddress to the value of lr when
the exception occurred.
7) Corrected User::StartThread to call DLL entrypoints with EDllThreadDetach
rather than EDllThreadAttach when the thread exits.
8) Set the RTC correction to zero on a cold start. (Forgot this last time!)
2) Graham
1) Added code to fetch the language index and the keyboard
index from E2. Added these values to the machine info
structure (UserHal::MachineInfo()) by adding class
TMachineInfoV2 which derives from TMachineInfoV1.
2) Modified the text window server to load a different
localisation module and keyboard module according to
the language and keyboard indexes read from E2.
3) Increased the adjustment for current consumption
that is made prior to establishing whether the main
battery status should fall.
4) Reduced the voltage levels at which the main battery
status changes. Low is now at 2150mV, Replace is now
at 1900mV (P2 and PD variants only).
5) Reduced the max backup battery voltage to 3100mV in
line with the max main battery voltage (P2 and PD
variants only).
6) Reduced the voltage levels at which the backup up
battery status changes:
Old (mV) New (mV)
Good -> Low 2900 2800
Low -> Replace 2800 2750
Replace -> Low 2850 2780
Low -> Good 3000 3000
Not present 2000 2000
7) Added kernel side EXPORTS for:
S::ChunkCreate
S::LibraryLoadExact
S::MutexCreate
S::PhysicalDeviceLoad
S::PhysicalDeviceFree
S::SemaphoreCreate
3) Basher
1) Added new function in the keyboard translation dll
(ChangeKeyData) which loads a different keyboard data
module.
4) Pete
1) When interrogating the CIS of a PC Card to determine the cards type,
the PC Card controller verifies the integrity of the CIS by
attempting to follow each CIS chain to the end. While performing this
operation the controller is currently reading each tuple entirely
rather than just checking its type and link. This is un-necesary and
in fact not recomemded. Unknown tuples may contain active registers.
This change fixes the problem.
Version 1.01.111
================
(Made by Graham, 11th July 1997)
1) Jonathan
1) Small fix to DPccdCntrlInterface::DoNotifyChange and DoChangeFlag to return
KErrGeneral instead of panicing on being passed an invalid socket number.
2) Kernel now exports all of DPlatChunkHw so that device drivers can map
in their own memory-mapped registers etc.
3) Added 2nd serial port (16550-based) to Snowball MARM variant. Currently
just a dummy because of a suspected bug triggered by ~DPlatChunkHW().
4) Variant::TestBootSequence on Snowball is always True. This enables an
(alternative) etest.exe to be run on boot, which starts elink before booting
normally.
5) Added etestl.exe which does the above.
2) Pete
1) Fixed SW3-1226
Makes it possible to force accesses to as particular type of PC Card
memory (ie Common,Attribute,I/O) to be 8-bit accesses only (ie 32bit
word accesses disabled). This mode can be enabled in the function
Variant::PcCardCntrlMemConfig() by returning KMemConfigByteAccess.
This is to support h/w implementations which can't support 32-bit accesses
to PC Card memory.
3) Dennis
1) Fixed SW3-1321
Moved the RTC correction value and last set time into the super page so
that they will be preserved over warm resets. This stops strange offsets
from being added to the system time when the machine is switched off and on.
2) Moved the definition of the super page from M32STD.H to K32STD.H. Added a
super page to the WINS build. Moved the battery statistics (insertion time,
time on main battery, time on external power, battery power used) from K::
into the super page so that they will be preserved over warm resets.
3) Fixed SW3-1419
Removed all user access from user data chunks in the home section. Changed
the way the stack/heap chunk is created on thread creation - the pages are
now allocated using DPlatChunk::AdjustL() instead of AdjustUserL(). This means
that the pages are immediately mapped with the correct page permissions
rather than with full user access. Removed the line in DPlatProcess::Loaded()
which applies the final page permissions to the main thread's stack/heap chunk.
4) Fixed SW3-1317
Modified function RUserHeap::SvClose() so that if it finds the access count of
the heap negative, it panics the owning process rather than causing a kernel fault.
5) Fixed SW3-1311
Fixed operator precedence error in CObjectIx::Remove().
6) Fixed SW3-770, SW3-1539
Modified DPlatProcess::DoSetPriority() to recursively descend the tree of threads
owned by the process and adjust their priorities (previously, thread-relative threads
were not adjusted).
Introduced a new set of absolute thread priorities which enable the priority of a
thread to be made independent of the priority of its owning process.
Note that this upgrade requires a modification to the SHELL to set the priority of
the EIKON server thread to EPriorityAbsoluteForeground instead of EPriorityMore.
7) Fixed SW3-319
Added a new exported function Kern::PanicCurrentThread(const TDesC&, int) which panics
a thread by sending a message to the kernel server (like K::PanicCurrentThread).
Modified D_COMM.CPP to call this function instead of DPlatThread::Panic().
8) Fixed SW3-1604
Modified RThread::RaiseException() so that if the exception is unhandled, it panics
with ECausedException rather than calling User::Exit(KErrDied);
9) Fixed SW3-4688
Modified UPWINS\UP_TRP.CPP to do a ret 4 at the end of User::Leave() instead
of a compiler-generated ret 0. Applied the same modification to the X86 build.
10) Fixed SW3-1408, SW3-1671
Modified UCDT\UC_REGN.CPP TRegion::SubRect() to return without doing anything if
the rectangle to be subtracted is empty. Applied the same modification to the
ARM version in UPMARM\UP_UTL.CPP.
11) Fixed SW-4688
Modified UPWINS\UP_TRP.CPP User::Leave() to end with a ret 4 instead of a ret 0.
Applied the same modification to the MX86 version.
12) Fixed SW3-1149
Added an inline accessor function for the iThread member of CAsyncOneShot to
allow the handle to be changed.
13) Fixed SW3-1604
Modified RThread::RaiseException() so that if the exception is unhandled, it
panics with ECausedException rather than calling User::Exit(KErrDied);
14) Fixed SW-5529
Modified RLibrary::LoadRomLibrary in UPMARM\UP_LIB.CPP and UPMX86\UP_LIB.CPP
to close a handle in all possible cases.
15) Fixed SW-5530
Modified KS_SEM.CPP, KS_MUTX.CPP and KS_CHK.CPP so that if a global object is
created with a thread-relative handle, it has no owner.
16) Modified DPlatThread::Die() so that if a system thread panics, the machine resets.
17) Fixed SW1-22
Modified CObjectIx destructor to invalidate each array entry after closing it.
Modified CObjectIx::Remove() to panic if an attempt is made to remove an entry with
a null object pointer.
Modified S::Close() to check if the handle is valid before attempting to close it.
18) Fixed CSW3-1426
Made 0x10 (DLE, non-breaking space character in OPL) a whitespace character.
19) Fixed CSW-5500
Check for nDig<0 in doGeneral() function, return KErrGeneral in this case.
4) Matthew
1) Fixed SW3-883
Moved the undertaker notification call Kern::NotifyThreadDeath() from
DThread::Cleanup() to DThread::DoDie(), so it is called before any child threads
are killed.
Added test to T_THREAD.
2) Fixed SW3-1173
Made "%X" give upper-case, instead of lower-case hex.
Added test to T_BUF.
3) Changed T_SOUND test code so that it actually tests that keyclicks are disabled
during recording.
4) Renamed Variant::TVarmpdPanic to TVarmp2Panic in P2 variant.
5) Made varmp2\va_prom.cpp #include v32armp2.h instead of v32armpd.h.
5) Graham
1) Anns fix for incompatibility between random number
generation on WINS and MARM.
2) Martin Tasker's updated header files E32BASE.H and
E32DEF.H for MSVC 5.0 compliance.
3) Increased RAM refresh rate to the maximum in the
bootstrap. This can then be slowed down in the
variant layer if applicable.
4) Changed the reschedule code to run with interrupts on.
5) Added Charles Wier's __DECLARE_TEST_DEBUG that compiles
out in release mode.
6) Added Charles Wier's RTest::SetConsole(CConsoleBase*).
7) SW3-716 sanitise E32KEYS.H for the resource compiler.
8) SW3-1556 released M32MMU.H and .INL in INCK and removed
dependency in M32HAL.H on M32DBG.H.
9) SW3-1557. Fixed an ASSERT in Mmu::AllocShadowPage().
10) Added new Central European language enums to TLanguage.
11) Changed RNotifier::Connect to use its own version number
instead of the operating system version number - the
notifier interface is updated independently of E32.
12) Merged in new in localisation files since 110.
13) Fixed bug in ARM architecture which caused ADC code
to be called when the variant specified that no
ADC was fitted - caused problems for Delaware.
14) Changed the main battery monitoring code to compensate
for voltage drops with high current consumption when
calculating changes in battery status.
15) Changed the main battery monitoring code to increase
the frequency that it samples the main battery voltage
when other components are interested in obtaining
accurate readings of that voltage.
16) Changed the P2 and PD sound driver to divorce its ability
to play digital sound from the main battery status. It
now has two threshhold voltages - one at 2200mV below
which no sound driver operation will begin and another
at 2000mV below which any sound driver operation that
is in progress will be aborted.
17) Fixed the backup battery code which caused its status to
oscillate between Good and Low every time you switched
off and on.
These fixes, in combination should fix CSW-5376, CSW3-682,
CSW3-1672
6) Basher
1) Added new user server function "ChangeLocale" to change
localisation dll.
Version 1.00.110
================
(Made by Graham , 5th June 1997)
1) Graham / Jonathan / Morgan / Colly
1) Fixed a bug in the Comms LDD emergency power down code.
This was causing interrupts to be enabled which then
caused the kernel irq handling routine to reenable
fiqs thus causing the fiq handler to be reentered with
subsequent death of a random nature to any user code
that might happen to be lying around within reach.
Multiple SW's hopefully.
2) Introduced interrupt protection around
TEiger::ModifyRegister8. This had been introduced into
TEiger::ModifyRegister32 a long time ago but somehow got
missed out of the 8 bit variant.
3) Added protection against rogue irqlevels passed into
Hal::RestoreIrqs();
4) Added NOPs into the following type of ARM assembler
construct:
asm("stmia lr, {r13-r14}^");
asm("add lr, lr, #8");
This now becomes:
asm("stmia lr, {r13-r14}^");
asm("mov r0, r0");
asm("add lr, lr, #8");
The ARM manual advises against using a banked register
directly after any user-bank load or store multiple
instruction.
5) Added T_IRQS test code developed by Alastair.
Version 0.01.109
================
(Made by Graham , 3rd June 1997)
1) Dennis
1) 2/6/97
Fixed SW-3795, SW-3798
Set main battery insertion time after initialising RTC
When system time is set, main battery insertion time is changed
by (new system time-old system time)
Moved initialisation of Locale data from S::Initialise() to P::Initialise()
just after Hal::Init1(). This is necessary to make sure that the home time
offset is initialised before the system time on a cold start.
2) Fixed alloc heaven problem in KS_CHN.CPP whereby a
physical channel is created and not deleted if the
corresponding logical channel creation failed.
2) Matthew
1) Changed sound and comms emergency power-down code to do their completions
with DFCs. This seems to fix the exception-type resets associated with
emergency power-downs.
2) Fixed a bug in the sound driver's write-to-thread code where the home
address of the user buffer was not being used. Spotted by Colly.
3) Fixed bug in sound driver where if an Open() failed with OOM then any
subsequent attempts to open would fail with KErrInUse. Spotted by Colly.
3) Pete
1) Fixed SW3-998: Prevents emergency power downs occuring
while servicing PC Card interrupts from generating an exception.
2) Fixed SW3-974: Machine reset inserting CF card with OOM.
Fix is low risk (FLW). One part affects code only called in OOM
situation, and the other is minor change to a destructor.
4) Graham
1) Fixed a bug in the comms logical device driver. This bug
prevented the machine from switching on sometimes in the
presence of an oscillating DSR input (like Nautilus).
2) Fixed a bug in the backup battery handling when switching
on. This again was preventing machine from turning on
occasionally. Thanks to Colly, Bill and Morgan for help
finding this one. SW3-666 (the number of the beast).
3) SW3-877. Slowed down the turning off of the display
when switching off normally - the previous behaviour
may have been damaging to the lcd panel. (UNAPPROVED)
4) SW3-997 fixed a keyboard table bug when pressing FN+B
followed by the space bar - previously gave a little
circle; now gives a circumflex. (UNAPPROVED)
5) Upped the LCD pump value to 11 from 8. SW3-354.
(UNAPPROVED)
6) Changed MachineInfo for P2 to describe the microprocessor
as an ARM 7100 rather than an ARM 7110. SW3-1028.
(UNAPPROVED).
5) Morgan
1) Fixed RTC error. Conversion between parts per 4000000
and parts per 2^24 was wrong.
Version 0.01.108
================
(Made by ---, --- May 1997)
1) Matthew
1) 22/5/97
Fixed SW-5406: Made the fall-back alarm sound slightly less offensive.
Forward and backward compatible.
2) 22/5/97
Fixed SW-4899: WINS comms pdd no longer calls the ldd's transmit ISR the
extra time.
Backward compatible, not forward if you were assume the transmit ISR
can only be called once.
3) 22/5/97
Fixed SW3-293: Moved EWSRV.DLL to base 0x42800000 so it no longer clashes
with dsound.ldd.
Forward and backward compatible.
4) 22/5/97
Fixed SW3-372: Added the '%.' label to TTime::FormatL. This gives the
locale decimal separator. Test code in T_TIME.
Backward compatible, not forward compatible - previous versions of
E32 reduced '%.' to '.' whatever the locale information was.
2) Morgan
1) 23/5/97
Fixed SW-4604: When a growing Ram Drive hits a page containing
page tables the page allocator attempts to move them. This code was
assuming all four page tables in the page were in use which is not
always the case, causing the allocator to Leave. To fix this, trapped
the Leave when an unused page table is not found in the PageDir.
Forward and Backward compatible.
2) 27/5/97
Applied the correct Uids and capitalised the names of EKern and EFile
by hand during startup. Required because neither of these processes
are loaded by the file server (which is normally responsible for doing
that).
3) 27/5/97
Added RProcess::SetType(const TUidType &aType) and test code.
Backward compatible
3) Ann
1) 27/5/97
Changed KRealFormatNoExponent to use a maximum of aMaxSigFigs digits.
Updated test code accordingly.
4) Graham
1) 28/5/97
SW3-495. Reduced the risk of E32 getting out of step with case
opening/closing
2) 28/5/97
Introduced BLDARMREL as a synonym for ARMREL in MNT.CMD and
removed the need to do MAKEWORK before building.
Version 0.01.107
================
(Made by ---, --- May 1997)
1) Graham
1) Removed MEDCRR.MAP and DATXPD3.MAP from MARM releaseables
Forward and backward compatible.
2) Removed EKERN.LIB from WINC releaseables
Forward and backward compatible.
3) Upgrade 003
Fixed SW3-282. If the 'switch off when case is closed' option was
enabled and one switched off, closed the case, then attempted to wake
the machine up using the external buttons or by asserting dsr, then
the machine would remain dead until the next warm reset.
This was fixed by reading the state of the case when coming out of
standby as well as every second while switched on.
Forward and backward compatible.
4) Upgrade 007
Removed the ability to turn on using the digitiser after an emergency
power down. This makes the behaviour consistent with 'Switch on when
case is opened'. SW-5282
Forward and backward compatible.
5) Upgrade 008
Upgraded P2 and PD digitiser drivers to include debouncing logic
(SW-874 and duplicates).
Forward and backward compatible.
6) Upgrade 009
Upgraded P2 and PD comms pdd's. These now implement the following
current consumption scheme.
RS232 drivers enabled 2mA
Cable connected + 22 mA
Ir enabled 0 mA
Ir receiving 0 mA
Ir transmitting + 35 mA
The cable is detected by either:
1) DSR high
2) Character received
Forward and backward compatible.
2) Pete
1) Upgrade 001
Fixed SW3-331. Formatting of Local Drives was being done cardSize/32
bytes at a time. This was OK on smaller CF cards but on larger ones
(eg 16M Hitachi CF) it was locking up the machine for long periods
(because F32 which is running during each sub-format is at a high
priority). Changed so that a Local Drive is formatted
Min(16K,size/32) bytes at a time.
Forward and backward compatible.
2) Upgrade 004
In addition to having the option to disable compatibility checking between a cards
Vcc level requrements and those supported by a machine, it is now possible
to disable Vcc current and Vpp level compatibility checking in
TPcCardConfig::IsMachineCompatible().
Backward compatible, not forward.
3) Upgrade 005
Fixed a problem parsing device info. tuples which fail to provide the
end of field character. TCisReader::FindReadRegion() now checks the
length of such a tuple and doesn't rely on the terminating character
being present.
Forward and backward compatible.
4) Upgrade 006
Various changes to Pc Card Serial Port PDDs:
- Added Cellular Card Phone Serial Driver (VA_NCCP.CPP) for Rack D.
- Fixed a problem with the standard Modem Card Serial Driver (EUART3.PDD)
when writing to the card at 115Kbps. The driver wasn't making full
use of the Tx FIFO and was spending too long servicing interrupts
resulting in a triple beep reset due to the watchdog timing out.
Also disabled Vpp compatibility checking in order to support the
WorldPort modem.
The full list of supported modems is now:-
- Socket I/O serial port
- Dacom Goldcard V34 + Fax
- Dacom GoldCard Global (V34+Fax)
- Hayes Optima 288
- US Robotics WorldPort
- MegaHertz XJ2288
- Trellis Datacom PC288V2
- Com1 Modem Card MC218
- Paldio Data card
- Changes to Delaware standard Modem Card Serial Driver (EUART2.PDD)
to bring it up to same standard as the Rack D driver.
None of this affects Protea P2.
Forward and backward compatible.
3) Ann
1) Upgrade 002
Fixed SW-4304, SW3-415. TRealFormat changes. Changed
Calculator mode to discard trailing zeros first and then to decide on
exponential or non-exponential format based on the number of digits
available. If the number of digits (including significant leading/trailing
zeros) when using non-exponential format would exceed aMaxSigFigs, then
exponential format would be used, so reducing to no more than aMaxSigFigs.
Fixed SW3-416. The above changes should been this situation won't
occur, but leaves space for sign now, just in case!
Also T_FLOAT test code improved and updated.
Version 0.01.106
================
(Made by Graham, 19th May 1997)
1) Graham
1) Implemented MNT VALID verb.
Forward and backward compatible.
2) Updated all version numbers to 1.0(106)
The compatibilty issues for this are quite complicated.
However, I believe these changes to be both forward and
and backward compatible.
3) Added .MAP files to MARM releasables.
Forward and backward compatible
4) Changed idle current to 38mA, backlight current to 98mA.
Forward and backward compatible
5) Upgrade 004
Changed the WINS fascia to reflect the changed order on the
application bar.
Forward and backward compatible
6) Upgrade 009
Fix which defends against the possibility that the Flash ROM will not
wake up quickly enough when coming out of standby. We jump into RAM
to execute the standby instruction. When we come out of standby we
check the ROM is reading correctly before jumping back.
Forward and backward compatible
7) Upgrade 010
SW-5179 Return an error if an attempt is made to turn the backlight
on when the main batteries are set to 'replace' and no external power
is being applied.
Forward and backward compatible
8) Upgrade 011
Reduce default on time of backlight to one minute and make it
sensitive to user activity.
Forward and backward compatible
9) Upgrade 012
SW-5319 Changed default screen contrast of PD and P2 variants
Forward and backward compatible
10) Upgrade 013
SW-3264 Changed default auto power down behaviour to
'Enabled always' and reduced the default timeout to
3 minutes.
Forward and backward compatible
11) Upgrade 014
SW-3232 Swop round FN-Q,D and FN-Q,T
Forward and backward compatible
2) Dennis
1) Changed wait states on CS1 ROM from 4 to 2 on P2 variant.
Forward and backward compatible
2) Modified ImpHal::PrepareForRepro() to leave the cache and
write buffer enabled. It is only necessary that the page
directory entries for the FLASH are marked as not
cacheable or bufferable and that the TLB and cache are
flushed, which was already the case.
Forward and backward compatible
3) Upgrade 001
Rewrote some of the TRegion member functions in ARM assembly language in an attempt to
speed up the operation of the window server, which uses these functions extensively, and
which was found to be responsible for slow operation of the machine when a large number
of applications are open. See defect reports SW-3500 and SW-4478 and the replies to them.
Forward and backward compatible
3) Ann
1) Upgrade 002
Fixed a bug in Math::Pow() (defect report SW-4624) so that
KErrOverflow errors are not incorrectly returned as KErrArgument
errors. This occured because of differencing of infinity - which is
now checked for. Updated maths test code (t_math) to test this
change fully.
Forward and backward compatible
2) Upgrade 025
Fixed SW3-317 KRealFormatNoExponent mode was not checking for
KExtraSpaceForSign flag. Now checks and changed to act accordingly.
Also added this to test code.
4) Morgan
1) Upgrade 003
Set a constant string in the SuperPage when platform initialisation
has completed. This string is checked on warm resets to validate
cold start initialisation has completed successfully at some point
in the past.
Forward and Backward compatible except for machine configuration
compatiblity. So, machine configurations may not be passed
between old and new versions of E32. You must perform a cold
reset having upgraded to the version of E32 because of this
change.
2) Upgrade 019
Fix for SW3-91 and SW3-66: Shared code chunks are Open()ed properly
in DProcess::Create(). New code chunks are named "$EXE[<Checksum>]"
and no longer have an owner.
3) Upgrade 026
Initialised TheSuperPage.iXtalError to 0 in Hal::Init1() on a cold boot
for those platforms that don't do it themselves in their variant
initialisation.
5) Matthew
1) Upgrade 005
Changed "Rings" alarm sound to be the same as those on the 3a. Thanks to Jezar
for his help with this.
Also adjusted the trailing silence in algorithmic alarms as suggested.
Fixes SW3-22.
Forward and backward compatible
2) Upgrade 006
Fixed SW3-256: Arm sound ldd no longer links to localisation dll.
Forward and backward compatible
3) Upgrade 007
Fixed bug SW3-25: Requests on logical channels by threads which did not open
that channel will now panic the rogue thread, rather than potentially crashing
the whole machine.
Added test code to T_SOUND.
Forward and backward compatible
4) Upgrade 008
Fixed bug SW3-9. Wins fixed (again) to take account of NT daylight saving settings.
Forward and backward compatible
5) Upgrade 023
Fixed SW3_315. In the sound LDDs play and record dfc functions the value of
iThread.iExit is now tested, and if it is not EExitPending then the function
returns straight away.
Forward and backward compatible
6) Pete
1) Upgrade 015
SW3-138 Change to CF card interrupt enable scheme. Currently the MTD keeps
card IREQ interrupts enabled in Etna while its open. These are normally
disabled at the card level but enabled in the card during a write operations.
When the media switch is broken or when a dodgy CF card is present, this can
resulting in a watchdog timeout due to the card permanently asserting IREQ and
not responding to the interrupt clear. This change leaves IREQ disabled
in Etna until required for the write operation.
Forward and backward compatible
2) Upgrade 016
Change only for variants with 2 sockets (ie RackD). Currently on these systems,
when a media change occurs, the PC Card controller does the following
to each socket in turn before turning off Vpc:
- Disable IREQ
- Disable Etna interface
However, because the two sockets have an individual IREQ, but share
the same Data/Address buffers, when the Etna interface is disabled on
the 1st socket, it causes the RESET signal to the 2nd to become
active. This in turn causes the 2nd socket to permanently assert IREQ
(which is now Rdy/Bsy) while its IREQ interrupt could potentially be
enabled. Result is continuous interrupts followed by watchdog
timeout.
The fix is to disable IREQs on both sockets before disabling the Etna
interface. This is done in the variant code for Rack D - ie no impact
on Protea P2.
Forward and backward compatible
3) Upgrade 017
Change to test program DRVSOAK so that it monitors the amount of
spare RAM while soak test is running.
Forward and backward compatible
4) Upgrade 027
Fixed SW3-440. Older SanDisk CF cards still sometimes timeout when
running on batteries. Increased timeout in CF card media driver from 60ms
to 70ms.
Forward and backward compatible
5) Upgrade 028
Fixed SW3-434. Allow CIS parsing functions not to reject a CIS which
has incorrect link tuples.
If a CIS chain contains no link tuples then a check is made for a link target
tuple at address 0 in common memory (as before). However, if a link
target isn't found here then we assume a normal end of the CIS chain
(rather than marking the entire CIS chain as invalid as before).
If a CIS chain contains a 'Long Link to attribute memory' tuple but no link
target tuple is found at address: (specified offset x2) then we also check for a
link target tuple at address: (specified offset x1).
Forward and backward compatible
7) William
1) Upgrade 020
Changes to test programs so that they run from CF card on top of the full
Protea ROM. T_CTRAP, T_POWR, T_UID from TBAS, the rest from TCDT. Still more changes
required to fix "Z:\Test" assumptions and the strange bug with the EIKON console.
T_CTRAP will now fail on WINS debug because it checks the stack depth.
Forward and backward compatible
2) Upgrade 021
Extend RChangeNotifier to do EChangesSystemTime: effects E32STD.H and KSRC\KS_TIM.CPP, KS_NOFTY.CPP
There is a Defect for this, but it's really an E32 Proposal trying to be noticed...
Backward compatible, not forward compatible if you take
advantage of this new feature.
3) Upgrade 022
Check in DThread::Cleanup to see if the dying thread is the one which currently owns the event hook.
If so, cause a 'graceful' kernel fault instead of an
'ungraceful' one further down the line (SW3-205).
Forward and backward compatible
4) Upgrade 024
Fixed SW3-73. Puts the first 8 characters of the Panic/Fault category into the codeAddress
and dataAddress of the last exception information (except, of course, if we are faulting
because of an exception...)
Forward and backward compatible
8) Geert
1) Upgrade 029
Fully source and binary compatible. Not link compatible, however. See below for details.
Fixed SW3-11, replacing the following EUSER.DLL exported functions with binary equivalents:
CArrayFix<TAny>::CArrayFix(TBufRep aRep,TInt aRecordLength,TInt aGranularity);
CArrayFix<TAny>::~CArrayFix();
CArrayFixFlat<TAny>::CArrayFixFlat(TInt aRecordLength,TInt aGranularity);
CArrayFixFlat<TAny>::~CArrayFixFlat();
CArrayFixSeg<TAny>::CArrayFixSeg(TInt aRecordLength,TInt aGranularity);
CArrayFixSeg<TAny>::~CArrayFixSeg();
CArrayVar<TAny>::CArrayVar(TBufRep aRep,TInt aGranularity);
CArrayVar<TAny>::~CArrayVar();
CArrayPak<TAny>::CArrayPak(TBufRep aRep,TInt aGranularity);
CArrayPak<TAny>::~CArrayPak();
All CArrayXxx<TAny> stock instances acquire inline ctors just like the template ones.
If you use any of these classes then to be able to link against the new EUSER.LIB
will require re-compilation.
A clean build should be sufficient.
2) Upgrade 030
Entirely backward compatible. Forward compatible for all software that doesn't use the new service.
And additional forward incompatible change now allows the element just past the array to be addressed
using CArrayXxx::End().
Fixed SW3-374, adding new exported function
TAny* CArrayFixBase::Back(TInt anIndex) const;
as well as inline wrappers to CArrayFix<T> and CArrayFix<TAny>.
These functions provide functionality equivalent to CBufBase::BackPtr(), being CArrayFixXxx::End()
counterparts for fast _backward_ iteration.
Also introduced modifiable overloads of End() inline wrappers and relaxed index range checks for
CArrayFixXxx::End() as well as Back().
9) Jonathan
1) Upgrade 031
Fixes SW3-334
Debug::SetBreakpoint only allowed breakpoints to be set at 0x2xxxxxxx (and at
0x5xxxxxxx in debug releases). Eikon apps get loaded into memory between
0x9000~ and 0xFFFF~.
Debug::SetBreakpoint allows breakpoints between 0x9000~ and 0xFFFF~.
No API change. Doesn't depend or tread on any previous upgrade.
Forward and backward compatible
Version 0.01.105
================
(Made by Pete, 8th May 1997)
1) Dennis
1) Modified the scheduler to set machine current consumption to either
running or idle current depending on whether the null thread is
being scheduled.
2) Added functions Custom::BacklightCurrentInMilliAmps() and
ImpHal::BacklightCurrentInMilliAmps and code to include the
backlight current in K::TotalCurrentMilliAmps when it is on.
3) Fixed a problem with average battery current calculation - the function
was using a hard-coded tick rate of 10 ticks per second.
4) Changed function DLogicalChannel::SetCurrentConsumptionInMilliAmps from
protected to public since in practice it is always the PDD which calls it.
5) Modified the sound and COM1 PDDs to set the current consumption according
to the device state.
2) Morgan
1) Digitiser calibrated from values in E-squared Prom on a Cold Start.
2) Calibration preserved over a warm reset.
3) Plugged in crystal error and machine unique Id values from the E-squared.
4) DPlatProcess destructor closes the process code chunk, and Create() adds
newly created code chunks to the list of Kernel chunks.
5) RLoader::LoadProcess() Kill()s the new process on a failed load.
3) William
1) Reorganise CDeltaTimer creation to fix SW-4030
2) Remove TDblQueLInkBase::EnQue() assertion, to fix SW-4991
3) Reset auto switchoff timeout when an absolute timer completes, to fix SW-4870
4) Ann
1) Fixed bug SW-4351 in Math::Mod(). Now returns KErrTotalLossOfPrecision
if an accurate answer cannot be given.
2) Reorganised maths test code so it now builds for ARM.
5) Andrew 1) Fixed bug SW-4180. SetReserveL(TInt) is now available only
for CArrayFixFlat<T>, CArrayFixFlat<TAny> and CArrayPtrFlat<T>.
The parameter is new the reserved size of the array, not the
reserved expansion space.
6) Pete 1) TPcCardSocket::SetSocketStatus() made virtual function.
2) Added the inline function
TPcCardSocket::EventCallBacksRequested(TPccdEvent anEvent).
Used to determine if there are any clients expecting notification of
a particular PC Card event.
3) CROM Media Driver Caps() no longer sets the drive attributes as
KDriveAttRom.
4) Fixed problem parsing Configuration table entry tuples where the
last two entries both have the same configuration entry value. Prior to
this, only the first of the two was reported.
5) ATA Media Driver now leaves card interrupts enabled in the PC Card
Controller h/w, and enables/disables these as required on the card. This
is quicker than the previous scheme where it was continuously enabling
and disabling interrupts in controller h/w on each Write() request.
6) Media Driver Open() failures due to media change now only return
KErrNotReady rather than any other error value.
7) ATA Media Driver now verifies that a partition is a DOS partition
(extended DOS partitions not supported).
8) ATA Media Driver now uses Pulse mode interrupts where possible.
Previously it always used Level mode interrupts.
9) Change to ATA Media Driver - for write requests
which straddle a sector boundary and require prior reading of two
consecutive sectors, the read is now performed with a single read
command (of two sectors) rather than two reads of one sector.
10) Default attribute memory access speed for 3.3V
socket is 600ns rather than 300ns (as per PC Card Spec.).
11) Withered Custom::DriveName() and Custom::PcCardSocketName() in
custom dll.
12) Prevented DPrimaryMedia queueing same DFC twice.
13) Introduce Media Driver Interface version number.
14) Made media driver current consumption values more realistic.
7) Jonathan
1) The Debug class won't let the user insert breakpoints or
single-step into ROM code before the aDebugLimit argument to
Debug::Open. Gdbstub sets aDebugLimit to its own location in
ROM, thus preventing breakpoints/stepping into code before it in
ROM (including EUser, EKern etc) which might otherwise break.
2) The Debug class ignores the user-supplied aDebugLimit in Release
builds and prevents setting of breakpoints/single-stepping
anywhere in the ROM.
3) Binary incompatibility (affects gdbstub & test code, doesn't
affect RDebug::Printf):
Debugger functions in the RDebug & Debug classes changed to use
thread Ids instead of opaque DThread pointers. Components that
call RDebug::ReadMemory() or RDebug::WriteMemory() should pass in
RThread().Id() as the first argument to these functions to retain
their current functionality.
4) New DThread* Kern::ThreadFromId(TThreadId) for use by Debug
class. Also changed S::ThreadOpen(... TThreadId, ...) to use it.
8) Matthew
1) Fixed SW-3783 - by default, the comms driver now uses descriptor
MaxLength() rather than Length() for reads.
Note: This fix has meant a change to the inline function RDevComm::Read(),
so anyone using this function should recompile with the new E32. You
know who you are.
2) Fixed bug in comms driver so that it no longer crashes if you
request that it writes beyond the end of a descriptor.
3) Stopped WINS sound pdd from gurgling when you do a PlaySineWave().
4) Moved DTMF volume information from sound LDD into the PDDs, since
it depends on the frequency response of the hardware.
5) Tiny amount of fiddling with algorithmic alarm sounds.
6) Made the __WINS_UID() macro expand in WINC builds, implementing the E32
proposal.
7) Removed the EChangesAll enum from E32STD.H since if it used it may break
forwards compatability. This should only effect BAFL.
8) Added a User::SetCurrencySymbol() function for setting the system-wide
currency symbol.
9) Graham
1) Added German keyboard table which now gets
released as CAKDP2.GE
2) Released IMPORT_C from TInt64A functions. These
were not being exported anyway.
3) Exported RLibrary::LoadRomLibrary on EPOC
platforms
4) Fixed update of battery statistics when the
main batteries are changed (SW-5096, SW-4228).
5) Fixed update of main and backup battery statuses
when switching on (SW-3401, SW-4479).
6) Changed UK, US, and German keyboard tables to give
the multiplication and division signs when the
appropriate keystrokes are made.
7) Shortened the beeps for Cold Start, Warm Start,
and Kernel Fault.
10) Jal
1) Added build infrastructure for ELOCL.GE
(the german localisation dll).
Version 0.01.104
================
(Made by William, 2nd May 1997)
1) William
1) Removed the TRAPD() from DThread::RequestComplete, which still seems
to cause lots of E32USER-CBase 71 and 63 panics when used in the
harsh environment of real test roms
2) Remove reference to GateFunction in EGATE.DEF to fix the T_DUID.DLL test
3) Add extra test cases to TCDT\T_THREAD.CPP
4) Add missing XCUST*.DEF files to BMARM\LI.PRJ
Version 0.01.103
================
(Made by Morgan, 1st May 1997)
1) Graham
1) Fixed a problem with the code which looks for both shift
keys when switching on after a warm reset in order to
change it into a cold reset.
2) Fixed a problem with constructing the encrypted password
in the super page.
Version 0.01.102
================
(Made by Morgan, 30th April 1997)
1) Pete
1) Change to PC Card Serial Driver (EUART3.PDD) for Rack D. Added
followers for 16550 registers IER,LCR,MCR rather than relying on
them being read/write registers. Tested this driver using
COMMS(033) app. Sent/received files at various baud rates up to
57600 (didn't test at 115K) using XMODEM without any problems. The
above driver works with the following PC Card Serial Ports/Modems:
- Socket I/O serial port
- Dacom Goldcard V34 + Fax
- Hayes Optima 288
2) Now possible for ATA media driver to return the following errors
on read or write command fails:
KErrCorrupt - Bad block detected / sector ID error.
KErrWrite - Write fault.
KErrTimedOut - Timeout waiting for ATA controller to negate
BSY bit.
KErrLocked - Timeout waiting for ATA controller to assert
RDY bit).
KErrGeneral - Protocol error (wrong state of DRQ bit
detected).
KErrUnknown - General ATA controller error.
KErrCancel - Command aborted
KErrDied - Uncorrectable error encountered.
Prior to this, all the above conditions resulted in KErrTimedOut.
(All of these get translated as before by F32 but the extra
information from the driver is useful).
3) Format command now implemented using ATA WriteSectors command rather
than FormatTrack. This is because there seem to be a variety of
implementations of the FormatTrack command and also it can take a significant
time to complete (>200ms) on some cards which require CHS addressing.
4) Changes to various trace o/ps to prevent system watchdog timeouts on media
changes with tracing on.
2) William
1) Use Win32 IsBadReadPtr/IsBadWritePtr functions to provide better emulation of
EPOC32 kernel exception handling (should allow us to handle the access violations
that the kernel has contingency plans for, even under the MSDEV debugger).
2) Fix SW-1799 by preventing the Win32 thread priority from being raised too high
3) Fix SW-???? by ignoring the KNotifyIfDie flag when WINS threads die (as per EPOC32).
4) Trace the Win32 Thread ID and the WINS thread name in the debug window (WINS debug builds)
5) Fix SW-4346 by making CalcChunkHeapCompression wary of corrupt heaps and wrapping the
invocation from ChunkCompressAll in a suitable exception trap.
6) Arrange to keep iHandles valid (but empty) after thread cleanup
7) Fix SW-3718 by making ChangeNotifier handles thread-relative.
8) Prevent WINS RProcess::SetPriority from changing the Win32 process priority (SW-1799)
9) Limit the size of a heap cell to 1 Gigabyte (SW-4528)
10) Fix SW-4389 by ignoring UserSvr::InitRegisterCallback calls after initial bootstrap.
11) Fix SW-3527 by ensuring that the SYSTEM.INI screenwidth is rounded up to a multiple of 16.
12) Fix T_QUE, T_DLL1, T_DLL2 and T_SVR2 test failures.
3) Graham
1) Fixed WINS problem with expanded MachineInfo
structure.
4) Bruce
1) Two field dates are now accepted for all locales. Fixed year 2000 bug.
Removed hard-coded 'am'/'pm' and replaced these with data
retrieved from the localisation dll.
5) Ann
1) Fixed bug in TLex8::ScndigAfterPoint() (SW-4304) - now reads in first 18 significant
digits rather than just first 18 digits.
2) Fixed bug in TLex8::Val() (SW-4355) - overflow in some cases was being returned as
positive regardless of actual sign.
Version 0.01.101
================
(Made by Graham, 29rd April 1997)
1) Graham
1) SW-1921 Fixed the occasional load click by disabling interrupts while creating the click.
2) Added localised keyboard tables to the P2 build
system and created CAKDP2.UK and CAKDP2.US. CAKDP2.DLL
remains and gives a layout consistent with the keyboards
currently on our Limes.
3) Change the rombuilding system to accept a localisation
parameter. So you may use "rom rel p2 uk". If you specify
just "rom rel p2", you get what you always used to.
4) SW-3330 Fixed repeating keys when entering 'Raw'
mode in the text window server while a key is depressed.
5) SW-3837 introduced ELangInternationalFrench
6) SW-4181 allocated WINS DLL address for MEDCRM.PDD
7) Solved problem with watchdog timer going off sometimes
when coming out of standby.
8) Changed Hal information names in preparation for the
final ROM.
9) Changed supply voltage information so that it
never returns a voltage above the stated maximum
for that battery and returns zero millivolts if
the battery status is EZero. Changed the maximum
voltage for the main battery to 3100mV and for the
backup battery to 3200mV. SW-4194 SW-4237.
10) Implemented the reading of ADC channel 7 on a cold
boot in order to detect when test department boot
to final test is required.
11) SW-3563 Displaying years >2000 as 2 digits in
abbreviated form.
12) SW-4339 Set CurrencyNegativeInBrackets to EFalse
in both the US and UK localisation dlls.
13) Added structure for UserHal::CpuInfo(TDes8& aInfo)
14) Added UserSvr::WsRegisterSwitchOnScreenHandling().
If a window server wants to take control of
turning on the screen, then it should call this
function with ETrue and may then call
UserSvr::WsSwitchOnScreen(). It may relinquish
control back to the Os by calling the register
function again with EFalse.
15) Added the functions:
UserHal::SaveXYInputCalibration();
UserHal::RestoreXYInputCalibration(aType);
Restore takes an argument that may be EFactory (to
restore the factory set calibration) or ESaved to
restore the previously saved calibration.
16) Added the following to the Machine Information
structure:
TInfoName iProcessorName
TInt iProcessorClockInKHz
TInt iSpeedFactor
TInt iMaximumDisplayColors
2) William
1) Added WINS SYSTEM.INI support for "MegabytesOfFreeMemory" which also turns on the
mechanism for limiting the total amount of memory which WINS can allocate.
2) Number some more enumerated types associated with panics and faults. Note that this
includes removing #ifdef __XCON in KPWINS\KP_STD.H so that the KPWINS platform fault
numbers will change: prior permission was obtained from the BC police.
3) In DEBUG builds, change RHeap::Free to fill the released block with 0xDE rather than 0
4) Add __ASSERT_DEBUG to catch double insertion of a TDblQueLink (and fix two places in
the Base which weren't constructing a link when creating an object).
5) Fix SW-3707 by not panicing unnecessarily in DPlatProcess::AllocateDataSectionBase()
6) Fix SW-2104 in DTimer::Cancel(), by not calling RequestComplete on a dead thread, and
not doing the expensive timer scan in DThread::Cleanup().
7) Fix SW-1185 by interpreting EKeyIncContrast to mean "bigger number in SetContrast" in the
text window server.
3) Morgan
1) Preserved the password and its enabled state over a warm reset.
4) Matthew
1) Added PlaySineWave() function to RDevSound. Also added an iMaxSineWaveFrequency
member variable to the sound caps structure. Frequencies are in Hz.
2) Changed sound LDD so that it gets the alarm name via the kernel's
locale-message-text service. LS_SND.CPP and K32LSND.H have thus been scrapped.
3) Fixed bug in sound LDD which caused a kernel panic if FlushRecordBuffer() was
called after a record request had failed with bad power.
Version 0.01.100
================
(Made by Graham, 23rd April 1997)
1) Dennis
1) Modified ARM boot code to automatically work out the size and bus width of
the ROMs connected to CS0 and CS1 chip selects. This information is stored
in the super page in the iRomConfig entries. Both banks of ROM are then mapped
to consecutive linear addresses.
2) Added a new function Hal::PrepareForRepro, which re-maps all the ROM in the
machine. This is to make sure repro works correctly even if ROM page shadowing
is in use. This function uses the information stored in the iRomConfig entries
in the super page to work out which ROM to map and how to map it.
3) Removed ROM mapping calls from VA_HW.CPP for all variants, and added code to set
up the ROM speed and type. For P2 variant, added code to set up the ROM size
for CS1 and the total ROM size. This is required to ensure that repro will work
correctly even if the CS1 ROM is initially blank.
4) Added code to SF_MAIN.CPP to load an LDD (BOOT.LDD) from Z: immediately prior to
loading the window server. This allows any shadowing of the ROM for bug fixes to
be done.
5) Added a new function UserHal::RomInfo to read the iRomConfig entries from the
super page. Updated T_INF.CPP to display this information.
6) Modified ARM boot code to allocate 1K for each page table instead of 4K as it
does at the moment. Also use page tables 6 onwards for ROM mapping instead of
8 onwards, since page tables 6 and 7 are unused at the moment.
This saves 44K RAM for the standard Protea configuration.
7) Modified ARM boot code to make checking the RAM configuration non-destructive.
2) Graham
1) SW-3765 Export TReal96::IsZero by number instead of by name.
2) SW-3760 Removed E32VIRT.H from the release
3) SW-3759 Removed temporary __ARRAY_NO_PTRS__ from E32DEF.H
and appropriate function definitions.
4) SW-3058 Removed __DECLARE_DLL_UID().
5) SW-3480 Removed default Southern daylight savings
time from the UK localisation DLL.
6) SW-3565 Implemented ~ as FN+J on Lime keyboards
7) SW-3564 Implemented the dial key as Fn+Menu on a
Lime and as F3 on WINS. This comes through as
EStdKeyDial and EKeyDIal (in E32KEYS.H).
3) Morgan
1) Moved the locale configuration into the SuperPage to preserve it
over a warm-reset.
2) Implemented TDes::TrimAll();
3) Checked Uid[1] in S::PhysicalDeviceLoad and S::LogicalDeviceLoad.
Added WINS Uids to the device drivers in the Base.
4) Cold reset is now: Warm-reset followed by LeftShift+RightShift+On
to make it harder to do by accident.
5) Fixed K::TickCounter synchronisation after standby, and initialised
iLastLock for locked timers.
4) Matthew
1) Fixed SW-2855 - the TRegion::Sort() and CArrayXxxBase::Sort() functions
have been changed from having no return value to returning TInts, they
will return KErrGeneral if there is a stack overflow.
2) Fixed blitting bug in eiger text window server which caused blocks of
screen to be cleared.
3) Fixed bug in sound driver which made it crash when given a zero-length
sample.
5) Jal
1) Added TLocaleMessageText to E32SVR.H
6) Alastair
1) Changed e32\wsrc\ws_main.cpp so that the eikon shell is not loaded
if the machine is in test department boot mode.
2) Created new project e32\etest producing an executable which will be
loaded instead of ewsrv.exe if the machine is in test department
boot mode. This executable will attempt to load ewsrv.exe and
final.exe from the root directory of a cf card containing euser.dll,
edisp.dll and econs.dll from the base in directory D:\system\libs.
If this attempt fails, etest.exe will try to load elink.exe from
Z:\system\libs which will open the remote link so that the machine
can be booted down the serial port. If this fails etest.exe will
attempt to boot the machine up normally.
7) Pete
1) Fixed 'Emergency power down with CF card powered results in cold
reset' (SW-3620). This was due to QuickEmergencyStandby() not
disabling the Etna's wait state controller properly.
2) Force ATA and CROM media drivers on ARM to only return KErrNotReady
rather than any other error value when a request is interrupted by a
media change.
3) Added the function CardIsReady() to class DPcCardCntrl. This should
be used periodically while using the PC Card Controller to check that
a media change hasn't occured. The new function is a quicker alternative
to the function CardIsReadyAndVerified(). The later is now only used once
at the start of each interface with the controller.
4) Requests to Write or Format the CROM card now return KErrAccessDenied
rather than KErrNotSupported.
5) PC Card Controller now calls P::ResetAutoSwitchOffTimer() on each
call off RPccdWindow::SetupChunkHw() to stop the machine going into
standby in the middle of a long write to a CF card etc.
Version 0.01.099
================
(Made by Graham, 18th April 1997)
1) William
1) Fix SW-3331 by ignoring Undertakers owned by threads which have themselves already died
2) Tweak UPWINS\BLD.CMD to bootstrap ECONS.LIB more reliably
3) Arrange for absolute timers to complete with KErrOverflow for times too far in the future
instead of treating them as times in the past (starts to fix SW-3566)
2) Graham 1) Fixed leaving without a trap harness. This was
calling a slow executive function to panic the
thread inside a fast executive trap function.
Moved the call to panic to the user side.
2) Added V32ARMP2.H to INCK release.
3) Fixed a problem with 098 which meant that
EKERN.DLL was linking to ELOCL.US rather
than ELOCL.DLL (In WINS).
4) Included device driver def files in the INCK
release.
3) Matthew
1) Fixed Sound device driver's DTMF tone generating
interrupt handler.
4) Ann
1) Fixed doCalculator() function so that KRealFormatCalculator mode displays in no exponent
mode only if full precision may be seen in this mode or if no mor precision will be available
in exponent mode.
2) Fixed doNoExponent() function so that KRealFormatNoExponent mode reduces the number of
significant figures used if the given no won't fit. Now only raises an error if value is too
big or too small to fit into the given width.
Version 0.01.098
================
(Made by Graham, 16 April 1997)
Note: This release is neither 100% binary compatible with 097, nor 100% source compatible.
The binary incompatibility is to do with UID allocation changes, the source incompatibility
with the correction of "overriden".
The UID changes are such that narrow release DLLs should work as they are. Other targets need
tweaking, which maktran 063 will do for you. See below for details.
1) GrahamA
IMPLEMENTATION OF UNICODE CHARACTER CLASSIFICATION, CONVERSION AND COLLATION
NEW FILES
e32\inc\collate.h
header for Unicode collation system
e32\inc\unicode.h
header for Unicode character classification system
e32\unicode\collate.cpp
Unicode collation system
e32\unicode\unicode.cpp
Unicode character classification and attribute retrieval
e32\unicode\unitable.cpp
tables of Unicode character attributes; this file is generated by the READTYPE utility from unidata2.txt.
CHANGED FILES
e32\bmarm\elocl.mak:
e32\bmisa\elocl.mak:
e32\bmx86\elocl.mak:
e32\bwins\elocl.mak:
added ls_unic.cpp to list of source files
e32\bmarm\eloclu.def:
e32\bmarm\eloclud.def
e32\bmisa\eloclu.def:
e32\bmisa\eloclud.def
e32\bmx86\eloclu.def
e32\bwins\eloclu.def
removed UpperTable, LowerTable, FoldTable, CollTable, TypeTable; added CharSet.
(where relevant) added ls_unic.cpp to list of source files
e32\bmarm\euser.def:
e32\bmarm\euser.frz:
e32\bmarm\euserd.def:
e32\bmarm\euserd.frz:
e32\bmisa\euser.def:
e32\bmisa\euser.frz:
e32\bmisa\euserd.def:
e32\bmisa\euserd.frz:
e32\bmx86\euser.def:
e32\bmx86\euser.frz:
e32\bwins\euser.def:
e32\bwins\euser.frz:
added TChar::GetUpperCase, TChar::GetLowerCase
e32\bmarm\euser.mak:
e32\bmisa\euser.mak:
e32\bmx86\euser.mak:
e32\bwins\euser.mak:
added collate.cpp, unicode.cpp and unitable.cpp to list of source files, and collate.h and unicode.h
to dependencies where needed
e32\bmarm\euseru.def:
e32\bmarm\euseru.frz:
e32\bmarm\euserud.def:
e32\bmarm\euserud.frz:
e32\bmisa\euseru.def:
e32\bmisa\euseru.frz:
e32\bmisa\euserud.def:
e32\bmisa\euserud.frz:
e32\bmx86\euseru.def:
e32\bmx86\euseru.frz:
e32\bwins\euseru.def:
e32\bwins\euseru.frz:
added TChar::Compose, TChar::Decompose, User::Fold (new overload), TUnicode::Fold,
TChar::GetBDCategory, TChar::GetCJKWidth, TChar::GetCategory, TUnicode::GetCategory,
TChar::GetCombiningClass, TChar::GetInfo, TCHar::GetLowerCase, TUnicode::GetLowerCase,
TChar::GetNumericValue, TChar::GetTitleCase, TChar::GetUpperCase, TUnicode::GetUpperCase,
TChar::IsAssigned, TChar::IsMirrored, TChar::IsTitle, User::TitleCase,
TChar::TranslateFromUnicode,TChar::TranslateFromUnicode.
changed entry for RLogicalChannel::DoCreate to suit new signature
e32\dsound\d_sound.cpp
changed an erroneous use of TChar::Fold to TChar::UpperCase
e32\inc\d32ftim.inl
corrected penultimate arg to RLogicalChannel::DoCreate to suit new type (const TDesC8 *, not const TDesC 8).
e32\inc\e32std.h
added Unicode functions and constants to TChar class
added Unicode functions to User class
e32\inc\e32std.inl
added inline definitions of TChar::Fold and TChar::TitleCase
e32\inc\k32std.h
added declarations for ExecHandler::GetLocaleCharSet, Locl::CharSet, K::CharSet
e32\inc\u32std.h
added definition of LCharSet and removed character type bits (__U, __L, etc.), from Unicode build
defined EExecGetLocaleCharSet and DExecGetLocaleCharSet
added declaration for Exec::GetLocaleCharSet
e32\kearm\ke_int.cpp
e32\keisa\ke_int.cpp
e32\kex86\ke_int.cpp
e32\kpwins\kp_utl.cpp
added ExecHandler::GetLocaleCharSet to the dispatch table
e32\ksrc\ks_dat.cpp
in the Unicode build, removed K::TypeTable, K::UpperTable, K::LowerTable, K::FoldTable and K::CollTable
and added K::CharSet
e32\ksrc\ks_exec.cpp
added Unicode functionality to existing functions; added ExecHandler::GetLocaleCharSet
e32\ksrc\ks_ini.cpp
in the Unicode build, removed initialisation of K::TypeTable, K::UpperTable, K::LowerTable,
K::FoldTable and K::CollTable and added initialisation of K::CharSet
e32\lsrc\ls_lat1.cpp
in the Unicode build, used preprocessor directives to remove unused material
e32\lsrc\ls_table.cpp
added preprocessor directives to select Unicode-build or Ascii-build material as appropriate
e32\lsrc\ls_std.h
in the Unicode build, removed the LAlphabet class and added the TheCharSet object
e32\tbas\t_key.cpp
e32\t_cdt\t_buf.cpp
collation tests now work with new Unicode stuff
e32\t_cdt\t_char.cpp
now works with new Unicode stuff; and in the Unicode build tests character classification and
my new collation system
e32\tlocale\t_chset.cpp
now works with new Unicode stuff
e32\ucdt\uc_des.cpp
changed two erroneous uses of TCharF to TCharUC
e32\ucdt\uc_des16.cpp
e32\ucdt\uc_des8.cpp
Capitalize and CopyCP convert first letter to title case, not upper case, in the Unicode build
e32\ucdt\uc_exec.cpp
character classification and conversion functions (TChar::IsUpper, etc.) now work for all
Unicode values in the Unicode build; added new Unicode-only functions like TChar::IsMirrored
and TChar::GetNumericValue
e32\ucdt\uc_func.cpp
the Unicode versions of Mem::CompareC now use the Unicode locale-specific string-based collation
system implemented by the TCollate class in the new source file collate.cpp
e32\ucdt\uc_ksvr.cpp
changed type of penultimate arg to RLogicalChannel::DoCreate from const TDesC* to const TDesC8*
so that it works in the Unicode build: this caused changes to exported function signatures in the
.def and .frz files
e32\ucdt\uc_lex16.cpp
e32\ucdt\uc_lex8.cpp
changed two erroneous uses of TChar::Fold to TChar::UpperCase: folding isn't guaranteed to make
characters upper case, and doesn't in the Unicode build, but UpperCase is
e32\upmarm\up_exec.cpp
e32\upmx86\up_exec.cpp
e32\upwins\up_exec.cpp
added Exec::GetLocaleCharSet
e32\upmarm\up_lib.cpp
e32\upmx86\up_lib.cpp
changed an erroneous use of CompareC to CompareF
2) William
1) Used Win32 InterlockedIncrement/InterlockedDecrement to implement WINS LockedInc and LockedDec
2) Implemented first-cut exception->leave translation for WINS (as per MARM)
3) Added exception trapping to DThread::RequestComplete, to fix SW-2274
4) Arranged not to complete requests if the requesting thread has already died
5) Enhance T_HEAP test to include truly concurrent access to shared heaps
6) Fix incorrect semaphore count on default heaps (as shown by the revised T_HEAP!)
7) Correct implementation of DThread::GetRamSizes for shared heaps, to fix SW-2671
8) Fix WINS implementation of RDebug::Print, which was assuming a zero-terminated string
9) Add T_REASON, a utility which loops printing the restart reason using RDebug::Print.
This isn't a test program as such, but can be put on a CF card as \System\libs\wserv.exe
to help debug endless restarting.
10) Improve DSession destructor to dequeue any messages which are marked EDelivered, in the
hope of fixing SW-1407 and friends.
11) Implement scheme to orphan kernel CObjects when their owner goes away, to fix SW-1665 (again!)
3) Dennis
1) Modified prefetch abort, data abort and undefined instruction exception
handlers in ke_int.cpp to save correct context if exception occurs in
supervisor mode.
4) Matthew
1) Fixed SW-2408 (problems with signals when you come out af standby).
2) Fixed SW-3293 (cancelling fallback alarm causes panic).
3) Fixed bug with emergency power down during fallback sound.
4) Increased DTMF buffer so if can now cope with 32 characters.
5) Made kernel noises (keyclicks, buzzes and sound driver activity) obey
the state of the sound info. KErrAccessDenied is returned when sound
cannot be played. Fixes SW-2725.
6) Yet more fiddling with algorithmic alarm sounds - fixed nasty distortion
occuring with chimes.
7) Fixed potential memory leaks in CSecurityBase and CConsoleBase.
8) Fixed TTime::RoundUpToNextMinute() and TTime::operator+(TTimeIntervalMonth)
so they now handle negative values correctly.
9) Fixed SW-1974 (Switching on IrDA gives 0xff in Rx buffer).
10) Changed comms PDD so that RS232 hardware is not enabled when IrDA is in use.
11) Changed "KeyClickOverriden" to "KeyClickOverridden" in lots of places.
12) Fixed SW-3097 (Wins Hal switch statement missing a break after TickPeriod).
5) Graham
1) Fixed (with help from Morgan) booting up into a text
shell on a normal eikon-based machine by placing
the appropriate components (EWSRV.EXE EUSER.DLL ECONS.DLL
EDISP.DLL ESHELL.EXE) in the \system\libs directory on
a CF card.
2) Fixed SW-3163 (Alarms when the case is closed and
'switch off when case is closed' is enabled).
3) Fixed SW-3091 (Auto switch of in the presence of
'switch on when case opens').
4) Fixed SW-2893 (UserHal::MaxDisplayContrast(TInt&) in
WINS).
6) Geert
1) Removed the encoding of build variants in uid[0] of E32 images. Introduced
differentiation between EXEs and DLLs in uid[0]. EXEs have a uid[0] of
KExecutableImageUid [0x1000007a], DLLs come with one of KDynamicLibraryUid
[0x10000079]; ie, DLLs don't change for narrow release builds, EXEs get the
value previously used for narrow debug builds. EXEs won't load unless they
have their uid[0] changed.
2) Changed lots of other private and public UIDs, taking care to preserve
compatibility for ARM builds. Unless you release an EXE you're alright, and
even EXEs can be fixed at rom build time.
UIDs of interest can be found in a bare <e32uid.h>, which, in addition to
KExecutableImageUid and KDynamicLibraryUid contains KLogicalDeviceDriverUid
and KPhysicalDeviceDriverUid--uid[1] values for device drivers--and unrelated
KMachineConfigurationUid.
3) Removed the second PREP stage from the rom build process.
7) Morgan
1) Fixed a chunk problem with RAM loading the same process twice.
8) Pete
1) Fixed 'Panic in DPlatMediaChange::TickService()' in WINS
(SW-1962). Now ignore further media change events (F5 keydown)
while the door state is open (as per ARM).
2) Fixed problems parsing the CIS of Multifunction PC Cards.
3) Temporarily fixed 'Occasional Write() / Format()
timeouts when accessing CF card' (SW-3311) by increasing the
WaitForNotBusy() watch dog in the CF media driver from 40mS to 60mS.
4) Door close event in WINS (F5 keyup) now processed
when the machine is in standby.
5) CRom(Prog) media driver (MEDCRR.PDD) now
calculated the CRom size by attempting to read the intelligent ID
from each flash device. This driver now has 'high' priority to allow
it to open in preference to the normal CRom media driver.
Version 0.01.097
================
(Made by ???, ??? April 1997)
1) MarkT
1) Added Early write completion to serial driver - D_COMM.CPP.
To enable set the flag KConfigWriteBufferedComplete in the
iHandshake of TCommConfigV01 and writes will be completed when
they are in the transmit buffer as oppose to waiting until they are
in the hardware. To flush data from the transmit buffer either
use Write(0), (Write(0) will not complete until transmit buffer
is empty), or unset KConfigWriteBufferedComplete and do a
write as normal.
2) Pete 1) Change to CF media driver (MEDATA.PDD) so that this reverts to CHS
addressing if the LBA disk size is found to be invalid. Allows us to
work with Epson PC ATA card.
2) Fixed a problem such that the second socket on rack D (E:) wasn't
properly being reset following a media change (DPcCardSocket::Reset1()
wasn't being called) - only applies to racks modified for
VPC control via the CHRGEN signal.
3) Pc Card Controller now fully supports Memory Space Description fields
when parsing Configuration Table Entry tuples.
4) Pc Card Controllers attribute memory chunk increased from 8K to 64K.
5) Added the Delaware variant (VARMPG).
6) Added PC Card Serial Driver (EUART3.PDD) for Rack D - ie providing a third
serial port on Rack D when PC Card Modem or Serial card is inserted into the PC
Card Socket (68pin socket). To use it you have to switch the '3.3V/5V' switch to
the 5V position (LEFT) and apply a 5V/500mA supply to the '+5V'pin next to this
switch. Unfortunately, without a modification to Rack D it is not possible to
turn this socket on/off under s/w control. The driver assumes the card is
permanently powered and if the rack goes into standby (or the media change switch
is operated) then the card is no longer useable.
This driver has only received limited testing:-
- With a Serial PC Card it passes T_SERIAL up to 115K baud as long as the power-off
tests are disabled and the serial port FIFO is enabled. (Passes T_SERIAL up to
19200baud with FIFO disabled).
- Dacom V34 PC Card modem responds to an AT<CR> with T_TERM.
7) Change to CROM media driver so that the page latch
is reset after each access. This ensures that the page containing the
cards CIS is always selected at the start of each access.
8) Fixed problem where DPccdCntrlInterface::DoNotifyChange was adding the same TPccdCallBack
to two event queues. This resulted in the wrong event callback being
called on media change. This eventually lead to the situation where
the DMediaChange Dfc wasn't queued and the door close event was
missed. Any subsequent access to the CF card returned KErrNotReady.
(Fixes SW-2557)
3) William
1) Fixed HeapOffset/ChunkCompressAll interactions to ensure heap safety: the HeapOffset
is now set by RHeap::ChunkHeapCreated after the RHeap has been fully created, and
ChunkCompressAll now respects the RHeap critical sections.
2) Add "DebugMask nnn" facility to WINS SYSTEM.INI (sadly you have to specify the
bitmask as a decimal number, but it's still useful).
3) Start adding explicit numbering to some of the panic enumerated types, in particular
TBasePanic, TCdtPanic and TExcType.
4) Implement CConsoleTextWin::SetTitle
5) Add T_HCOMP.CPP heap compressing program used to cause ChunkCompressAll problems.
6) Add __KTRACE_ANY which is similar to the previous version of __KTRACE_OPT
4) Graham
1) Made pointer click volume default to soft (on a cold boot)
2) Removed Steve Townsend's change to TRegn::Clear()
3) Removed the leading 'V' from version names
4) Changed the fold and collate tables of the ISO
LATIN1 character set so that 'a with a ring above
it' and 'ae combined into one character' both
fold to an 'a' and so that 'o with a slash through
it' folds to an 'o'.
5) Froze the complete kernel interface on all builds
except WINC.
6) Published CConsoleBase interface def files in
CONSWINS.FRZ, CONSMARM.FRZ, and CONSMISA.FRZ.
These are released in the INCC zip file so they
will end up in \EPOC32\INCLUDE
5) Morgan
1) Released E32 as PETRANned components, complete with Uids.
2) Removed RLibrary::UidL() and RLibrary::Gate() from the API
3) Introduced TUidType RLibrary::Type() and
TUidType RProcess::Type().
4) TLoaderInfo has changed, so this E32 and the new F32 must be
used as a pair.
6) Matthew
1) Fixed comms drivers so they return the correct Ir Capabilities
(KCapsSIR115kbps on Eiger).
2) Fixed bug in WINS sound pdd which meant that sometimes cancelling
a play request would only finish after the sound had finished playing
anyway.
3) Fixed bug in sound LDD which meant that samples up to the length of
the buffer could be played or recorded on one go. Now descriptors
must be less than or equal to the half the size of the buffer.
4) Added code to check that the power was not too low for playing or
recording before it started. Also added code which checks the power
level while it is in use and aborts if the power drops too low.
5) Further changes to the algorithmic alarm sounds - they now use beats,
as on the 3a.
6) Added EChangesPowerStatus to the change notifier. This change occurs
when either of the two battery statuses changes, or if external power
is connected or disconnected.
7) Fixed bugs in TTime::DayNoInWeek() and TTime::DateTime() which were
giving the wrong values for negative TTimes.
8) Added horizontal tabs, delete and ascii bell to test window server.
Also made it ignore the null character and vertical tabs.
Version 0.01.096
================
(Made by Graham, 2nd April 1997)
Binary compatible with 095
1) Graham
1) Improved backup battery voltage monitoring
2) Fixed a bug in the sound driver in the presence of
emergency power loss. This should cure all reported
problems of not being able to turn the machine back
on after playing sounds with low batteries.
2) Dennis
1) Fixed bug in unsigned division routine when used with
a divisor >= 0x80000000.
3) William
1) Implement primitive support for WINS memory gauge (SW-1183)
Note that this won't limit the total memory allocated, so the gauge can
exceed 100% (see Defects database for details).
2) Report allocated base address even for chunks of committed size 0 (SW-1876)
3) Fix dangling pointer problem with DChunk::AdjustL (SW-1793)
4) Implement Steve Townsend's suggested shortcut in User::Free and User::FreeZ
5) Tidy up handling of config structures in DoControl in D_COMM.CPP (SW-1970)
4) Matthew
1) Fixed SW-1994: Playing no sound can lock up machine.
5) Pete
1) Measurement of Vpc when powering up Pc Cards has now been enabled. This is in order
to reject cards which are found to be drawing excessive current.
(This had been disabled until it was possible to convert the ADC reading to millivolts).
Version 0.01.095
================
(Made by Graham, 26th March 1997)
1) William
1) Fixed bug with shared heaps (SW-1665) and added failure scenario to the T_RHEAP test.
2) Fixed SW-1884 bug about timer.At() alarms going off early after switchoff, and
enhanced T_POWR test to check for this.
2) Morgan
1) Added code to calibrate the digitiser based on the values in the
E-squared on a cold start. This may mean that if your E-squared
contains wildly outrageous values the digitiser will be out of
kilter. You can run \E32\TBAS\T_PROM to rectify this.
3) Matthew
1) Fixed B5/B6 bug SW-1726 (volume suddenly shooting to maximum).
2) Moved algorithmic alarm data into the localisation dll, so the names can
be changed.
3) Fixed B5/B6 bug SW-1630 in Comms PDDs: trying to set Mark and Space now
returns an error, and they are not returned as part of the capabilities.
4) Changes to Etna comms:
Fixed bug where the TEtna class was ignoring the Parity-Enable bit.
Removed the Uart interrupt enable from the boot up, since it was being
switched off anyway, and made the Etna comms driver switch interrupts on.
5) Added Comms driver power handling code. The behaviour is now that read and
write requests are completed with KErrAbort on normal switch-off and with
KErrBadPower if there is an emergency power down. On a power down the input
signals drop. On switch off, writes will keep going until the end of the
hardware fifo.
6) Fixed some bugs in the Comms LDD to do with signals.
7) Added Grahams K32DBGDD.H header file, which contains a helpful class for
debugging device drivers.
4) Jal
1) Changes to the Pccd interface controller to allow
access to media change notification. Added to UserPcCardCntrl:
IMPORT_C static TInt NotifyChange(TSocket aSocket,TRequestStatus *aReqStat);
5) Graham
1) Tightened up the backlight handling code and added various
backlight tests to T_POWR.CPP
2) Made Steve Townsends modification to TRegion.
3) Fixed a bug in Unicode in UM_RTOD.CPP
6) Jonathan
1) t_dbg: Added memory read/write tests to user data and, on
MARM, to Eiger registers.
2) Forced RDebug::WriteMemory() to use Mem::Move for aligned
writes so that writing to Eiger registers works.
7) Dennis
1) Added code to implement real-time clock correction based on a
measured crystal error value in parts per 2^24, written into
K::XtalError at startup.
8) Pete
1) On media change, before writing to a thread which
has requested notification of media change, a check has been added to
verify the thread has not been destroyed.
2) Fixed a problem with CRom media driver (MEDCRM.PDD).
Reads/writes from a position which wasn't on a word boundary (or of a
length in bytes which wasn't a multiple of 4), weren't previously supported.
3) Implemented a 40ms watchdog timeout on writes to CF cards (MEDATA.PDD).
4) Pc Card Controller now supports extended device
speed bytes when parsing Device Information Tuples.
5) Added extra fixed media enum to TMediaDevice in E32PCCD.H.
6) Various changes to Pc Card Controller to reduce code size.
7) It is now possible to disable the media change
implementation by setting iTotalMediaChanges=0 in Custom::PcCardMachineInfo().
8) Pc Card inactivity power down and 'not locked' power down periods can now be
set at the custom layer in Custom::PcCardMachineInfo().
Version 0.01.094
================
(Made by Graham, 20th March 1997)
1) William
1) Changed __KTRACE_OPT for exact matches on multiple trace bits, and tweaked some
of the debug messages a bit.
2) Enabled __KTRACE_OPT for WINS builds, writing to "Output" window under MSDEV
3) Automatically set KPANIC trace bit if debug mask is non-zero
4) Use aThread==NULL to mean &Plat::CurrentThread() in ObjectFromHandle functions,
and adjusted the callers appropriately
5) Check in SvSendReceive to make sure that the iSvSession is not NULL, and
fault if it is: the most likely reason for this is a User::Panic in the Supervisor
thread, so we check to see if the message code is ESvThreadPanic and extract the
Panic category and code as appropriate.
6) Added a new TCDT\T_KILLER.CPP test program.
7) Added simple calibration of WINS ticks, to fix SW-1384 by making the clocks run on time...
8) Arranged for Plat::Panic to add 0x10000 to the afult number and call Plat::Fault, so that
the machine will restart rather than loop forever.
9) Put back tweaked VA_RCHG.CPP battery charging driver: it will charge batteries without
melting the machine, but it won't do so automatically: still needs more work.
2) Graham
1) Changed rack B,C,and D keyboard tables to interpret FN+cursor
keys as home, end, page down and up.
2) Updated all keyboard tables to handle ctrl+fn as outlined in
the 090 release notes - not sure what happened to these changes,
they seemed to disappear some time after 090
3) Added code to handle low battery situations a lot faster.
Typically, we remove power from all devices within 110uS and go
into standby within 130uS.
4) Enhanced the P2 keyboard driver. It no longer locks the keyboard
out fully when three keys are pressed simultaneously. Rather, it
waits until fewer then three keys remain pressed before beginning
to deliver keyboard events again.
5) Fixed a bug in the keyboard when switching on with the dictaphone
keys - it delivered the key down event but never delivered a
key up event when the key was released.
3) Ann
1) Changed TRealFormat KRealFormatExponent mode to be able to use
either significant figures or decimal places. Default is still
decimal places, but oring in the KUseSigFigs flag to the format type
will allow use of significant figures instead.
2) Changed TRealForamtFixed mode so that negative numbers < -1 are
are "0" rather than "-0" when 0 dp are used.
4) Dennis
1) Exec::ThreadRead8, ThreadRead16, ThreadWrite8, ThreadWrite16, ThreadGetDesLength,
ThreadGetDesMaxLength now return an error code of KErrArgument if the pointer into the
remote thread address space is invalid, rather than panicing the caller. This fixes
problem SW-1013.
2) Supervisor server functions invoked with a bad pointer will now panic the caller,
rather than causing a system fault and rebooting the machine.
3) The sound driver LDD has been changed to allow only one channel to be open at a time.
This fixes problem SW-1165.
4) All key and pointer clicks are now disabled during sound recording. This fixes
problem SW-817.
5) Morgan
1) Read the E-Squared ROM into RAM on a cold boot.
Version 0.01.093
================
(Made by Graham, 14th March 1997)
1) Pete
1) Fixed a problem with inter-thread reading from CF card.
2) Fixed a timeout problem with some CF cards when
formatting.
2) Jonathan
1) StrongARM port (ISA) brought up-to-date but not tested.
*) Base team please note that (rightly or wrongly) the ARM Custom
API is shared with ISA (file inc\v32arm.h), so any changes or
additions to the ARM Custom API must be reflected in the ISA
Custom implementation.
3) Graham
1) Fixed handling of the emergency power down queue. This
problem was due to the bad design of single queues - it
is impossible to fully check that you are enqueued without
traversing the queue from the top. We might look into
adding a more useful single queue type.
Version 0.01.092
================
(Made by Graham, 13th March 1997)
1) Pete
1) Fixed problem with Format() in Compact Rom (repro version)
media driver (MEDCRR.PDD) such that it was only formatting the first
2M of a CRom card.
2) Compact Rom media driver (MEDCRM.PDD) now included in release.
2) Graham
1) Fixed an bug in the mmu abstraction which assumed that the page
directory was aligned linearly in the same way as it was aligned
physically.
3) William
1) Fixed a problem with threads dying
Version 0.01.091
================
(Made by Graham, 12th March 1997)
1) SimonB
1) Fix for Serial PDD in NT 4
2) Removal of dependancy on MSVCRT40*.DLL
2) Morgan
1) Added screen information to TRomHeader for the bootstrap
2) Fixed corrupted ExcInfo on MARM by adding a FiqStack and
moving the exceptions onto the ExceptionStack.
3) Moved TExcInfo to E32HAL.H
4) System Death due to an exception now saves ExcInfo in the
Superpage and causes a Kernel Fault. Startup, Fault and
Exception reasons are available through:
UserHal::StartupReason()
UserHal::FaultReason()
UserHal::ExceptionId()
UserHal::ExceptionInfo()
There should be a Shell dialogue which retrieves
this information after a kernel fault. This will
enable us to pin down the offending code. Also, along
with each new Protea image, MAKSYM should be run and
the generated log file should be placed on the network
as well. This will give the address of every function
in every module of the ROM.
5) Changed the startup beeps
ColdStart 1 beep
WarmStart 2 beeps
KernelFault 3 decending beeps
6) Fixed SW-1069 - WINC heaps can grow up to 8Mb
3) Graham
1) Enabled the shift key when typing e.g. CTRL-1 a to give
a-umlaut.
2) Solved the œ sign problem on WINS - this had been
re-introduced by Simon's WINS internationalisation
code.
3) Re-introduced some digitiser inertia code to prevent
wobble.
4) Re-structured the Spi controller code.
5) Fixed a bug in CObjectCon::CheckUniqueFullName() that was
preventing two processes of the same name being loaded.
This cures problems with T_KHEAP.EXE and T_PROC1.EXE.
6) Fixed T_KEYS.EXE by updating it for the new ISO LATIN 1
keyboard tables.
7) Made TInt64::GetTInt() and TInt64::GetTReal() const.
8) Swapped the dictaphone keys round (again?)
9) Changed the emergency power down list to be on a single
queue instead of an object container.
10) Changed the P2 keyboard table to make FN-e give e acute
and FN-SHIFT-e to give E acute. This is just to test that
such things are possible although it might be cool to just
leave this in since e acute is probably the most-used
accented character in English.
11) Moved the accenting keys from CTRL+1-6 to FN+Q and FN+Z-B
12) Completed anti-ghosting logic to disallow more than one
modifier and more than one normal key at the same time.
13) Changed the text window server so that a pointer click outside
the region of any window will cause the foreground window to
change.
14) Implemented battery voltage monitoring
15) Increased the number of frozen functions in the kernel to
avoid BITGDI recompilations when E32 is released. Lane, you
will have to recompile, hopefully for the last time, for
this version of E32.
16) Changed keyboard driver to recognise when the machine is
turned on. It will then scan the keyboard and deliver a
keyboard event only if the dictaphone keys are down. It then
waits for all keys to be up before proceeding to deliver
further events.
4) Matthew
1) Fixed B5 bug SW-266 ("%+0*S" formatted incorrectly).
2) Put in Ir power-down fix (from Mark Ball).
3) Added emergency power down handling to sound driver. The driver
completes statuses with KErrBadPower on emergency power down.
This fixes B5 bug SW-384.
4) Added two functions to sound driver - BytesPlayed() and
ResetBytesPlayed() wich give the user feedback on how playing is
progressing.
5) Increased the volume of EVolumeMedium in Eiger sound PDD so the
steps are more even. "Fixes" SW-543 (No apparent difference
between volume settings).
6) Moved sound test code from F32 to E32.
5) Jonathan
1) Added SA ARM variant for Snowball.
2) Fixed #defines in ROM.OBY file to make PREP happy.
3) Made screen size a variant-dependent thing on ARM:
- Screen size is no longer hard-coded in ARM text window server
(wd_eiger.cpp) or ImpHal::Init3(). Text window server no
longer handles switching bit depth.
- LCD initialisation moved out of boot code into
ImpHal::Init3(), with size-dependant LCD initialisation in
Variant::Init3().
- ARM boot code uses screensize parameters in ROM header to
determine video RAM size and placement of page tables.
6) Dennis
1) Fixed a bug in the high-resolution timer code, and added a
Cancel() function to TMilliSecondCallBack.
2) Added a logical device driver for the high-resolution
timer (EFTIM.LDD) accessed via RFastTimer class in
D32FTIM.H
3) Fixed some bugs in 486 build of E32 and speeded it up
by enabling the processor cache and by coding the Mem::
functions in assembler.
7) Ann
1) Fixed a bug in TLex8::Val() which setting next to start of
string if an overflow occurred, causing problems for EIKON.
8) Pete
1) On ARM architecture, moved code for Etna device out of the Kernel
into the Variant DLL for P1,P2,RackC and RackD builds.
2) Added iInterruptInfo to TPccdConfigInfo class. Users of
UserPcCardCntrl::GetConfig() must rebuild - only Pc Card test code should
be using this.
3) Changes to the inter-thread Read()/Write() functions and the Format()
function of DMediaDriver to take a reference to a length (TInt &aLen rather
than TInt aLen). Read/Write/Format requests which would result in excessive time spent in the Kernel now only partly complete. They then return TErrTooBig
with aLength adjusted to the remaining length.
4) Removed the current thread read/write functions
Read(TInt aPos,TintaLength,TDes8 &aTrg) and Write(TInt aPos,TDesC8 &aSrc) from class DMediaDriver as the inter thread read/write versions now perform the same function if the target thread is found to be current.
5) ARM Ata media driver now adjusts auto power down timeout of CF card to 1sec. This prevents it from going into sleep mode between access which could affect CF card transfer rates (default is 5mS).
Version 0.01.090
================
(Made by Graham, 26th February 1997)
1) Graham
1) Changed CTRL+FN+key behaviour. This is a complicated
issue. If one hits CTRL+FN+'1' on a Lime, then it is clear
that the Control and Function modifiers should be set.
However, what should the keycode be? It should be '1'
and not '_'. Higher level software is more interested in
the fact that CTRL+FN+'1' has been pressed than CTRL+'_' has
been pressed. For this reason, in 089, the keyboard tables
were changed to make CTRL override FN as far as keycode code
production was concerned.
However, consider the keystroke CTRL+FN+LeftArrow. In this
case, the opposite is true. Higher level software is more
interested in the fact that CTRL+HOME has been pressed
than that CTRL+FN+LeftArrow has been pressed.
So, in this release I have changed the keyboard tables to
cater for both problems by judging each key on an
individual basis. On a Lime, the keycode produced for:
CTRL+FN+'1' - CTRL+FN+'9' -> '1' - '9'
CTRL+FN+'A' - CTRL+FN+'Z' -> 0x01 - 0x1a
CTRL+FN+LeftArrow -> Home
CTRL+FN+RightArrow -> End
CTRL+FN+UpArrow -> PgUp
CTRL+FN+DownArrow -> PgDn
CTRL+FN+Tab -> CapsLock
CTRL+FN+Esc -> Off
CTRL+FN+' -> '
CTRL+FN+. -> .
CTRL+FN+<space> -> Backlight
CTRL+FN+, -> Help
2) Changed the raw key code on WINS for the Alt key from
EStdKeyLeftAlt to EStdKeyLeftFunc. Attempted to get the
windows key to be the Epoc32 Alt key.
3) Various additions to do with REPROing the upper 2Mb on
Limes.
4) Protected the eiger internal registers from user mode access
5) Introduced anti-ghosting algorithm into the P2 keyboard
driver. It doesn't, however, get rid of the ghost FN key
when you hold down LeftShift, DownArrow, and RightArrow
together. This leads me to believe that not all the diodes
have been fitted on the modifier keys.
The algorithm is basically one of 2-key rollover. So, any
keypresses made when two keys are already held down should
be ignored. Naturally, this is no good when you want to
hold down certain complex modifier and key combinations.
So, these special cases are compensated for in the software
in the knowledge diodes should be fitted into the modifier keys
to prevent any matrix-ghosting.
2) Ann
1) Fixed bug spotted by Natascha in doCalculator() so that values
with negative exponents are displayed correctly.
Version 0.01.089
================
(Made by Jane, 21st February 1997)
1) SimonB
1) Removed dependency on WINMM. Timer now based on a RealTime thread
and sleeps.
Required for Win95 and general compatibility.
2) Changed WINS Comms PDD to work with Windows 95
3) Mark T's Comms PDD bug fixes integrated.
4) International Keyboard support. Just UK and US at the
moment, more to follow.
5) Removed first chance exceptions from WINS loading.
IsBadWritePtr replaced by VirtualQuery.
2) Jane
1) Finished the CObjectCon improvements suggested by Andrew. Note
that to pick these up you need the new version of
CheckUniqueName which takes CObject*s rather than names.
The time taken to Add 0x600 named objects to a container has
gone down from 14 seconds to 6 seconds.
2) Added code for _ftol() to WINS and X86 builds. The function
header is in e32std.h
3) Fixed various debugging printfs by supplying a simple overflow
handler so that long strings are truncated rather than
panicing the caller.
3) Graham
1) Fixed the œ gives ae keyboard problem by converting all
keyboard tables from CP850 to ISO Latin 1.
2) Introduced a new key code - EKeyHelp. This is now F2
on WINS.
3) Changed the WINS keyboard tables so that the dictaphone
keys give the correct raw scan code as well as the
appropriate Epoc32 key code. Did the same trick for
the menu, help and off keys.
4) Fixed up the P2 keyboard tables. Note that the backlight
keys have to be handled in higher level software -
presumably the window server. On Protea the key code used
is EKeyBacklightToggle. However, a really skillful
implementation would handle EKeyBacklightOn and
EKeyBacklightOff as well (in case future hardware has
both on and off keys for the backlight).
5) Fixed the P2 sticky shift and function modifiers.
6) Removed the keyclick on shift, function and control keys.
This has only been implemented on P2.
4) Pete
1) Renamed EPccdEvent enums to prevent name clashing with
W32STD.H.
2) Enabled media change interrupts on P2 hardware.
5) Morgan
1) WarmReset+LeftShift boots with EStartupColdReset on P1,P2,PB,PC,PD
2) Added startup beep
3) Fixed SW-32
4) Write protected the Mmu page directory backup
6) Ann
I IMPLEMENTATION OF SPECIAL VALUES:
TReal96, Math and TDes8/16 classes now handle "special values" - NaNs,
infinities, signed zeros and denormals.
Changes are as follows:
1) Maths constants renamed:
K...ExponentBigBad now K...SpecialExponent
K...ExponentSmallBad now K...ZeroExponent.
2) The Math member functions
ASin(), ACos(), ATAn(), Exp(), Frac(), Int(), Ln(), Log(), Mod(),
Pow(), Pow10(), Sin(), Cos(), Tan(), Sqrt()
have been changed as follows:
a) to return an error corresponding to the result, i.e.
KErrArgument if the result is indefined / a NaN,
KErrOverflow if the result is too big to be represented or infinite
positive only if the result is an integer),
KErrUnderflow if the result is too small to be represented (or if the
result is an integer, if the result is too large or infinite
and negative),
KErrNone if the result is finite and representable.
b) to write a result to the aTrg IN ALL CASES rather than just
the return value is KErrNone. Hence the result is as follows:
NaN if the error is KErrArgument,
Positive or negative infinity as appropriate if the error is
KErrOverflow (or the max value if the result is an integer),
Positive or negative zero as appropriate if the error is
KErrUnderflow (or the min value if the result is an integer).
c) to be able to handle denormals. i.e. all numbers >= 5E-324 and <
KMinTReal64=2.2250738585072015E-308.
3) Math member functions IsZero(), IsNaN(), IsInfinite() and
IsFinite() added. Also private member functions SetZero(), SetNaN()
and SetInfinite().
4) TDes8/16::Num/AppendNum() returns error value or length of string
as previously, but if error value is returned an appropriate string
is set:
"Inf" for positive overflow (KErrOverflow and positive argument)
"-Inf" for negative overflow (KErrOverflow and negative argument)
"0" for positive underflow (KErrUnderflow and positive argument)
"-0" for negative underflow (KErrUnderflow and negative argument)
"NaN" for NaN (KErrArgument)
5) TDes8/16::AppendFormatList() only panics for KErrGeneral and
if another error value is returned by Num(), uses the string set
as above.
6) The exponent of TReal96 zero is now -32768, the smallest exponent
possible.
7) TReal96 member functions IsZero(), IsNaN(), IsInfinite(),
IsFinite(), SetZero(), SetNaN() and SetInfinite() added.
II ROUNDING FLAG:
See Programming DB - Global Rounding Flag Required
A new private member of TReal96, iFlag, has been added to
indicate whether the mantissa is rounded up, rounded down or exact.
This has required changes in member functions to set and use the
flag where necessary.
Changes are:
1) iSign member changed from TInt16 to TInt8.
2) Constants for values of iFlag added to e32math.h:
const TUint8 KRoundedUp=2;
const TUint8 KRoundedDown=1;
const TUint8 KExact=0;
3) New TReal96 member function TReal96::Flag() which returns the
value of iFlag as a TInt.
4) New private function TReal96::Round() taking an argument which
specifies the number of binary digits in the mantissa to perform
rounding in the (MSDEV and IEEE standard default) round to nearest
mode and to set the flag as appropraite has been added to be used by
Normalise(), Prepare() and conversion functions. New private member
function TReal96::ShiftToNormalise() added to be used in cases where
rounding will never be required e.g. assignment/construction of
TReal96 from TInt.
5) TInt64::Multop() returns integer values between -2 and 1 with the
following meanings:
-2 least significant 64 bits exactly zero
-1 least significant 64 bits less than TInt64(0x80000000,0) but
not zero
0 least significant 64 bits exactly TInt64(0x80000000,0)
1 least significant 64 bits greater than TInt64(0x80000000,0)
and TReal96::MultEq() changed to round according to these values.
6) TReal96::DivEq() rounds on the remainder after division similarly.
All maths test code updated to test special cases including
correct return values and setting target values and new functions,
etc. Also fixed to work in X86 build.
III OTHER
1) UP_GCC.CPP function converting double to float changed to raise
the exception. Also all arithmetic changed to do operation and
conversion and raise the exception if an error value is returned at
any stage.
2) Function TReal96::CheckOverUnderflow() used by arithmetic now a
private member function and altered to check fewer large-exponent
cases for overflow.
7) Matthew
1) Fixed SW-25 from B5 database (Power off while recording hangs machine).
Version 0.01.088
================
(Made by Jane, 12th February 1997)
This version requires F32 053
1) Graham
1) Sorted out the digitiser. This should no longer
exhibit wobble or erroneous points when touching
the surface lightly.
2) Updated digitser driver to use the new digitiser
clicks rather than the keyboard clicks. These
should now be indepenently controllable.
2) Jane
1) Added an implementation of User::IsRomAddress from
Simon B.
2) Added CArrayFixBase::SetReserveL
3) Fixed a chunk bug - when a TFindChunk was opened read-only
in a process, the top bit of the process address (data
section) was set to indicate this. If another thread was
then created in the process, its heap address was incorrectly
allocated over the TFindChunk, as the latter's address was
stored with top bit set.
4) Fixed a shared chunk bug on 486 - when T_CHUNK opened the
Window Server chunk RO, and then did an Exec::SessionSend
to the WindowServer, there was a fault when the kernel
attempted to write the message into the Window Server's
heap. Fixed this by unsetting the WP bit in CR0, so that
supervisor can write over User RO chunks. This is OK on the
ARM, but a thing to look out for if we ever port to another
processor.
5) Improved CArrayPtr<T>::ResetAndDestroy as suggested.
6) Changed profiler end/start behaviour as detailed on Notes.
7) Started to optimise CObjectCon::CheckUniqueName as suggested
by Andrew Thoelke.
The time taken to store 0x200 unnamed objects has gone down
from 6 seconds to being as close to 0 as makes no difference.
More on this later...
8) Added __ftol to EUSER.
9) Added CObjectCon::AtL which leaves rather than panicking, so that
the kernel can panic a thread which passes an invalid find handle to
open, rather than dying itself.
10) Increased the WINS main user thread's max heap size to 8M.
3) Pete
1) Moved sections of code relating external interrupt control and binding out of
the Kernel DLL and down into the Variant DLL.
2) Code for Pc Card external interrupts (Ready,IREQ,Status change) added.
3) CF card media driver now makes use of card IREQ signal during card writes. This
now goes into idle after initiating a write to the card, with the card asserting
an interrupt on completion to wake up the system.
4) Added a media driver for compact rom card (MEDCRM.PDD).
5) Written media driver for programming flash on compact rom card(MEDCRR.PDD).
6) Modified the functions
7) Changes to functions CardInfo() and ChangeFlag() of UserPcCardCntrl class.
8) Monitor the Vpc voltage on first applying power to a Pc Card to check that
the card isn't drawing too much current for the rail.
9) Alteration to media change simulation in WINS:
F5 - Media door open as long as F5 is held down.
F4 - This toggles between 1 of two simulated CF cards on socket 0 (ie X:)
when hit while F5 is held down.
10) All files used to simulate Pc Card memory and internal ram drive now created in
systems temp directory rather than \EPOC32\DATA - ie fixed HA-262.
11) Fixed problem with ATA media driver - divide by zero.
12) Removed support for Rev 1.0 Asic12.
13) Check battery status before commencing write to CF Card - return with
KErrBadPower if battery is low.
14) CF Card driver now handles emergency power down.
15) Pc Card power consumption - K::PcCardCurrentMilliAmps
now implemented.
4) Matthew
1) User::SetHomeTime() has been changed to return a TInt. This will return KErrOverFlow on
Arm if the new time is out of range (past about 2068, before about 1932).
2) Sound driver: Added more click controlling code and implemented a fallback alarm.
Version 0.01.087
================
(Made by Graham, 5th February 1997)
This release is binary compatible with 086
1) Graham
1) Implemented dictaphone keys in WINS:
F6 Dictaphone Play
F7 Dictaphone Stop
F8 Dictaphone Record
2) Begun the production of power supply
information from UserHal::SupplyInfo().
Expanded test code in t_power accordingly.
3) Added the P2 variant which will be used for green
machines. Changed the keyboard variant to include
the dictaphone keys.
4) Added PD and P2 variants to the releaseables.
5) Added the function UserSvr::TestBootSequence(). This
returns true if the machine is being booted by the test
department. The file server should call this function and
load etest.exe rather than ewsrv.exe if this is the case.
6) Added the function UserHal::ResetAutoSwitchOffTimer().
7) Added the function UserSvr::AddEvent(). This enables user
code to add events into the event queue. Quite apart from
the numerous applications that this might spawn, it is
necessary for user side implementation of a VT100
console driver and handwriting recognition software.
8) Added the EKeyMenu, EKeyBacklightOn,
EKeyBacklightOff, and EKeyBacklightToggle keycodes
to all variants. On WINS the F1 key is used as the
MENU key.
9) Rationalised the MARM rom building system. This is
now controlled by a single ROM.OBY file which is
preprocessed with build and variant information.
10) Added backlight support. The backlight may be
either timed or untimed. Should the timeout
be reset whenever the machine is used?
11) Made pointer clicks configurable separately from
key clicks.
12) Added screen clearing on switch on if a password
is set.
13) Added UserHal functions for PointerSwitchesOn,
CaseOpenSwitchesOn, and CaseCloseSwitchesOff.
Grouped these, together with the
AutoSwitchOffTime, AutoSwitchOffBehavior,
BacklightTime, and BacklightBehavior information,
into a new TOnOffInfo structure.
14) Implemented switch off on case close and switch
on on case open on all platforms.
15) Simon has implemented a visual simulation on WINS
of case closing. On WINS, F11 is also used to simulate
both closing and opening the case. You will
notice that, while the case is closed, keyboard
and pointer events have no effect. This is to
simulate the fact that normally you can't get to the
keyboard or screen under these conditions.
16) Enhanced MARM switch on on pen down to take
account of the Hal variable PointerSwitchesOn.
17) Solved Low battery bugs (HA-357, HA-362)
2) Ann
1) Test code changes:
i) Additional tests added to t_math tests for Pow10(). These show
that in all but one case inexact string to real conversion is due
to inexact calculation by Math::Pow10(). All tests in t_math check
for as much accuracy as possible.
ii) t_float tests are now consistent between WINS and ARM.
iii) Whetstone benchmark tests added
iv) t_r96 casting tests now include identity tests (which check
consistency with MSDEV in WINS). Casting to TInt tests changed
in line with changes to source code (ii below).
2) Source code changes:
i) TReal96::MultEq() altered to do one shift rather than preparing
and then shifting to left. This avoids losing bits which may be
shifted off the end by preparation, but for which there is space in
the final postition.
ii) TReal96::operator TInt() changed to round towards zero to
comply with IEEE standard and Java requirements (also MSDEV).
iii) TReal96::Prepare() altered to check for zero sign or zero
mantissa. If so, preparation is not done. Im the latter case,
the mantissa is meaningless and in the second preparation would
result in an infinite loop which does nothing.
3) Morgan
1) Implemented Kernel Faulting.
2) Reorganised low memory to include the Registry just before the
Ram Drive. This means that the Ram Drive is shoved up and down
in memory as the Registry changes size.
Added class TLowMemory to manage the Ram Drive and Registry
memory allocation and to provide information to F32 about the
drive's changing position.
3) The Ram Drive now survives Warm Resets and Kernel Faults
Implemented CPersistantRegistry to do the same for the Registry.
T_RESET tests all this jiggery pokery on MARM.
4) Added integer divide by zero exception to MARM
5) Implemented a user side mini-loader for loading Dlls from ROM
when an explicit ROM path is provided.
eg. lib.Load(_L("MONKEY.DLL"), _L("Z:\\Animals\\Primates\\Hairy"));
This eliminates most of the time taken to load these Dlls.
4) Jane
1) Fixed MMU bug which showed up in fairly obscure kernel growth/shrinkage
situations.
2) Optimised page allocator for faster kernel growth.
3) Added a routine to compact kernel pages when the machine is reset. This function
is not called yet, except in test code.
4) Made a TFindChunk::Open() actually add the chunk to the process address space (unless
it is a kernel chunk) so that the chunk can be read/written from another process.
5) Matthew
1) Fixed HA-355: added %*a and %*b to TTime::Format() which give
am/pm without a space.
2) Fixed HA-367: descriptor formatting now accepts things like
%-10f (default fill character space) and % 5F (no "+").
3) Internal changes to sound driver to reduce the amount of clicking.
Also fiddled with the volumes of DTMF dialling, so it should work now.
Version 0.01.086
================
(Made by Matthew, 22nd January 1997)
This release is binary compatible with 085
1) Graham
1) Renamed T_PARSE to T_TPARSE to eliminate the
conflict with the F32 test program of the same
name.
2) Updated the TREALTIM test programs and fixed some
super thread bugs.
3) Temporarily reintroduced page-based ROM mapping so
that debugging can be tested again.
4) Fixed a bug in the user side event code which
prevented position information being extracted
from the new EPointerSwitchOn events.
5) Fixed bugs in the ARM implementation of
TInt64A::MulTop() and changed it to return a TInt.
2) Ann Windsor
1) Removed KTReal96MaxExponent and KTReal96MinExponent from
e32math.h
2) Fixed bug HA-345: constants now correct to full precision.
3) In t_math test code, all approximate tests now use the
function testApprox(). This tests that the relative error
is within a specified tolerance.
4) Removed all approximate tests from t_r96 and t_r64.
5) In Pow10(), limits for second underflow check changed so
1.0E-308 underflows as expected.
6) TInt64A::Multop() fixed to carry from insignificant parts
and now returns a TInt to indicate whether the insignificant
64 bits are zero or non-zero. TInt64::MulTop() changed
accordingly.
7) TReal96::DivEq() fixed to force rounding up where
appropriate. This results in division being up to
5E-6 secs slower in the worst case.
8) SReal64 and SReal32 struct definitions added to um_std.h
and removed from other umath *.cpp files
9) TReal96::MultEq() fixed to force rounding up where appropriate.
3) Alastair
1) Fixed bugs in release versions of T_SEC.
4) Simon
1) Protected EventQ from access from WINS Window and Timer threads.
Fixes a few WINS Bugs related to AddEvent causing an Access
Violation.
2) Added some new shutdown code to allow System threads to continue
execution when the machine is off. This fixes bugs like "Program
does not exit when minimized" and other miscallaneous hangings
after a PowerDown.
3) Change to E32Initialize to allow WINC apps to call it more than
once.
5) Matthew
1) Stopped WINS from adding 1 hour for summer time when it's winter.
2) Fixed bug in CRegistry::SetContents().
Version 0.01.085
================
(Made by Jal, 10th January 1997)
1) Morgan
1) Fixed OOM alloc heaven in CreateSession and RLoader::LoadLibrary
2) Renamed kernel.exe to ekern.exe in the X86 obey file so device
drivers can link to it.
3) Added iLanguage bitfield and iHardware members to TRomHeader.
Updated BOOTROM.BIN to match.
2) Jane
1) E32 Proposals
a) Made CObjectCon::ValidateName -> User::ValidateName (static)
b) Removed copy constructors for TPoint, TSize, TRect
c) Made TLocale constructor exported, removed setting to 0 from TChar
constructor.
d) Removed CDeltaTimerAlloc
e) Americanised Capitalise.
f) Make TDesC8::Length and TDesC16::Length inline
g) Implemented Rog's amendment of David's User::Notify proposal: an RNotifier
class with the following member functions-
TInt Connect();
void Notify(const TDesC& aLine1,const TDesC& aLine2,const TDesC& aBut1,const TDesC& aBut2,TInt& aButtonVal,TRequestStatus& aStatus);
TInt InfoPrint(const TDesC& aDes);
2) Bug fixes
a) Removed unused User time/date functions
b) Kept a list of thread relative threads within the thread so that they
can be closed properly when the thread dies.
c) Alloced a bit in the DThread iFlags for whether the thread is the main one, this
fixed the bug with APPRUNs not dying.
d) The priority of the NULL thread was incorrect in WINS - spotted by
David Batchelor, thanks.
f) Added CServer::Restart() and fixed CServer::RunL()
g) Fixed HA-55 kernel alloc heaven causes kernel re-entrancy
3) SteveG
1) Fixed bug in the battery recharger hanging when free'd. Added
iChargeTick.Cancel() into the device driver destructor.
4) Geert
1) Inlined various TDateTime, TTimeIntervalXxx and TTime members.
2) Integrated Bruce's TTime::Parse() service. (See the proposal and
spec in E32 Proposals for details.)
3) Removed all Time member functions duplicating services in TTime.
4) Removed initialisation code from TTimeIntervalXxx's and TTime's
default ctors. Default constructed instances of these classes now
have undefined, arbitrary values.
5) Graham
1) Added functionality to the text window server to allow raw
event information to be passed through to a client. The
primary user of this is the final test program which
needs some way of testing each raw keyboard element.
2) Updated the double multitasking kernel functions to give
handles wrt the kernel server rather than the device
driver client. Updated the real time test program and
device driver accordingly.
3) Made relocatable static data changes appropriate for
our real-time needs.
4) Fixed a further digitiser problem. There should
now be no machines which experience complete
digitiser failure apart from those with hardware
faults in this area.
6) Alastair
1) Added overloaded NewL function for Security class which
takes a piece of security data as a parameter so that a
CSecurityBase object can be constructed using security
data stored in a file for decryption purposes.
2) Removed ConstructL, EncryptL, DecryptL and
IsValid functions from CSecurityBase API.
3) Added NewEncryptL and NewDecryptL functions to
CSecurityBase API so that objects for handling encryption
sessions and objects for handling decryption sessions can
be created. The APIs for these object classes -
CSecurityEncryptBase and CSecurityDecryptBase - have been
added to E32BASE.H.
NewEncryptL and NewDecryptL take an initialisation
vector as a parameter to allow for pluggability with
more sophisticated encryption methods.
4) Written a new UB_SEC.CPP to cater for the above
changes. The current encryption scheme produces
encrypted data in multiples of 32 bytes.
5) Rewritten T_SEC.CPP to test security changes.
7) Matthew
1) Changed set and free tls functions from exec to sv calls.
2) Fixed alloc heaven in change notifier, and changed notifier so that
you can only logon once to each notifier, so that the kernel's notify
function can be called from exec functions. This has meant API changes,
and the RUndertaker API has also been changed - the parameter has been
removed from LogonCancel - so the two are more similar.
3) Added iMaxVolume capability to sound driver, now the volume-by-value
takes a value from 0 to iMaxVolume, instead of 0 to 100.
4) Removed Time::IsValidDate().
8) Pete
1) Added custom and variant DLL for rack D h/w.
2) Moved sections of code relating to the Pc Card Controller h/w out of
the Kernel DLL and down into the Variant DLL.
3) Added the function UserHal::DriveInfo() which
returns a TInfoName for each local drive and Pc Card socket as well
as the total number of valid drives and socketss on a given variant.
4) Various changes to the member functions of UserPcCardCntrl
class.
9) Ann Windsor - CHANGES TO MATHS SOURCE CODE
I e32\inc\e32math.h
-------------------
1. Constants KTReal32MinExponent and KTReal32MinExponent, KTReal96MaxExponent,
KTReal96MinExponent, KTReal96ExponentBigBad and KTReal96ExponentSmallBad added.
2. Functions added to UM_R96.CPP added to TReal96 class
II e32\inc\e32std.h
-------------------
1. Constant KErrDivideByZero added.
2. New constants defined for flags in TRealFormat type:
KExtraSpaceForSign=0x40000000
KAllow ThreeDigitExp=0x20000000
KUseSigFigs=0x10000000
KDoNotUseTriads=0x08000000
KGeneralLimit=0x04000000
KRealFormatTypeFlagsMask=0x7c000000
KRealFormatTypesMask=0x0000007
3. RealFormatType no longer enum; changed to constant TInts
KRealFormatFixed=1
KRealFormatExponent=2
KRealFormatGeneral=3
and two new types added:
KRealFormatNoExponent=4
KRealFormatCalculator=5
4. iDecimalPlaces member of TRealFormat name changed to iPlaces because used
for decimal places or significant figures as appropriate.
5. TLex8 member function ScndigAfterPoint() added.
III e32\ucdt\uc_des.cpp
----------------------
1. Changed in line with changes to e32std.h above.
2. AppendFormatList() altered to allow three-digit exponents in E,e (exponent)
and G,g, so Printf %E,e,G and g all display numbers to the maximum range.
IV e32\umath\um_dtor.cpp
------------------------
1. Changed TLex8::Val() appropriately to deal with the full range of values. This
includes doing multiplications in TReal96's so that errors can be detected.
2. TLex8::ScndigAfterPoint() added to do conversion from decimal after point, so that
trailing zeros are not included. This ensures that e.g. 0.2900 and 0.29 have the same
binary representation.
V e32\umath\um_pow.cpp
-----------------------
1. Changed to check for aSrc being ±1. If so, sets result appropriately to ensure exact
and to save running algorithm.
2. Bug found and fixed: Int() being used for a number potentially larger than 32767.
Altered to return an error if Int() reports an error, i.e. if the input has an absolute
value larger than 32767 (a return value larger than 32767 would lead to an error later in
the function anyway). This ensures that results over and underflow as expected.
3. Bug found and fixed: reduce() set high part of f to 0 rather than leaving it unchanged.
This fixes the bug reported in B4 problem report no HA-207: overflows are now reported as
expected.
VI e32\umath\um_pow10.cpp
-------------------------
1. Changed to handle the full range of TReals rather than up to 1e±100.
VII e32\umath\um_r96.cpp
------------------------
1. Set() checks that exponent does not exceed maximum (KTReal64ExponentBigBad/
KTReal64ExponentBigBad) and is not less than minimum (KTReal32ExponentSmallBad/
KTReal64ExponentSmallBad). If so, KErrArgument is returned.
2. GetTReal()
i) In checking for underflow, value against which check is made changed from
-KTReal32MaxExponent/-KTReal64MaxExponent to KTReal32MinExponent/KTReal64MinExponent.
ii) Rounding has been implemented for TReal32s so that when a TReal96 mantissa is
converted to a TReal32 it is rounded to the nearest value using all bits available,
rather than just being truncated.
3. Casting to a TInt from a TReal96 changed to check for zero by using sign and also to
round to nearest, rather than always rounding down.
4. Arithmetic
i) Added functions AddEq(), SubEq(), MultEq() and DivEq() which perform the operations
+=(), -=(), *=() and /=() respectively, as these operator functions did previously, but
reporting an error constant, rather than panicking.
ii) Similarly to i), functions Add(), Sub(), Mult() and Div() have been added as the
non-panicking variants of operator +(), -(), *() and /(). The latter functions panic on
an error as described in ii). The result is written to an input target variable.
iii) operator +=(), -=(), *=() and /=() perform arithmetic operations (using AddEq(),
SubEq(), MultEq() and DivEq() respectively) and either panic (when unsuccessful), leaving
the initial arguments unchanged, or otherwise return the result in *this.
iv) Added function CheckOverUnderflow(), to be used in AddEq(), SubEq(), MultEq() and
DivEq(), to check for overflow or underflow in cases where it may occur by normalising
the result and checking the exponent.
v) Added function PanicOverUnderflowDividebyZero() which is used in operator +=(), -=(),
*=() and /=() to panic if an error is returned by AddEq(), SubEq(), MultEq() or DivEq()
respectively.
vi) Addition operations (in AddEq()) improved to eliminate loops which change exponent by
1 and shift the mantissa by 1 place on each loop to make the exponents equal before
addition takes place, instead altering the exponent and shifting as appropriate in one
step.
vii) Fixed bug in AddEq() so that it shifts the mantissa of the bigger number right by
one. This prevents failure when subtracting numbers of the same sign (or adding numbers
of the opposite sign) when the ms bit needs to be carried down (and hence only two bits
are shifted down into the extended part when preparing the result) and the last hex digit
of the result is 4 when prepared.
viii) In DivEq(), a new error KErrDivideByZero has been introduced. Also reports
KErrArgument if 0/0 (invalid operation).
5. Changed Normalise() to round on last three bits to nearest value, rounding to value
with l.s. bit zero (even) if two values are equally near to be consistent with MSDev and
to minimise propagation of rounding errors in general.
6. To be consistent with MSDev, increment and decrement operators should normalise after
each operation. However, this doubles the time and ultimately decreases accuracy, so
has not been adopted.
VIII e32\umath\um_rtod.cpp
--------------------------
1. fDigLim() changed to handle all exponents between -1022 and 1025, i.e. all TReal64s.
2. All do...() functions now take TInt flags as one of their parameters to enable (or
disable) extra space for sign, three-digit exponents, significant figures rather than
decimal places, triads and linited accuracy of digbuf.
3. In addtition to the flags above, an internal flag determining whether the digbuf needs
rounding has been added.
4. doExponent() altered so it can be used both directly and by doGeneral() and
doCalculator(). In calculator mode, trailing zeros are eliminated. Also uses three-
digit exponents if allowed by flag if necesary.
5. doFixed() altered so that a space is left for a potential sign if a flag is set. This
allows positive and negative numbers of the same exponent to be of the same accuracy.
6. doGeneral() altered in line with alterations to doFixed() and doExponent().
7. doNoExponent() new function added to deal with calculator representation which does
not use exponents, i.e. numbers to a maximum number of significant figures. This
function is similar to doFixed(), other than it does not pad with zeros and hence does
not necessarily have a decimal point or deciaml places. If the triad length is non-zero
then triads are allowed by default (but can of course be disabled by a flag). An
overflow error is reported if the number is too big to fit in the maximum significant
figures and an underflow if it is too small for any significant digits to appear i.e.
apparently 0. If the number does not fit, i.e. not enough space for sign, point or triad
separators, then a general error is reported.
8. doCalculator() new function added which operates as a conventional calculator would,
i.e. using non-exponential representation as far as possible and otherwise exponential
representation. The number of figures in the display is limited by the maximum
significant figures. This function will report a general error if there is insufficient
space availble to include a sign, decimal point and exponent, as well as the figures,
EVEN IF THEY ARE NOT REQUIRED. In this way it operates as a conventional calculator.
doCalculator() uses either doNoExponent() or doExponent() (in calculator mode, see 4.)
as necessary.
9. rtob() has been altered in line with the above changes.
Also it now checks that the numspace is >0, otherwise reporting a general error. iType is
now used to take both the user-specified flags and type. If no type or flags are
specified then it leaves. Flags are also set as necessary for the various modes (in all
modes, rounding is needed):
fixed - does not use significant figures
exponent - does not use significant figures (when accessed directly rather than
through calculator)
general - does not use significant figures or triads
no exponent - uses significant figures
calculator - uses significant figures and no triads.
IX e32\umath\um_sin.cpp
-----------------------
1. sinx() changed to ensure than sin of a multiple of pi and cos of an odd multiple of pi/2
give exactly zero.
X e32\umath\um_std.h
---------------------
1. EMathUnknownPanic added to TMathPanic to deal with unknown errors.
XI e32\umath\um_tan.cpp
-----------------------
1. Tan() changed to ensure that tan of a multiple of pi gives exactly zero and tan of an
odd multiple of pi/2 reports an overflow error.
XII e32\umath\um_utl.cpp
------------------------
1. Poly() changed to use TReal96s.
XIII e32\upmarm\up_gcc.cpp
--------------------------
1. Arithmetic now raises an exception if an error is returned by the TReal96 non-
panicking arithmetic variants.
XIV e32\upwins\up_i64.cpp
-------------------------
1. Bug found in MulTop() - the two least significant words are never multiplied together
and hence the possible carry from this part into the ls word of the result is ignored.
This part may also need to be used for rounding purposes.
CHANGES TO MATHS TEST CODE
--------------------------
I T_FLOAT
---------
1. Altered and increased appropriately to test altered and new cases due to changes
in the above. Also divided into two modules containing data only (FLTDATA1.CPP and
FLTDATA2.CPP) and a header file containing class definitions because the amount
of initialised data was too large for the GCC compiler.
2. Altered and increased appropriately to test fully string to real conversion to
full range. N.B. THESE TESTS ARE CURRENTLY APPROXIMATE DUE TO AN UNRESOLVED BUG.
II T_GEN and T_GEN32
--------------------
1. Added to generate files for use by T_R64 and T_R32. These are for testing in
ARM, to see that the GCC and MSDEV compiler give the same results.
T_GEN also generates special values needed for the generation of these files and
for T_R32 and T_R64 test code.
III T_MATH
----------
1. In the light of changes made to sin, cos, tan and power functions various tests have
been added or updated:
i) tests exact results are given for: zero to a power, any number to power zero, ±1 to
any power, sin(n*pi), cos((2n+1)*pi/2) and tan(n*pi) (where n is an integer).
ii) tests overflows occur as expected for Math::Pow()
iii) tests tan((2n+1)*pi/2) overflows.
2. More comprehensive tests of trig functions have been included to test multiples of
"common" values: pi/6, pi/4, pi/3, pi/2 and pi (in addition to test for exact values
above).
3. Comprehensive testing of Math::Cos() (not just Sin() ) have been added.
4. Added test to check reduce() is working correctly.
IV T_R64 and T_R32
-------------------
1. Special values generated by T_GEN and T_GEN32 used in all tests.
2. Casting tests for TReal32s now use TReal96s. (A special test following this shows the
occurrence of an (as yet unresolved) bug.) Tests have also been added to be used when
exception handling is fully implemented.
3. All tests improved and made comprehensive.
4. Further tests added using the files generated as described in II.
5. T_R64.CPP and T_R32.CPP have also been split so their data is in a separate file
to avoid duplication of code in T_GEN and T_GEN32.
6. Arithmetic tests all test for equality rather than using BitApprox, with cases
which fail being removed until bugs are fixed so exact results are obtained in all cases.
With changes to um_r96.cpp explained in VII 2. and 4. above, T_R32 tests are now all
exact.
7. Test code has been included (for use in debug mode only) to test that exceptions
are raised correctly by the up_gcc.cpp code (which has been copied into separate files -
emgcc32.cpp and emgcc64.cpp - which may be called by these tests).
V T_R96
--------
1. Special values for use in the test code have been initialised and used in the tests
where appropriate.
2. Constructors of TReal96s from TInts, TReal32s and TReal64s tested fully, including
tests that attempting to construct from values with "bad" exponents (i.e. exponents too
big or too small) results in a return of KErrArgument.
3. Test of preparing a denormal checks that the value is not already prepared. Also added
test of preparing of an unprepared value.
4. Arithmetic tests
i) Arithmetic tests all test for equality rather than using BitApprox, with cases
which fail being removed until bugs are fixed so exact results are obtained in all cases.
ii) As a result of the bug fixed in operator/=() by Jal a test of division of denormals
has been added.
iii) Extra tests have been added to test the new member functions AddEq(), SubEq(),
MultEq() and DivEq() which perform arithmetic operations and report an error rather than
panicking if overflow, underflow or division by zero errors occur. The panicking-variants
are also tested to be sure panics occur as expected (to be run in debug only).
5. Tests of GetTReal(), casting functions unary operators, increment and decrement
operators and equalities and inequalities have been made more comprehensive and include
tests for overflow, underflow and total loss of precision errors where appropriate.
6. Tests for SetExp() and SetSign() and also for assignment operators added.
7. Increment/decrement tests now include normalising to get results consistent with
Microsoft.
Version 0.01.082
================
(Made by Morgan, 20th December 1996)
This release is binary compatible with 081
1) Morgan
1) Fixed a bug in the SWI vector code on the ARM that was calling
dispatchDfcAndReschedule incorrectly.
2) Jane
1) Changed the base addresses of WINS dlls as suggested by Martin Budden.
2) Fixed bug in CObjectIx where creating many objects could return a null handle.
3) Fixed Daylight saving bug in WINS
3) Graham
1) Modified bootup code so that it reads the keyboard to
set up ROM memory configuration. This will be used with
the masked ROM to check paged mode rom access
Version 0.01.081
================
(Made by Matthew, 17th December 1996)
This release is binary compatible with 080
1) Matthew
1) Fixed dereferencing-zero bug in CObjectCon and CObjectConIx destructors.
2) Changed EDLL WINS debug info to C7 format.
Version 0.01.080
================
(Made by Jane, 16th December 1996)
This release is binary compatible with 079
1) Morgan
1) Timers abort on power up and locale changes to universal
time, and daylight saving.
2) Fixed HA-307
2) Matthew
1) Speeded up several CObjectIx, CObjectCon and CObjectConIx
functions by using pointers into arrays instead of operator[].
3) Jane
1) Added support for real time threads. These are supervisor mode threads
whose real time response is greatly improved over ordinary user threads,
as it is possible for them to interrupt the supervisor server and
non-blocked slow exec calls.
Wrote the WINS and X86 implementations of the above, and a test driver
and test program. (D_RTIM and T_RTIM).
4) Graham
1) Added ARM implementation of real time threads.
Version 0.01.079
================
(Made by Graham, 10th December 1996)
This release is binary compatible with 078
1) Graham
1) Changed the bootstrap to map the ROM using ARM MMU 1Mb
sections. This reduces the number of TLB entries used
by the ROM and yields a 4% speed increase on our inter-
process message passing test (T_PROC1).
2) Fixed MachineInfo problems on WINS (HA-220, HA-303).
3) Patched up some Hal information services.
4) Experimentally added clicks when the digitiser is touched.
2) Matthew
1) Checked all PP::, KK::, Plat:: Panics and Faults. Some
have been changed to panic the calling thread, instead of
the kernel. This fixes bugs like HA-276 (Leave without TRAP).
Version 0.01.078
================
(Made by Graham, 7th December 1996)
This release is binary compatible with 077
1) Simon
1) Changed WINC over to use some WINS components, allowing
Store and other components to use WINS librraies for WINC
development.
WINC now conists of a EKERN ECONS and EEXE but all other
components are taken from the WINS build. The BLD.CMD has
been changed to reflect this new building model.
2) WINS EUSER added WINC initialisation functions.
3) Removed unecessary files from UPWINC
2) Graham
1) Implemented User::MachineConfiguration() and
User::SetMachineConfiguration(). These may be used to
save and restore the registry and O/S information such as
whether key clicks are enabled or sound volume is loud etc.
It is hoped that this information will now be standardised
in such a way that anyone moving from one EPOC/32 machine
to another will be able to transfer their machine's
'personality' in one go.
2) Moved P::DebugMask() to Plat::DebugMask() as it was being
exported.
3) Pete
1) PC Cards are now powered down automatically after 5
seconds if the card is left both un-configured and with no memory
allocated.
2) Fixed a problem were a CF Card was incorrectly returning
'Not supported' on each subsequent access following the
situation were a read from the card was interrupted with a media
change. (Unfortunatley interrupted writes still cause the file server
to panic).
3) Full 16bit access of CF cards (and therefore support of Hitachi
cards) now takes place when a Rev2 Etna is detected.
4) General PC Card related class renameing. Also, PC Card
configuration info. has now been moved from the EKERN into the
appropriate custom DLL for ARM builds.
Version 0.01.077
================
(Made by Graham, 6th December 1996)
1) SteveG
1) Fixed bug in battery charging LDD which hung when free'ing the
device driver. Removed debug information which was being
output to the comms port while charging was in progress
2) Morgan
1) Altered the MARM MMU PTE permissions lookup table to enable
write buffers for user data. Fixes HA-300 (Speed).
2) User::Abort now raises EExcKill exception.
3) Jane
1) Fixed Lane's shared chunk growing problem
4) Graham
1) Fixed a versioning problem with the text window notifier
server.
Version 0.01.076
================
(Made by Graham, December 3rd 1996)
This release is binary compatible with 075
1) Graham
1) Added Eiger port control code which avoids output bits
reading erroneously when they are connected to circuits
with large rise or decay times.
2) Added Minor Version 4 to the E32 version number to reflect
the fact that this is a B4 release.
3) Fixed a problem in the media driver version numbering.
2) SteveG
1) Preliminary release of the battery recharging LDD, DARCP1.LDD,
for tests by the hardware dept. This is only for the real
Proteas.
The LDD offers the following functions:
RDevNicads::Open() to open a channel
RDevNicads::Type(TInt& type) to get the charge type in progress
This will be EChargeNone, EChargeFast or EChargeTrickle
RDevNicads::SetChargeType(TInt aType) to set the type
The type should be EChargeNone, EChargeFast or EChargeTrickle.
Returns an error if it is not possible to start the requested
charging method.
RDevNicads::Close()
The functions are defined in D32RCHG.H and D32RCHG.INL
Loading the device driver using LoadLogicalDevice will start
the charging if a rechargeable battery pack is fitted. The mains
LED will flash while fast charging is in process. Once fully charged,
the battery pack is trickle charged while mains power is applied.
This can be overridden using the above functions.
3) Morgan
1) Fixed WINS so that it reports the same physical screen
size as it did before .INI-file-controlled fascia bitmaps
were introduced.
Version 0.01.075
================
(Made by Graham, November 28th 1996)
This release is not binary compatible with any previous version.
1) SteveG
a) Wrote the device driver for the serial E2PROM. This is currently
only for P1 Proteas, as the racks do not have the device fitted
The device driver is DAE2P1.LDD and provides all the commands
necessary for writing, reading, protecting and locking the
sixteen 16-bit registers in the E2PROM chip
b) Fixed bug in ARM Mem::Compare with non word aligned buffers >=16
c) Implemented keyboard repeats in the E32 text WServ
d) Added an EActive event, which is sent in WINS when the focus
is returned to the WINS window. The EInactive event is still
sent when the WINS window loses focus
e) Added an EUpdateModifers event, which is sent whenever the
WINS window gains focus. This event includes the current
state of the toggling modifier keys, and should be passed
on to the keyboard translator to update its modifier states
using KeyTranslator->UpdateModifiers(TInt). The modifiers
are extracted from the event using TInt TRawEvent::Modifiers();
E32 text WServ modified accordingly. This event is sent before
the EActive event. This event will also be sent when booting
up WINS, so the caps/num lock states will be correct at bootup.
KeyTranslator->UpdateModifiers() also resets the state of the
key translator to normal
f) Implemented keyboard clicks, the following UserHal functions
can be used to set the clicks:
to set/read the volume:
UserHal::SetKeyClickLoud(TBool)
UserHal::KeyClickLoud(TBool&)
to set/read if clicks are enabled:
UserHal::SetKeyClickEnabled(TBool);
UserHal::KeyClickEnabled(TBool&);
to override the system on/off setting, forcing clicks off
(will be used by WServ to turn off clicks when an application
requests to disable clicks while in foreground):
UserHal::SetKeyClickOverriden(TBool)
UserHal::KeyClickOverriden(TBool&)
(This function could do with a better name...:-)
Using SetKeyClickOverriden(ETrue) will disable key clicks
regardless of the system setting. The system setting can
still be changed while overriden.
Note that key clicks will not work in WINS as they produced
more of a key fart than a click. The functionality is there,
and if a way of producing a suitable click is found, will be
added in a later release (function P::KeyClick() in KP_UTL.CPP)
g) Fixed problem with CTimers going off 1 second early - this
solves the problem of alarms going off a second or so early
in TimeW app on MARM. There still appear to be problems
in WINS, which may lie elsewhere...
TSecondLink::At() now converts the absolute time you specify
to seconds since year2000, and uses this to work out the
delta value to put into the queue. This is more accurate
since the time that the queue was last ticked over is also
stored in seconds since year2000. Previously the value added
to the delta queue was the difference between the system time
and the time you supplied, which could be upto a second out
if the microseconds part of the system time was non-zero
which would be 99.9999% of the time
2) Morgan,
a) Added support for a WINS system ini file allowing some system defaults
to be setup. The .INI file lives at \EPOC32\DATA\SYSTEM.INI
and allows you to change the screen dimentions, fascia and the
LED arrangement.
The defaults are
ScreenWidth 640
ScreenHeight 240
ScreenOffsetX 123
ScreenOffsetY 53
FasciaBitmap \epoc32\data\Fascia.bmp
LedOffsetX 30
LedOffsetY 26
LedSize 14
LedGap 5
LedArrangeHorizontally
#LedArrangeVertically
b) Added exception support for MX86, MARM, and WINS:
TExceptionHandler* RThread::ExceptionHandler() const;
TInt RThread::SetExceptionHandler(TExceptionHandler* aHandler,TUint32 aMask);
void RThread::ModifyExceptionMask(TUint32 aClearMask, TUint32 aSetMask);
TInt RThread::RaiseException(TExcType aType);
TBool RThread::IsExceptionHandled(TExcType aType);
If a thread has no handler for an exception it is passed onto the
kernel for handling. The default action is to panic the offending
thread. Unhandled exceptions caused by RThread::RaiseException()
force the thread to exit via User::Exit().
Otherwise handlers are executed in the context of the thread on
which the exception is raised and control returned to the
point of the exception.
When debugging under WINS, MSDEV will intercept the exception before
the handler has a chance to execute.
c) Fixed HA-258
d) Added Uids (and -type-safe-link for ROMBUILD) to the Base components under ARM.
The Uids are #defined in \Epoc32\include\E32UID.H and \e32\kbarm\E32UID.IBY.
e) Added an iTextSize to TLoaderInfo and TRomImageHeader for GDB
f) Implemented Dll::GlobalAlloc, Dll::GlobalAllocated, Dll::GlobalRead, and
Dll::GlobalWrite.
3) Matthew
a) Fixed HA-208 (IsPresent and IsValid in TUidType should return TBool).
Also changed loads of other Is*() functions to return a TBool instead
of a TInt. A few Is*() functions which returned KErr values have been
renamed:
CObjectCon::IsValidName -> ValidateName
CObjectCon::IsUniqueFullName -> CheckUniqueName
DComm::IsValid -> Validate
b) Fixed HA-196 (inline TLocale functions not expanded in release builds).
c) Fixed HA-238 (Shortcomings of KNullUid definition): removed TUidC class
and added static functions TUid::Uid(TInt) and TUid::Null() to get round
GCC bug. #defined KNullUid as TUid::Null().
d) Changed WINS Uid scheme so that the UId is stored in a segment of its own
called ".E32_UID", to add a UID to a windows file include the code
#pragma data_seg(".E32_UID")
__WINS_UID(Uid1,Uid2,Uid3)
#pragma data_seg()
in your source.
e) Added the capability to detect thread death to the RChangeNotifier
(completes with the EChangesThreadDeath bit set).
f) Implemented User::InfoPrint() function. Also added a very simple notifier
server to the text window server so that little windows appear when
anyone calls User::Notify or InfoPrint.
g) Improved the Tls scheme so that it uses a CArrayFixFlat. According to my
benchmarking this should speed up Dll::Tls(), though it remains to be
seen what happens in the real world.
Note that there is now a Dll::FreeTls() function, and that Dll::SetTls
can now return KErrNoMemory.
h) Changed midnight crossover code, to avoid costly divisions.
i) Changes to sound driver: Fixed several bugs to do with having two LDDs
going at once. This has caused the driver to become more sensitive to
playing and recording at once, and may mean that code that previously
worked fine now returns KErrInUse. Remember that the driver keeps
playing aLaw even after the last play request has been completed, and
keeps recording until the buffer is full. If you find problems, check
that you flush the record buffer when you have stopped recording, and if
you try to record and get KErrInUse, you may want to wait until the play
buffer has had time to drain and try again before reporting an error.
Added some preliminary power handling code. Playing will stop on
switch-off and the restart from where it left off; recording will
terminate with KErrGeneral (this seemed the only appropriate value)
when you switch back on.
The PDDs now support EVolumeByValue. The values are as follows:
0-20 = EVolumeNone
21-40 = EVolumeSoft
41-60 = EVolumeMedium
61-80 = between EVolumeMedium and EVolumeLoud
81-100 = EVolumeLoud
4) Jane
a) Changed MMU from a scheme of passing 3 parameters denoting the chunk's
owner, its type (code, data etc.) and whether it was locked in physical or
linear memory, to a simpler scheme where the chunk's owner is passed throughout the MMU
system (there being a greatly increased possible number of chunk owners). This
was to enable the ARM MMU, which is more limited than the X86 one, to cope with
shared chunks being read only in one process and writable in another etc.
b) When creating certain types of chunks, kept a list of allocated pages, so that it
is possible to support 3 possible states of permissions. (On the X86 this is achievable
by merely changing the top level PDE permissions - this is not so on the ARM). This change
allows the ARM MMU to support code chunks which are read/write to start with when the file
server reads the code into them from a CF card, but later are both supervisor read/only
when in the home section and user read/only when running.
c) Made a note early on of the file server's process. Changed the ram drive chunk
to being two-state chunk, and when the file server runs, change the permissions on the
RAM chunk (top level PDEs only) so that the file server has direct access to the
RAM drive.
d) Made the RAM drive supervisor priviledges, so that no-one except the file
server (see above) can access it.
e) Added size reporting functions for spy programs
TInt RLibrary::GetRamSizes(TInt& aCodeSize, TInt& aConstDataSize);
TInt RThread::GetRamSizes(TInt& aHeapSize, TInt& aStackSize);
TInt RProcess::GetRamSizes(TInt& aCodeSize, TInt& aConstDataSize, TInt& anInitialisedDataSize, TInt& anUninitialisedDataSize);
f) Added Andrew Thoelke's optimisations to various Find and Locate functions - see
Notes for more details.
5) Graham
1) Added and enhanced Kazuhiro Konishi's unicode/japanese changes
to the text window server.
2) Added the UID into the sound driver make file and removed
all the link dependancies that the sound PDDs had upon
their LDD.
3) Fixed the dodgy digitiser (HA-284)
4) Experimentally increased the digitiser sample rate to
50 samples/s.
5) Introduced the EPointerSwitchOn event. This event contains
x and y information and is generated when pen down causes
the machine to switch on. No further pen events should be
generated until the pen has subsequently been removed from
the surface of the digitiser. I believe appropriate windows
(i.e. the application bar window) will be able to register
with the window server an interest in these events. So, normal
windows should not be troubled by them. This should solve
problem HA-325.
6) Removed the text window server's beep when switching on
normally and introduced it when switching on with the
digitiser. (This only occurs on debug builds).
6) Rog 1) Fixed RackC COM::1 bug which was causing input RS-232 lines
to be reported incorrectly.
7) Pete 1) Reduced the wait states introduced by Etna on CF Card
attribute memory reads. This was interfering with screen
refreshing when 16 shades of grey mode was enabled (HA285).
2) CF card support when powering on and off the machine has
now been added. On power off, the card is fully powered down. On power
up, TLocalDrive objects are notified of the power down, forcing them
to re-mount the disk on the next access (HA281).
3) Added the functions InCritical() and EndInCritical() to
the PC Card controller. While in-critical, media change power down is
delayed. Writes to the CF Card are now critical. Prior to this, if a
media change occured during a write to the card then this could leave
a sector with an ID error on the card.
However, there is currently a problem such that the File Server
panics if a media change occures during a write to the CF card
so this should be avoided for now.
4) PC Card controller now able to access a CIS chain in common
memory as well as attribute memory.
5) Removed the function User::PcCardCntrlInterface() and
replaced this with the class UserPcCardCntrl.
6) Added the following functions to the above class: MediaStart(),
MediaOpen(),MediaInfo(),MediaRead(),MediaWrite(). These
allow access to a media device (eg CF Card) at a media
level (rather than a partition level as do TLocalDrive.Read() and
Write()). I.E. they allow access to the partition table etc.
Version 0.01.074
================
(Made by Graham, November 6th 1996)
1) Graham
1) Fixed a leak in AddProtected() which caused the O/S to
panic with EBadDfc when stressed.
2) Added followers into the TEiger class for ports A,B,C,D
and E. Modifying these registers can now be safely
achieved without worrying about those bits which are
programmed to be input bits.
3) Added interrupt protection into all TEiger modify
functions.
4) Stopped KE_ALL debug information from coming out in all
circumstances.
2) Morgan
1) Moved WINS power off button to F9 (HA-214).
2) Fixed HA-255 and added test code.
3) Made semaphore and mutex names unique for each process to fix
HA-163. It is now possible to run 2 WINS kernels with the same
process name simultaniously.
Version 0.01.073
================
(Made by Graham, November 6th 1996)
1) Graham
1) Solved the stack problem which prevented debug information
from being emmitted in MARM debug builds.
2) Fixed WINS keyboard repeat problem when the WINS window
loses focus.
2) SteveG
1) Reduced stack usage of CObject::FullName, which was shoving a
TFullName on the stack for every owner of an object. Now only
one TFullName is put on the stack regardless of the number of
owners. This cures HA-273.
Version 0.01.072
================
(Made by Jane, October 25th 1996)
This release is the candidate B3 release. Unless there are any show-stopping
bugs, our next release will be the first in the chain leading to B4, and
will not be binary compatible with this one.
NOTE: Once again to speed the passage of this non-binary compatible release
through the system, I have released with test code failures. However in this
case I believe them to be test code problems. The following tests are failing
with kernel alloc heaven - T_CHUNK (chunk testing), T_KHEAP (thread testing)
and T_THREAD (undertaker testing). These tests fail in ARM debug builds only,
and pass on X86, which leads me to believe that these are granularity
issues in the kernel heap on ARM.
1) Jane
a) Implemented allocation of sub-page tables for ARM.
b) Fixed bugs to do with lengths of supplied filenames in
process and library loading. Took the opportunity to rationalise
the loader to do this and reduce stack impact considerably.
c) Added MMU debug supervisor calls to enable the porting of my
MMU system from its emulated environment, and converted several
tests to the new system.
d) Tidied up various APIs to their correct places, ready for
unfreeze.
Affected are the new unimplemented exception APIS, and the
RLoader::LoadLibrary
e) Added an enum, TKernPanic, to e32std.h
Now client threads will be panicked with values in this list,
rather than error numbers.
f) Fixed a couple of bugs in the low-level arm mmu implementation which
showed up with very large RAM disks.
g) Exported wildcards KMatchAny and KMatchOne from e32std.h
h) Changed RConsole::Set to RConsole::Init
i) Stopped RTest writing to comm ports (except in X86 builds)
j) Rationalised KErrxxxx constants
KErrNoLinearMemory gone, used KErrNoMemory instead
KErrSubSystem gone
KErrDomain gone, used KErrArgument instead
KErrException gone (kernel panic enum used instead)
KErrNotFound becomes -1, so that we could omit KNotFound in future.
NOTE - KErrGeneral is no longer -1. This showed up quite a few
bugs in the file server which was assuming that KNotFound was the
same thing as KErrGeneral. This is no longer the case, beware!
k) Added RThread::ProcessPriority() and RThread::SetProcessPriority()
l) Changed void RThread::GetHeap(RHeap*&) to RHeap* RThread::Heap()
m) Speeded up interprocess messaging by about 10%. A further 8%
to come in next release.
2) Steve
a) Fixed UserHal::MemoryInfo which was returning an incorrect
figure for FreeRam - it was deducting the size of the RAM
disk from the real free ram size.
3) Graham
a) Changed the ADC interface to unsigned values. This should give
doubled digitiser accuracy but meant recalibration of the
digitiser on all platforms.
b) Updated K32VIDEO.H to include power handling functions.
c) Add CountDown(n) and FirstDelta() function calls to the
priority queue class.
d) Implemented waking up from alarms.
e) Implemented waking up from pen down.
f) Implemented ESwitchOn events on all platforms (HA-229).
g) Added a beep to the Text Window Server in debug builds
when an ESwitchOn event occurs.
h) Added a general purpose interface to the ADC channels which
measure battery voltages, thermistor readings etc.
i) Made Neil Lilliot's change for reducing shadowing on the LCD.
4) Jal
a) Fixed a bug in TReal96::operator/=
Version 0.01.071
================
(Made by Graham, October 11th 1996)
1) Graham
1) Added a millisecond timer queue to the kernel. It
currently uses FRC2. All kernel services which were
using TEiger::WaitMilliseconds should now move over
to the new services provided by this queue.
2) Implemented the digitiser in terms of the millisecond
timer queue instead of the system tick queue. This enables
code to be written which can deliver more than 21 digitiser
events per second (it is currently set to 25/s). Not only
this, by driving current across the digitiser only when it
is absolutely necessary, power consumption has been
reduced. The digitiser should now work on upgraded
machines - the H/W fix for digitiser wobble involves an
increase to 1mS in the X/Y drive rise-time. In order to
take account of this rise-time, the millisecond timer was
required.
3) Implemented the buzzer in terms of the millisecond timer
queue. Due to variable interrupt latency, this does not
produce a pleasing effect. So, for the time being, I have
left the buzzer monopolising FRC1. You can switch between
this and the new millisecond timer buzzer with the compile
time switch __SOFTWARE_BUZZER__ in KEARM\KE_UTL.CPP
4) Introduced Hal::WaitMilliSeconds which uses the
millisecond timer. This replaces TEiger::WaitMilliSeconds.
5) Added device driver power handling functions in
KS_POWER.CPP.
6) Created a release of header files for those who link to
the E32 kernel (device driver writers mainly). This can
be found in R:\E32\ZIP\INCK.xxx
7) Implemented the auto clibration sequence on the ADC
converter. This cures the problem which causes the first
ever pen down event to have the wrong y-coordinate.
2) Pete
1) Fixed a bug which prevented the machine booting up with
the CF card door open.
Version 0.01.070
================
(Made by Jane, October 4th 1996)
1) Morgan
1) Priority of a process is set according to the Executable's E32Image.
2) Fixed svLibraryLoadExact to deal with statically linked libraries where
the ownership of the libraries handle belongs to the newly created process.
2) SteveG
1) Changed the keyboard data for P1 to have ' on shift-6, not ^
2) RDebug changes: Anyone can now request to be informed when a thread
panics, hits a breakpoint or causes an exception without having
called RDebug::Open. This means a panic catcher can be running
continuously and still allow GDB to be used. Previously, only one call
to RDebug::Open was allowed, meaning that the debugger could not
be used while a panic catcher was running and vice-versa.
To catch panics etc, use the following code:
SDebugInfo info;
TRequestStatus status;
RDebug::GetException(info,status);
User::WaitForRequest(status);
SDebugInfo is defined in E32SVR.H
You must kill the thread that paniced at some point using:
RDebug::KillThread(info.iThread);
or it will remain suspended forever. Do not use RDebug::Open
or you will prevent GDB from running at the same time.
If someone starts GDB while your request to GetException is pending,
GDB takes priority and you will not recieve any notifications of threads
panicing until GDB quits
Only one call to GetException can be active at any one time. It is
quite safe to call GetException while GDB is running, your request
will remain pending until the first app panics after GDB quits
To cancel a request to GetException, use RDebug::CancelGetException()
This feature has been buried by Jane's RUndertaker class which
should be used in preference ('cos she says it's better :-()
The ability to use GetException without calling RDebug::Open will
be removed in a later release.
3) Altered D_GDB, the GDB stub, so that if you launch it without
passing a program to debug on the command line, it will wait
for a thread to panic/hit a breakpoint and then call
User::Notify(). You can then start up GDB on the PC and
connect to the Protea and start debugging the thread that
paniced/hit a breakpoint.
To put a hardcoded breakpoint into your code, use the line:
asm(".word 0xe7ffffff");
in your code. Run D_GDB without passing a command line, and
start your program. When the notify appears saying that
a program has hit a breakpoint, start up GDB on the remote
PC and start debugging...
3) Jane
1) Added KErrException. Threads which make illegal accesses etc. are
now panicked with this value.
2) Added RThread::RaiseException(TExcType aType)
For the time being, this just panics a thread with category
"Exception Raised" and panic number = the exception number
TExceptionType is obsolete, and will be retired at the next thaw.
3) Filled all user mode stacks with 0x29 to aid spy programs
4) Implemented the thread death notifer service. The class is
class RUndertaker : public RHandleBase
{
public:
IMPORT_C TInt Create();
IMPORT_C TInt Logon(TRequestStatus& aStatus,TInt& aThreadHandle) const;
IMPORT_C TInt LogonCancel(TRequestStatus& aStatus) const;
};
To use the class, create an RUndertaker and logon to it like so
RUndertaker u;
u.Create();
TRequeststatus stat;
TInt handle;
u.Logon(stat, handle);
User::WaitForRequest(stat);
When a thread dies, the status word is completed, and the handle is that
of the dying thread. To look at why the thread died, for example, you might
do the following...
RThread r;
r.SetHandle(handle);
if (r.ExitReason()==0x666)
{
...
As you now have a handle on the dying thread, it won't go away until
you close it.
r.Close();
Look at T_THREAD for examples.
NOTE: This service isn't guaranteed. If a thread dies while you are not
logged on to your RUndertaker, obviously you'll miss it - and there is a
window of opportunity after a thread has died & your status has completed
and before you get chance to deal with this and logon on again.
NOTE2: Matt will be implementing a more general form of this in his
RChangeNotifier class, which will complete to tell you that a thread
has died, but not tell you *which* thread.
4) Matthew
Fixed bugs: HA-207 (%J in TTime::FormatL should abbreviate in 12hour
mode) and HA-215 (CActiveScheduler::Add should assert parameter).
5) Graham
Partial implementation of a kernel millisecond timer which
now runs the buzzer. Do not be alarmed if buzzing sounds
different in this release.
Version 0.01.069
================
(Made by Jane, September 26th 1996)
1) Jane
1) Clients causing an exception are now panicked KErrAbort.
2) Possible fix for curtains bug. Any more reports of curtains
welcome (sort of.)
The bug was caused because of the change in behaviour such that
a client thread is still hanging around when the server processes
the disconnect. If the process creator had already closed its
process handle, then the process died immediately, but the client
thread was left. Then when the client thread eventually died, it
closed its chunks, which involved removing them from the (dead)
process's address space. BANG!
Now the chunk is removed from the process address space earlier on.
2) SteveG
1) Release 068 had a problem with the MARM custom DLLs,
which prevented the LEDs from flashing. Now OK.
3) Graham
1) When the kernel faulted, it used to continue to run and
possibly do all sorts of bad things.
For the time being, we just print a helpful message to
COMM1 and loop forever. (In the future we will reset.)
Version 0.01.068
================
(Made by Jane, September 23rd 1996)
NOTE - T_RDRV failed on certain bananas. We think that it is due
to a problem with the hardware - the door open interrupt is not
asserted for these fruit.
1) Graham
1) Removed nocallentrypoint declarations in MARM .OBY files
and added dll= appropriately.
2) Fixed HA-219 which caused the digitiser to stop working
after the sound driver had been used.
3) Added a system of cumulative inertia into the digitiser.
Consider a system where a physical movement of the pen
produces an actual Pen Move Event only if it has moved
more than 1 pixel. Call this an inertia of value 1. So,
if the digitiser has an inertia value of 3, then it only
produces Pen Move Events when a movement of greater than
3 pixels in any direction has occured. The system I am
now experimenting with is one where the longer the pen
stays in one place, the greater inertia it acquires. So,
normally, with the pen moving all the time, no inertia
effects are apparent. But, when the pen comes to rest,
then the inertia begins to increase by one unit for every
1/4s that it remains within its 'inert event horizon'. It
is currently set so that the maximum possible inertia
value is 5. Clearly, I can't tell if this is a valuable
system until some higher level apps start running with
this O/S. So, feedback on this subject is especially
welcome.
4) Speculative fix for HA-217 ('Curtains').
5) Exported Hal::DisableIrqsToLevel1() et al. from the kernel
6) Reworked the kernel exception interface (TException,Exc).
2) SimonB
1) Removal of F32 code from the EWINC library
1) Addition of a new TWINC directory with MAK files for building all the code in TBAS. (The CPP files
used are the ones in TBAS). The header files from TBAS have been copied into TWINC, but this could
be rectified by changing the #includes to reference "..\TBAS\..."
1) Addition of bld and run cmd for building WINC libs, and test code. Also for running the test code.
1) Changes to MNT additional verbs
winc build the libarries
wincall
wincdeb
wincrel
wincudeb
wincurel
btwinc build the test code
btwincall
btwincdeb
btwincrel
btwincudeb
btwincurel
rtwinc Run the test code
rtwincall
rtwincdeb
rtwincrel
rtwincudeb
trwincurel
1) Changes to EWINC MAK files and build cmd file to get Unicode variants to build and work. May still
need some more changes - (the mak files were completely stuffed with release builds compiling debug
code). It may be worth recreating all mak files again froms scratch
1) Changes to E32Initialise. With the file server in a separate Dll, the init code follows the WINS
init code method for the file server.
3) Jane
1) Added new RThread::Create which takes an open RLibrary, as discussed in EON defects -
IMPORT_C TInt Create(const TDesC &aName,TThreadFunction aFunction,TInt aStackSize,TAny* aPtr,RLibrary* aLibrary,RProcess* aProcess,RHeap* aHeap, TInt aHeapMinSize,TInt aHeapMaxSize,TOwnerType aType);
This function takes all possible parameters so that a thread with an open library
handle can be created in another process, sharing a heap etc. (If the RLibrary*, RProcess*, RHeap*
are not required, just pass in NULL as usual.)
The entrypoints of the library are called before the thread's entrypoint.
NOTE - obviously the thread cannot access the handle it has on the library, so the library
can only get its final close when the thread dies.
2) Fixed a bug to do with stack chunk creation. Improved the naming scheme for chunks.
3) Various E32 Proposals
- Processes unmarked by default
- Queues don't allow shallow copies
- CActive functions const
- RTest Console() accessor for iConsole
4) Improved the kernel server protection method, which was becoming more unsafe
with the addition of each new way of shooting a client thread. (Now if the kernel
server shoots a client, it should always leave KErrKernelServerLeave, after
stashing a suitable error to shoot the client with in K::ClientErrorCode)
5) Fixed a few situations where the kernel was shooting itself rather than the client.
6) Pervasive change, such that the Owmer() of a CObject - used in forming the
name - is correct for thread-owned objects.
If a semaphore A is owned by thread B in process C its name is now C::B::A
If it was owned by process C directly it would be called C::A
4) SteveG
1) Implemented control of the LEDs on the racks and P1. It is now possible to get your
red alarm LED on your banana to flash, but it will flash green. Please note that this
is not an E32 software bug
2) Changed all occurances of TheSuperPage().iTotalRamSize to TheSuperPage().iMaxFreeRam,
and added iTotalRamSize and iTotalRomSize to the SuperPage. iRamDriveSize is now
setup correctly, and these figures will be returned properly when using UserHal::MemoryInfo
3) Added ESpecialKeyBase and ESpeicalKeyCount to E32KEYS.H. Any scancode in this range passed
to the keyboard translator will be passed through unaltered, and can be used for the
on-screen keys facility provided by the window server
5) Morgan
1) Added RLibrary::FileName()
2) Corrected the key mappings for Func and Alt on the X86 build
3) Extended Library and Process RAM loading to share ready loaded code chunks. RAM loaded
Libraries can use ROM code chunks but currently Processes cannot. Suitable code chunks
are identified by matching their checksums.
5) Matthew
1) Implemented %lx, %ld etc for formatting TInt64s. Added TLex::Val functions for TInt64s.
Removed TLex::Convert() and TLex::ConvertList().
2) Given DThreads and DProcesses ids: essentially just a unique TUint. Threads and processes
can be now opened by their id.
3) Changed Hal::RomVersion() so that it now returns version number from the rom header on
Epoc platforms.
6) Pete
1) Changes to support Asci12-Rev2. (Still works with Rev1 though).
2) ATA Driver - Validation of partition entries in MBR now added.
3) ATA Driver - CHS and LBA addressing now supported (this allows us to work with Hitachi CF
card).
7) Rog
1) Introduced a rack only bug into hardware handshaking for the Serial driver. To facilitate a
timely E32 release the serial drivers will be re-released with C32. If you don't need h/w
handshaking or can get by on WINS, these drivers are just fine.
Version 0.01.067
================
(Made by Jal, September 7th 1996)
1) Jane
1) MMU fix to do with re-allocating linear space after RAM disk
has grown.
2) More build and mnt fixes.
3) Fixed HA-204, incorrect error given by in WINS library loading.
4) Fixed HA-205, bug in RThread::Create
5) Changed the Environment class, so that all environment variables are
stored and compared in UPPER CASE.
6) Changed ks_proc as requested by Colly so that names which are duplicates except
for generation are allowed.
7) Fixed HA-95, allowing the server to refer to the client thread when processing a
disconnect message
8) Fixed HA-211, RProcess::Open stops process from being destroyed
9) Fixed HA-210, runtime checks on queues
10) Implemented basic exception handling - i.e. shooting the offending thread. Fixes
bugs HA-137 and HA-157
11) Fixed HA-212, RLibrary::Load problems after creating thread in foreign process
2) Matthew
1) Bug fixes HA-188, HA-198 and HA-202. Also fixed a time-mangling bug on
the rack, which effected relative timers due to off after more than
about 30 seconds, and a bug which caused the sound LDD to panic.
3) SteveG
1) On the WINS build, F10 and F11 now send EKeySliderDown and
EKeySliderUp keypresses. F12 key is now the OFF key and
sends an EKeyOff keypress. The UserHal::SwitchOff() function
now minimizes the WINS window, simulating switching off.
Maximising the window will simulate switching on by sending
a TEvent::SwitchOn. The Shell, or whoever switches off,
should just look for EKeyOff and then call UserHal::SwitchOff
which will then work with the correct key on all platforms
2) Implemented the TTime::Set(TDesC& aString) function which
allows setting or constructing a TTime from a date string
in the format YYYYMMDD:HHMMSS.MMMM - any part of the string
may be omitted, but either the dot or colon must be present.
Any parts of the string which are omitted are zero'd.
3) Added suitable values to be returned by the WINS memory
functions in UserHal::MemoryInfo()
4) Fixed problem with supplying long category names when
panicing a thread - only the first 16 characters used
4) Morgan
1) Fixed HA-191 by not passing the placement new as an argument to
CArrayFixBase::ResizeL.
Fixed HA-187. Under WINS Mutex are signaled in thread CleanUp code
rather than in the DPlatThread destructor.
Fixed a Bug in Time::FormatL to prevent the %C directive overflowing
the descriptor and causing a panic.
2) CArray???::FindIsq returns an index of 0 if the array is empty.
3) User::IsRomAddress is back. Again.
Version 0.01.066
================
(Made by Jane, August 23rd 1996)
1) SteveG
1) Re-fixed bug in ARM Mem::Copy and Mem::Move, which got
lost prior to releasing 0.01.065. Refixed the test
software T_FUNC.CPP as well. The bug meant that
Mem::Copy and Mem::Move didn't return the correct
address if the source and target were the same
2) Debugger fixed to take into account the changes in the
way threads start - the change meant the debugger no
longer set a breakpoint at the start of the thread
when starting a debug session
2) Matthew
1) Fixes to sound LDD and arm PDD.
3) Jane
1) Various build fixes, especially to WINC
Version 0.01.065
================
(Made by Jane and Jal, 17th August 1996)
IMPORTANT NOTE:
To avoid delaying the chain below us, this version of E32 has been released with
2 known bugs and one possible bug. They are as follows...
1. Problems on ARM build when the RAM drive grows beyond 1 Meg in size. To avoid this
bug, this release of E32/F32 implements a maximum size of 1 Meg for the RAM drive.
2. T_SOUND fails on the ARM platform.
3. T_CPER (CPeriodic test) fails on EPOC platforms. However, I believe this is not a bug
- Graham fixed the timers but the test code is out of date.
4. There are WINC test code problems which aren't worth delaying the release for.
1) Graham
1) Added microseconds to the system time. This required a
fix to TEiger::RtcTickCount() to counteract an Eiger
hardware anomoly - the SYSFLG 64ths do not roll over to
zero at the same time as the RTC rolls over its seconds.
It does this on the half-second instead. Enhanced T_TIMER
to test this roll-over effect.
2) Changed the MUTATBLE errors in E32DEF.H
3) Updated EMARM.REL to include the P1 variant device drivers
4) Fixed warnings in T_BUF.CPP.
5) Fixed intrnal TTickLink services to work with microseconds
instead of tenths. In order to help device-driver writers,
I have changed the name of the functions to
PeriodicInMicroSeconds and OneShotInMicroSeconds.
6) IMPORTANT
I have changed the way in which the timing services in E32 work.
Although the changes mean that more of the underlying mechanism
is exposed, it is hoped that this policy will result in more
programmer-friendly services once the theory has been explained.
The theory:
The timing services are based upon the regular pulse that animates
the operating system. The time between pulses is called the tick
period and this will vary according to the platform being used.
The tick period for WINS, for instance, is 100000 uS, while for
MARM it is 15625 uS.
A new service has been introduced which enables the programmer
to determine the length of the tick period in microseconds:
TInt UserHal::TickPeriod(TTimeIntervalMicroSeconds32& aPeriod)
But, for the purposes of the subsequent discussion, I will call
this length of time T.
So, we have the following situation:
---|-----------|-----------|-----------|-----------|--
<----------->
T
At any point in time, a program may request a timing service
such as User::After(x). This function should return x uS later.
Let us show this on the diagram and introduce the term y.
User::After(x)
|
---|-----------|-----------|-----+-----|-----------|--
<-----------> <----->
T y
So, y represents the amount of time between the timing service
being requested and the next system tick. It is clear that y may
be any duration of time less than or equal to T.
Let's explore the behaviour of User::After(x) for a range of
different values of x.
x=0
---
This will return on the next system tick. So, if you ask
for 0 uS, you actually get y uS.
User::After(0) Completes
| |
---|-----------|-----------|-----+-----|-----------|--
<-----------> <----->
T y |
x<T
---
This will also return on the next system tick. So, if you
ask for T-1 uS, you actually get y uS.
User::After(T-1) Completes
| |
---|-----------|-----------|-----+-----|-----------|--
<-----------> <----->
T y |
x=T
---
This will cause a wait of 1 tick to be set up. So, if you
ask for T uS, you actually get y+T uS.
User::After(T) Completes
| |
---|-----------|-----------|-----+-----|-----------|--
<-----------> <----->
T y |
x=2T-1
------
Just to expose the workings a little more. 2T-1 gets divided
by T to see how many ticks to wait. Any remainder is discarded.
Now, in integer maths, (2T-1)/T = 1. So, we set up a wait of
1 tick. So, if you ask for 2T-1 uS, you actually get y+T uS.
User::After(2T-1) Completes
| |
---|-----------|-----------|-----+-----|-----------|--
<-----------> <----->
T y |
x=2T
----
2T/T = 2. So, we set up a wait of 2 ticks. So, if you ask
for 2T uS, you actually get y+2T uS.
User::After(2T) Completes
| |
---|-----------|-----------|-----+-----|-----------|-----------|--
<-----------> <----->
T y |
Notes
-----
a. It is a slightly irksome feature of this system that if you
ask for x uS, you may end up waiting less time than x, or you
might end up waiting more time than x. It all depends on
the value of the 'wobble factor', y.
As mentioned above, if you ask for T-1 uS, you actually
get y uS. Now y could be, in fact it will in all probability
be, significantly less than T-1. On the other hand, if you ask
for T uS, you get T+y uS, which means you will be waiting a
longer time than that requested.
It is impossible, then, for the operating system using this
system to guarantee that it will wait at least as long as the
period of time requested. If this is the sort of guarantee you
need, then you will have to arrange it yourself by
adding (T-1) to your request. You can determine T using the
UserHal function mentioned above.
b. In some situations the value of y is known. Consider a
periodic timer. After the first callback, you know that
you are now synchronised to the system tick and that y
is just less than T. The 'wobble factor', in this situation,
can be taken allowed for by the programmer. So, if you start
a CPeriodic with a delay of 0 uS and an interval of 0 uS,
you will get one which immediately starts calling back on
every system tick.
c. Timing test programs commonly want to synchronise to the
system tick in order to remove the 'wobble factor' from
their calculations. This can now be achieved using User::After(0).
2) Jane
1) Added new User class layout from Martin Tasker.
2) Re-fixed WINS RDebug.Print (HA-170) which had become un-edited after
I put it in!
3) Added CObjectIx::Count() to return the total number of
objects in a CObjectIx.
4) Added RThread::HandleCount(TInt& aProcessHandleCount, TInt& aThreadHandleCount) const;
This returns the total number of handles open in a thread and
its owning process.
5) Added RHandleBase::HandleInfo(THandleInfo* anInfo);
This function fills in a THandleInfo structure with
information about the current handle.
class THandleInfo
{
public:
TInt iNumOpenInProcess;
TInt iNumOpenInThread;
TInt iNumProcesses;
TInt iNumThreads;
};
iNumOpenInProcess = the number of times the object given by
the handle is open in this process.
iNumOpenInThread = the number of times the object given by
the handle is open in this thread.
iNumProcesses = the number of processes which have a handle on the object.
iNumThreads = the number of threads which have a handle on the object.
6) Added an extra defaulted parameter to many RHandleBase derived classes' Create calls.
For example, from RMutex...
TInt CreateLocal(TOwnerType aType=EOwnerProcess);
TInt CreateGlobal(const TDesC &aName,TOwnerType aType=EOwnerProcess);
The owner type specifies whether the handle created is
thread or process relative. (The default is process-relative
as before.)
Process-relative handles may be passed between threads in
the same process without duplication. The handles are held
in the process, and are not closed when the thread dies, so
the objects will hang around until the process dies.
Thread-relative handles need to be duplicated between
threads in the same process, but the handles will be closed
when the thread dies.
IMPORTANT NOTE 1
Due to design considerations, RLibraries and RTimers are
now always thread relative handles. You will need to
duplicate them if they are shared between threads. RLibraries
should now unload when their access counts become 0.
Fixes bug HA-170
7) Fixed X86 crash on test failure.
8) Fixed HA-177 - panicking a dead thread kills the caller.
9) Fixed HA-180 - panic enum was incorrect.
10) Dll loading changes.
RLibrary load api becomes...
TInt Load(const TDesC &aFileName,const TDesC &aPath=_L(""));
If aFileName is a full filename with path, then aPath will be ignored,
and the only load attempted will be that of aFileName. If the dll is not
at the specified location, the load will fail.
If aFileName is just a rootname, (e.g. _L("ECONS.DLL")), then the dll
will be searched for in the following order - specifed path, followed by
the system directory on each attached drive.
IMPORTANT - old calls with the extension specified as the second parameter
e.g. lib.Load(_L("MYDLL"),_L(".DLL")) are now likely to fail as the second
parameter is now interpreted as a path.
11) Dll entrypoints
For the first time under EPOC, DLL entrypoints are now called.
When a process is loaded, all the DLLs to which it is statically linked
get their entrypoints called with the value EDllThreadAttach. (This call
is on behalf of and in the context of the main thread.)
When a new thread is created in the process, the statically
linked DLLs' entrypoints are again called with EDllThreadAttach in the
context of the newly created thread.
When each thread in the process dies, the entrypoints are called with
EDllThreadDetach in the context of that thread.
Unlike Windows NT, I do not call entrypoints with EDllProcessAttach and
EDllProcessDetach. This is because the function pair Dll::GlobalAlloc()
and Dll::GlobalAllocated (currently unimplemented) allow the DLL to
discover its first ever call, if necessary. This is though to be more
useful in our system then knowing a first call per process. Similarly
Dll::SetTls() and Dll::Tls() enable the DLL to discover its first load
within a thread.
When a thread loads a DLL dynamically via RLibrary::Load(), the DLL's
entrypoint is called, if and only if this is the first load of this DLL
within the thread. (So if a process is statically linked to FRED.DLL and then
a thread does an RLibrary::Load of FRED.DLL, then FRED's entrypoint is not called
in response to this load.)
The entrypoint is called with the value EDllThreadAttach in the context of the
thread loading the DLL.
The above situation is further complicated by DLL's themselves being statically
linked to other DLLs. When a DLL is loaded, I make a list of unique DLL entrypoints
in the statically linked chain, and call each of them once only. So if DLL
A is linked to DLLs B, C and D, and then B is linked to X, C and Y, and D is
linked to B, C, and Z, then the entrypoints for A, B, C, D, X, Y and Z are called
once each when A is loaded.
If A were statically linked to just B and C, then when it was loaded just the
entrypoints for A, B, C, X, Y would be called. If the same thread then went
on to load D, then the entrypoints which had not already been loaded in that
thread would be called - i.e. D and Z.
All this DLL entrypoint calling can get very time-consuming in the case of
many of the DLLs in the ROM which have no need for entrypoints to be called.
In this case, add "nocallentrypoint" after the DLL's specification line in the
obeyfile, and no entrypoints will be called for that DLL or any DLLs below it
in the static linkage chain.
All drivers should have "nocallentrypoint" specifiers.
E.g. primary=\xxx\ekernd.exe sys\kernel.exe nocallentrypoint
IMPORTANT NOTE 2
Although for many of the files "nocallentrypoint" is optional, it is compulsory for
kernel.exe and efile.exe. Bad things happen if the kernel's entrypoint is called
when something which is linked to it is loaded, and the file server doesn't take
too kindly to it either!
Also, note that the name of efsrv.dll has changed in the obeyfile. It's probably
best to cut and paste from the released E32 obeyfiles.
There are new versions of ROMBUILD & PETRAN which support the above obeyfile
changes and new structures necessary for the calling of DLL entrypoints.
12) Due to the new directory scheme, it has been possible to remove
RLibrary::LoadExact. RLibrary::Load now does a load exact - i.e. it does no
name mangling on the name passed in as a parameter.
RLoader::LoadExact has been renamed to RLoader::Load. This will affect you
if you have one of those "mini-loaders" for WINS which allows you to live
without the file server.
3) SteveG
1) Altered all builds of E32 to use the new directory structure \Epoc32\Build and
\Epoc32\Release
2) Added SetModifierState function to KeyTranslator:
TInt SetModifierState(TEventModifier aModifier,TModifierState aState)
which alters the supplied modifier according to the supplied state.
TModifierState is defined in E32Keys.h and is one of ETurnOnModifier,
ETurnOffModifier or EToggleModifier.
3) Fixed bug in KYTRAN where left and right modifiers were not being set
4) Implimented DigitizerCalibration functions, and wrote simple text shell
calibration program. A calibrator will need to be written as an Eikon app.
A calibration program should:
Call UserHal::CalibrationPoints(TCalibration& aCalibration) which will return
three screen coordinates at which points should be plotted. The user should
touch these three points, and the values returned by the digitizer for the points
actually touched should then be returned to
UserHal::SetXYInputCalibration(TCalibration aCalibration)
Note that a TCalibration actually has 4 points - the 4th is ignored by
SetXYInputCalibration
Suitable default calibration values incorporated into each ARM variant, so
the calibration on your yellow jobbie should be more or less correct without
calibrating. If yours is wildly off, please let us know
5) Added profiling support to all platforms, and increased the number of nested
profiles to 64. You can specify a range of profiles to clear/read results of.
Results returned in microseconds, but only recorded at tick resolution. This
avoids changing the API when profiles are measured more accurately.
Using profiles:
Decide on the profile numbers you are going to use, between 0 and 63. You can
use any of them, unless someone else is using some in the same ROM build.
Reset the profiles you are using, by:
RDebug::ProfileReset(aStart,aCount);
which resets aCount profiles starting from profile number aStart.
Surround the code with __PROFILE_START(n) and __PROFILE_END(n) where n is
a number of your choice between 0 and 63 inclusive. You can nest the profiles.
Return the results using:
TProfile profile[n]; // n is the number of results you are reading
RDebug::ProfileResults(&profile[0],aStart,aCount);
which writes the results of aCount profiles starting with profile number
aStart into your profile array.
TProfile is currently defined as:
class TProfile
{
TInt iTime;
TInt iCount;
};
You need to include E32SVR.H in your code to use profiles
6) Moved the keystroke data dll to the variant level, allowing
different keyboard layouts for each implementation. Changed
the P1 version to give correct keystrokes and modifiers on the
yellow jobbies.
On the real Proteas:
Fn sets EModifierLeftFunc and EModifierFunc
Menu sets EModifierLeftAlt and EModifierAlt
Fn-Esc sends an EKeyOff keypress
Fn-M sends an EKeyDecContrast keypress
Fn-, sends an EKeyIncContrast keypress
On B and C racks:
Alt sets EModifierLeftAlt and EModifierAlt
Alt-Esc sends EKeyOff
Alt-, sends EKeyDecContrast
Alt-. sends EKeyIncContrast
On WINS:
Left Alt sets EModifierLeftAlt and EModifierAlt
Right Alt sets EModifierFunc and EModifierLeftCtrl
and EModiiferCtrl (the setting of Ctrl is a Windows
funny and can't be prevented AFAIK)
7) Fixed bug with ARM coded Mem::Copy and Mem::Move where it
returned the wrong value if the source and targets were the same
4) AdamG
1) Much of ECOMM re-written to speed up data paths and fix all known serial driver
bugs.
2) Implemented reference counting of interrupts in all serial PDDs for all hardware
and platform variants.
3) Added use of NT Critical sections to WINS Serial PDD to eliminate multiple
completion bugs.
4) Corrected signal polarity in all MARM serial PDDs.
5) Matthew
1) Changes to TLocale.
Most importantly there are now four date separators and four time separators, one
for the beginning, one for the end and two potentially different internal
separators. The convention is that the NULL character represents no separator.
This has had a knock on effect on the TTime::FormatL() function: now '%:0' means
first time separator, '%/3' means the forth date separator etc.
Additionally there is now an AmPmSymbolPosition indicator, and different distance
units for different contexts: one general and two for short/long distances.
2) Added an RChangeNotifier class, for notifying users of global changes. At the
moment changes to TLocale and midnight crossover are the only things which are
notified.
To use call Create() and then Logon() with a TRequestStatus. This first Logon()
will complete straight away with the value EChangesAll. Subsequent logons will
complete next time there is a change and the status will contain a bitfield
indicating what has changed.
3) Made certain TInt64 functions inline. Also changed the default constructor so
that it does not assign zero.
4) Changed the X86 build so that getting the time returns fractions of seconds. The
time is now given to the nearest tick (which occur at just over 18.2Hz on the X86).
5) Added unary minus operators to TPoint and TSize.
6) Changes to sound driver: Fixed a bug that caused a crash when you tried cancelling
playing alarm sounds. Stopped it from panicking in Wins if you turned beeps off
from the control panel.
6) Jal
1) Various internal changes to TLocalDrive and media drivers.
2) Added operator[] to CObjectIx
7) Morgan
1) More RThread test code under Suspend/Resume conditions
and fixes to WINS and EPOC threads.
2) Moved User::IsRomAddress to the file server where it is now called
RFs::IsRomAddress
3) Added User::TickPeriod
4) Added physical screen size (in twips) to MachineInfo
8) Steve & Jane
Implemented new Epoc32 directory structure (described in more detail on Notes.)
All makefiles should be changed so that the intermediate files are built to
e.g. \Epoc32\Build\WINS\E32\Deb for exes and \Epoc32\Build\WINSD\E32\Deb for dlls.
The executables and dlls themselves should be built to
e.g. \Epoc32\Release\WINS\Deb. (NOTE - there is no "E32" in this directory path -
all releasables for a given build go to the same directory.)
E32 mnt makework currently makes the whole Epoc32 structure - this can be used to
get started.
mnt gettools gets tools to Epoc32\Tools. This should be added to your path from
the control panel. All existing paths to \tools should be removed if possible
- if not possible then the e32 tools themselves should be removed from any tools
directories in your path.
\E32SYS should also be removed from the path.
The scheme whereby executables can be installed under Epoc32\WINS\Z and appear as
if they are under Z: is not in this release, but will be in the next one. For the
time being, the old scheme with romfile.bin holds.
NOTE: GCC only runs from C:\Epoc32\GCC\BIN, so if you are working on a substed
drive, you will still need an Epoc32 directory with GCC in on C:.
Version 0.01.064
================
(Made by Graham, 26 July '96)
1) Graham
1) Integrated WINC into MNT.CMD. This version is the first
to include a release of WINC.
2) Implemented a special version of RDebug::SupervisorMode
which suits the purposes of REPRO.EXE
3) REPRO.EXE now works. It communicates with a program called
PREPRO.EXE which runs on the PC. You can get this program
from S: using GETREL PTOOL PEIGER 104 in your \TOOLS
directory. You may type PREPRO for command line options, but, in
general, you merely type PREPRO imagefilename.IMG. The PC will
then wait for the Protea to lead communications.
Now run the REPRO program on your Protea. Make sure you do
not remove mains power during the reprogramming process.
Progress will be reported on the screen of the PC.
If an error is detected during the reprogramming process,
then the program on the Protea will just restart - erasing
all the flash chips again and then programming them.
This means that if you interrupt the PC program, no
disaster will occur. If you decide you are programming the wrong
image in the middle of the process, then just escape from the PC
program, get the correct image on your PC and restart
PREPRO with this image. By the time you have done this,
the Protea will have timed out and will have decided to
restart.
4) Added Gillian's bug fix for TTime::MonthsFrom() and
TDateTime::SetHour()
5) Changed EWSRV.EXE so that it hunts for ESHELL.EXE on all
drives from A: to Z:
6) Upgraded BOOTROM.BIN to the new E32TOOLS(36)
2) SteveG
1) Fixed bug in Des::AppendNumUC which converted the whole
descriptor to uppercase rather than just the appended number
2) Added simple profiling for ARM builds, which counts the
number of times a function or section of code is executed
and the time taken in ticks. A later version will be
more accurate (using a 512kHz timer).
To use this, surround the section of code to be tested with:
__PROFILE_START(n)
and
__PROFILE_END(n)
where n is a number between 0 and 7 inclusive. You use upto
8 profiles, which can be nested if necessary. You will need
to use the RDebug class to access the results as follows:
TInt E32Main()
{
RDebug debug;
debug.ProfileReset(); // Clear readings & reset counts
__PROFILE_START(0);
<test code>
__PROFILE_END(0);
SProfileInfo profile;
debug.ProfileResult(profile);
}
SProfileInfo and RDebug are defined in E32SVR.H.
SProfileInfo is defined as:
struct SProfileInfo
{
TInt iCount[8];
TUint iTimes[8];
}
RDebug::ProfileResults returns the counts and times
for all 8 profiles, even if you are only using 1 profile.
3) ARM coded the following E32 routines which were dog slow,
and changed the relevent descriptor functions to use these
new functions rather than their own copying code
Mem::Copy
Mem::Move
Mem::Swap
Mem::Fill
Mem::Compare
TDes8::AppendNum
TDes8::AppendNumUC
and added ARM code for signed or unsigned integer divide
by 2,4,5,7,8,10 and 16, which will improve the modulo
function as well.
Speed improvements, TDes::AppendNum()
TDes8::AppendNum has been optimised for hex, decimal, octal
and binary conversions, and is improved for all other
conversions as well.
TDes::AppendNum(num,EHex) is now 614% faster
TDes::AppendNum(num,EDecimal) is now 611% faster
TDes::AppendNum(num,EOctal) is now 751% faster
TDes::AppendNum(num,EBinary) is now 1322% faster
The uppercase conversions will be the same speed as the
lowercase ones, but the %age increase will be greater due
to the fact that the string is worked out in uppercase rather
than converting the descriptor to uppercase after the conversion,
as was done in the CPP version.
Speed improvements, Mem functions
Mem::Fill is now 236% faster for word aligned buffers, and
around 400% faster for non word aligned buffers, which were
slow before
Mem::Swap is now 975% faster for buffers which have the same
word or non-word alignment and around 160% faster for buffers
which have different alignments to each other
Mem::Move and Mem::Copy are 330% faster for word aligned
buffers. For buffers with the same byte alignment, the speed
increase is around 600%. If the two buffers have different
alignments to each other, the increase is around 157%.
Mem::Move will be slightly faster than Mem::Copy as it knows
the buffers are aligned by definition of the function.
Mem::Compare: no figures yet, but descriptor compares are
around 220% faster, although this depends on what you're
comparing
Speed improvements, Integer division
No speed measurements on this, but for divide by 16,8,4,2
should be pretty big, and the divide by 10 seems to be around
200% faster. Much hair missing after realising that the GCC
routine __umodsi3 in UP_GCC.CPP (which returns the remainder
of a division), doesn't actually 'destroy r3' as it states in
the cpp file, it returns the quotient in r3, which is relied
upon in divide routines which call __umodsi3.
4) DeBugger. Drastic unimprovements to get a working version,
which is now what we have :-)) The debugger will now not
single step into EUSER or certain other DLLs, as this
causes problems on the ARM build. As the ARM processor
does not have any single step or trace mode, all single
stepping is done by looking at the next instruction to
be executed, working out where the PC will be if that
instruction is executed, and setting a breakpoint at that
address. Stepping into EUSER or certain other DLLs causes
certain death as any thread could hit that breakpoint
before the thread being stepped. Although code has been
written to silently step any thread over a breakpoint
it shouldn't stop at, serious problems occur if the
kernel hits the breakpoint while in supervisor mode or similar.
A document on how to use GDB is on R:\E32\DOCS\GDB.DOC.
Contact me on x625 if you are daring enough to try and use
the most excellent GDB software.
If you wish to use the debugger, you need to include
D_GDB.EXE in your ROM build. Please ensure this is AFTER
euser.dll in the ROM and BEFORE anything you debug.
The debugger will not single step into any part of the ROM
that is before D_GDB.EXE. This is a quick 'bodge' to get
around the problem mentioned above, and allows a quick
method of changing what you can and can't single step
into.
3) Rog
1) Added CAsyncOneShot and CAsyncCallBack. These two active object
derived classes are like a single use CIdle. They can also be used
to transfer a thread of control between two threads. Because of the
way they work both classes are added to the current active scheduler
when they are created.
2) Added delta timer class. CDeltatimer is a resource efficient timer
based on a delta queue and a single RTimer. Requests are identified by
TTimerHandles which are returned from CDeltaTimer::Queue and may be
passed to CDeltaTimer::Remove.
3) Added the fast timer driver to the source release. Due to beta
deadlines work on the fast timer has ceased.
4) Matthew
1) Various changes to the sound LDD and PDDs. The main change is that
buffering in now done entirely within the LDD.
2) Renamed TTime::SetNow() to HomeTime(); TTime::SetUniversal() to
UniversalTime() and User::SetSystemTime() to SetHomeTime(). The
"system time" is now universal time ie GMT. Home time takes into
account any daylight saving and time zone.
3) Changes to TLocale - added SpaceBeforeAmPm and changed the way
daylight saving is handled.
4) Fixed bug in second queue which caused absolute timers to run twice
as fast as they should have done.
5) Implemented RHeap::CompressAll().
5) Jane
1) Added changes from Steve Townsend to optimize region code.
2) Added timer fixes to thread clean-up code
3) Fixed the RDebug death under WINS, and implemented RDebug::Print using
OutputDebugString to the debug window.
6) Pete 1) Pc card Controller now allows allocation of card memory chunks smaller
than page size.
2) Various omissions to Pc Card Controller now attended to.
3) Improvements to media change handling.
4) Internal ram drive supports size changing.
5) TLocalDrive::Format() now calls back during formatting.
6) TLocalDrive::Caps() returns more than just size.
7) Morgan 1) Thread and Process protection.
The kernel, file server, null thread, supervisor are now marked as
system threads/processes. They are also Protected.
Any attempt to Panic, Kill, Terminate, SetPriority on a protected thread
will shoot the caller.
A thread's status can be changed with:
RThread::SetProtected(TBool)
RThread::SetSystem(TBool)
RThread::SetNotifyIfDie(TBool) (was SetServer)
RThread::SetMark(TBool)
Similar functions exist for processes.
The Exec functions (Set)Mark, and (Set)Server have been replaced with
(Set)Flags functions for threads and processes to implement this.
T_PS.EXE displays thread and process status.
2) AppendFormat and AppendFormatList changes.
Both can now take a TDes[8|16]Overflow handler which is called when the
formatting operation would write to the descriptor beyond its max length.
When this happens and no overflow handler is supplied, the default action
is to panic.
3) TTime::Format has become TTime::FormatL
4) Added CServer *CSession::Server() to return the session's server.
Added protected member TDblQueIter<CSession *> CServer::iSessionQ, an
itterator over the server's sessions.
5) Name changes
TTimeIntervalShortMicroSeconds -> TTimeIntervalMicroSeconds32
AfterInMicroSeconds -> After
TStartup -> TMachineStartupType
and some Americanisations
6) Defined __ARRAY_NO_PTRS__
and *_CAST operators
Changed __ASSERT_*(c,p) to use (... p ,0)
8) Removed huffman encoding/decoding from TBuf
9) Implemented User::IsRomAddress(TAny *)
10) Added a checksum member to TRomHeader
Version 0.01.063
================
(Made by Graham 3 July '96)
1) SteveG
1) Applied patches to the GCC tools and rebuilt them all, with lotsa
help from Nick Twyman. You now no longer need template instantiations,
and the code saving seems to be somewhere between a massive 8 and 13%,
although the exact figure will vary between projects. You will need
to remove all occurances of 'template class.....' from your .cpp files.
2) Altered the whole of E32 to compile with the new tools, removing every
'template class...' line from all the source files, altering all the
MAK files etc. The new compiler/linker are a lot more nit-picky, and
you will experience several warnings such as 'class xxx only defines
private constructors and has no friends' or 'taking address of temporary'.
Handcrafted ARM MAK files will need changing by hand, v033 of MAKTRAN will
take care of any changes for you. Any handmade ARM MAK files will need
changing as follows:
change all occurances of -m6 to -mcpu=arm710 -mapcs-32 and remove all
instances of -fno-implicit-templates. Add in -fvtable-thunks after the
-fcheck-new flag. To remove the warnings 'class xxxx only defines
private constructors and has no friends' add in the flag
-Wno-ctor-dtor-privacy after the -Wall flag.
If anyone has any problems with the new tools, please hesitate to
contact me on x625.
3) Wrote various benchmark tests to identify areas of E32 that could
improve with being written in ARM code. Start made on testing speed
increases for various descriptor/memory/number functions in ARM code.
4) Debugger (Arrrrrrrrrgh :-(
Source level debugging now possible to some extent running a debug
.exe file from the E32 text shell (if you can bear to use Gdb).
No success with an eikon app yet. Identified some problems caused
by single stepping through user functions which my breakpoint
handler uses (memcopy, array/descriptor functions etc). The first
thing my breakpoint handler does is to clear any breakpoints in
the ROM, but in doing so it cannot use any functions which might have
breakpoints set in them.
2) Matthew
1) Changed RThread::Read() and Write() so that they leave on errors.
This fixes HA-158 - CSession::WriteL(...) panics caller.
2) Added RThread::SetInitialParameter() and RThread::GetHeap(),
fixing HA-63, so you can now create an RThread, find its heap,
alloc a cell in that heap, pass the pointer to that cell as the
parameter to the thread and the thread can call User::Free on it.
3) Made KCurrentThreadHandle have the NoClose flag set, so that
Close()ing an RThread which hasn't been Create()ed is harmless.
4) RThread and RProcess::LogonCancel() now return KErrGeneral if
you are not logged on.
3) Graham
1) Built and released Protea Rev 1 (P1) variant of MARM.
2) Made WeekNoInYear and DayNoInYear const correct.
3) Removed 'API Freeze Technology'
4) Added the REPRO program which must be included (In PETRAN
format) in all P1 variant ROMs. NB this program does not
work yet.
5) Re-included Andrew Theolke's fix for Single Queues. This
means that everyone will have to remove their work-arounds
6) Fixed the HAL API problem with UserHal::BacklightBehaviour
7) Reintroduced stack frames into the debug MARM builds of EKERN
and EUSER.
4) Jane.
1) Fixed linear address allocation problem with hardware chunks.
2) Stopped a false read of CMOS data/time information under X86
killing the kernel.
3) Fixed bug HA-150 - Rng was returning T rather than TBool
4) Removed J Day hacks and old functionality for RAM loading
of exes and dlls, and added support for new E32Image format etc.
IMPORTANT NOTE - You must now update to the latest version of E32TOOLS. This
version of E32/F32 is incompatible with versions of tools pre 029.
5) Morgan
1) Added WINS Led simulation. To turn the Leds on and off use:
UserHal::ModifyLedMask(TUint aClearMask, TUint aSetMask);
with the masks, KLedMaskRed1 and KLedMaskGreen1
2) Removed the protea bitmap from the kernels WINS resource.
The bitmap is now loaded from \E32\KPWINS\PROTEA.BMP at runtime.
3) Implemented TSecondQ::SystemTimeChanged()
User::SetSystemTime() now completes all pending timers on the
K::SecondQ with KErrAbort.
4) Added DTimer::Abort() to support this.
Version 0.01.062
================
(Made by Graham, 31st May 1996)
1) Graham Fixed MARM Debug mode
2) Pete Added Media change handling. This allows CF cards to
be inserted or removed without the need to reset. All
that is now required is that the DOOR switch is
depressed during these operations.
NB Do not attempt to use the CF card (or even boot up
a rack with a CF card inserted) if your rack does not
have a special capacitor fitted to counteract a fault
in the ETNA chip (ASIC12)
Version 0.01.061
================
(Made by Graham, 30th May 1996)
1) Jane
1. Implemented E32 Proposal: TDes8::Append(const TDesC16&)
2. Implemented E32 Proposal: calling RMessage::Complete twice panics server not kernel
3. Implemented E32 Proposal: priority enumeration for active objects
4. Fixed bug HA-93: referring to a dead thread panics caller
2) Matthew
Fixed bug HA-102: K::BeepComplete can be catastrophic
3) Rog Added IrDA support to serial LDD and COM1 PDDs
Enabling Irda will automatically set framing and
handshaking to SIR standards (i.e. 8N1 None)
Added CheckConfig()=0 to PDDs this allows PDDS to
furtle with the default configuration before the
driver is created (in specific it allows the Etna
driver to disable the Fifo.)
4) Pete Added ATA media driver for Compact Flash cards
(MEDATA.PDD). This allows read/write/format of CF cards
via TLocalDrive. However, media change interrupts aren't
handled yet. Therefore racks must be powered down or Reset
before inserting or removing a card to remove power
from the CF card socket.
NB Use E32TOOLS(028) - this release contains a .EXE which exposes
a bug in earlier versions of ROMBUILD. You should also use these
tools because the new MAKTRAN causes -fcheck-new to be introduced
into the gcc compiler options.
Version 0.01.060
================
(Made by Graham, 23rd May 1996)
1) Pete
1. General enhancement to TLocalDrive and its corresponding
kernel side objects to support Media Drivers. TDriveBase/TPlatDrive
now replaced with TLocDrv which is platform independant.
2. TLocalDrive::Connect() can now take a reference to a
media change flag (TBool).
3. Internal Ram Drive now implemented using Media Driver.
4. Further improvements to RPcCardController.
2) Rog
1. All but a complete re-write of serial LDD. Throughput much
increased.
2. Support for COM1 on RackC is now available from the new
DATXPC1.PDD.
3. Hardware handshaking is currently broken.
3) Graham
1. Etna support fixed.
2. Removed redundant .FRZ files
4) Jane
1. Added support for RAM loading of dlls and exes. Currently entrypoints
are called in the same manner as for ROM exes and dlls, i.e. only once
for a process attach, and never for a thread attach/detach, or a process
detach.
IMPORTANT NOTE: To support this, the format of the rom headers has
changed, and there are new rom building tools - see E32TOOLs release notes.
The old tools are incompatible with E32 060.
2. Added RDebug::Print(TRefByValue<const TDesC> aFmt,...) which outputs
text to COM1 from user side code as an aid in debugging.
Version 0.01.059
================
(Made by Colly)
1) Fixed RLibrary::LoadExact() which would not load more than 1
DLL at a time.
Version 0.01.058
=============[==
(Made by Matthew)
1) Colly
1. Changed the _S8,_S16 and _S macros to return
const TText*
rather than
TText*
which was allowing writeable descriptors to be constructed illegally
over strings. i.e.
TPrtC(_S("Test string"));
Bad news as strings are in the text segment and read only.
Compiler will now refuse to compile the above code.
2. Renamed class TGuid to TUid and changed the representation to just
a signed integer (to keep Bill happy). Added the class TUidC where
C stands for constructor which just has two constructor, a default
constructor which effectively sets the UID to KNullUid and one
taking an integer. Given a uid of 0x10000000 then TUidC(0x10000000)
will construct the right UID. KNullUid is unfortunately implemented
as a #define to avoid class consts.
Everywhere that guid was used has now been changed to uid which
effected RLibrary and the registry functions.
Renamed the uid test DLL from T_UID to T_DUID and the test program
from T_GUID to T_UID.
3. Changed CObjectCon::FindByName() and CObjectCon::FindByFullName()
to use MatchF() instead of Match(). CObject::FullName() used to
concatenate Owner().Name() with Name(). It now concatenates
Owner().FullName() with Name().
4. Changed TCreateProcessInfo and TCreateLibraryInfo to have a TUid
which in due course will be supplied by the loader from the
.exe and .dll headers. Added the TUid to DProcess and DLibrary.
Also added iGeneration to DProcess so that more than one process
can be run at the same time.
5. Changed the name of a library to include the TUid::Name().
If library t_test.dll is loaded and it has a TUid of 0x10000001
then its name will be:
t_test[10000001]
6. Changed the name of a Process() to include the TUid::Name()
followed by iGeneration as a 4 digit decimal value. If process
t_test.exe is loaded and it has a TUid of 0x10000001 and
it is the the third copy running its name will be:
t_test[10000001]0002
7. Added Mem::Crc()
which performs the 16 bit CCITT checksum. It should be called
for a descriptor as follows:
TPtrC8 des=_L("Check string");
TUint16 crc=0;
Mem::Crc(crc,des.Ptr(),des.Length());
8. Added the TUidType class. This class packages three UIDs
together. It is intended to provide Type, SubType and
SubSubType together for the typimng mechanism in E32. It
has the following important functions:
TUidType::IsValid()
TRUE if at least one of the UIDs is not KNullUid
TUidType::IsPresent(TUid aUid)
TRUE if any one of the UIDs == aUid
TUidType::MostDerived()
{
if (iUid[2]!=KNullUid)
return(iUid[2]);
if (iUid[1]!=KNullUid)
return(iUid[1]);
return(iUid[0]);
}
9. Added the TCheckedUid class. This class packages a TUidType
together with a checksum. It is intended to be placed at the
beginning of all E32 binary files as follows:
TCheckedUid check(TUidType(0x10000001)); // Created the header
RFile f;
f.Open(theFs,_L("binary.file"),EFileWrite);
f.Write(check.Des()); // Write the descriptor
....
The class can be reinstantiated from the binary file as follows
TPckgBuf<TCheckedUid> check;
RFile f;
f.Open(theFs,_L("binary.file"),EFileRead);
f.Read(check); // Read the signature
if (check().Type().IsValid()) // Is it a valid signature
10.Added a new type TPassword which is just a 16 character buffer.
11.Added the new abstract class CSecurityBase which provides
encryption/decryption functions given a TPassword. This is
polymorphic to allow other security systems to be
substituted at a later date. One implementation of a security
system is provided which implements a polyalphabetic
substitution which is similar to that on E32 but no great shakes.
In order to use CSecurityBase merely instantiate one with
Security::NewL(). By default the security object will be
initialsed with a zero length password and disabled. To
change its value use SetL(_L(""),new password). Alternatively
it can be re-initialised with a descriptor that was previously
extracted from a CSecurityBase with CSecurityBase::SecurityData().
The data returned by CSecurityBase::SecurityData() is intended to
be saved to file and acts as a token for the associated password.
Before encrypting or decrypting data use PrepareL() and there
after make continuous calls to EncryptL() or DecryptL().
Hopefully the other functions are self explanatory.
Added test code T_SEC.CPP to test the security system.
NOTE: Passwords are currently case sensitive.
12.Added the machine password control functions
class Password
{
public:
IMPORT_C static TInt IsEnabled();
IMPORT_C static TInt SetEnable(const TPassword& aPassword,
TBool aIsEnabled);
IMPORT_C static TInt IsValid(const TPassword& aPassword);
IMPORT_C static TInt Set(const TPassword& anOldPassword,
const TPassword& aNewPassword);
};
Password::IsEnabled() returns the current state of the password
enabled flag. Password::SetEnabled() allows the state to be
changed but only if the correct password is supplied.
Password::IsValid() returns TRUE if the password is valid.
Password::Set() allows the password to be changed
By default the password is _L("")
13.Added the notifier functions:
TInt User::Notify(const TDesC& aLine1,const TDesC& aLine2,
const TDesC& aBut1);
TInt User::Notify(const TDesC& aLine1,const TDesC& aLine2,
const TDesC& aBut1,const TDesC& aBut2);
TInt User::Notify(const TDesC& aLine1,const TDesC& aLine2,
const TDesC& aBut1,const TDesC& aBut2,
const TDesC& aBut3);
The function will attempt to connect to a server called
__NOTIFIER_NAME (#define in E32SVR.H) and then send a message
ENotifierNotify with P0() pointing to a TPckgBuf<TNotifyInfo>.
It is allowable for iButton[1] or iButton[2] to be NULL in which case
one, two or three button should occur in the dialog. If aBut1
is picked then 0 is returned, 1 for aBut2 and 2 for aBut3. Any
other error such as their being no Notifier or a result being
wrong will result in a return of KErrGeneral.
14.Added Mem::Move() which has the same API as Mem::Copy(). Move()
assumes that src and trg are 2^2 aligned and that aLength is a
multiple of 4.
15.Added a new time interval TTimeIntervalShortMicroSeconds
which is an interval in micro seconds but stored in a 32
integer. This is the new interval when specifying After()
delays. Note that I have left the low level kern services
in ticks for now.
16.Renamed
RTimer::After() to RTimer::AfterInMicroSeconds()
CTimer::After() to CTimer::AfterInMicroSeconds()
User::After() to User::AfterInMicroSeconds()
CPeriodic::Start() to CPeriodic::StartInMicroSeconds()
to aid the conversion to the new interval. When converting
just multiply the value being passed originally by 100000
which is ofcourse the number of microseconds in a tenth of
a second.
17).RSessionBase::CreateSession() and
RSessionBase::SetRetry() both take a
TTimeIntervalShortMicroSeconds as the the delay interval.
18).Fixed mnt.cmd by adding %_F32VER% as the second parameter
of all recursive getXXX calls to fix defect HA-121 reported
by DavidW.
19).Made the Timer services TicksToTenths() a bit easier to
implement and OneShot() timing slightly more accurate.
2) Geert
1. Removed CArrayFixBase::DestroyAll(). Use the new
CArrayPtr<T> class template instead. (See below.)
2. Added support for objects that can only ever
live inside an array. E.g. support for a variable
array of TBufC<100000>, where the elements are just
big enough to contain the actual data in the
buffer.
CArrayFix<T>::ExpandL(TInt anIndex) opens up a slot
at anIndex by shifting the elements after anIndex
and returns a reference to the new element. The new
element is constructed in place.
ArrayFix<T>::ExtendL() is equivalent to ExpandL(Count()).
CArrayVar<T>::ExpandL(TInt anIndex,TInt aLength)
opens up a slot of size aLength at anIndex by and
is otherwise the same as the fixed record case.
CArrayVar<T>::ExtendL(TInt aLength) is equivalent
to ExpandL(Count(),aLength).
3. Added repeated insertion and re-sizing functions
to CArrayFix.
CArrayFix<T>::InsertL(TInt anIndex,const T& aRef,TInt aReplicas)
inserts a copy of aRef, aReplicas times.
CArrayFix<T>::ResizeL(TInt aCount)
extends or shrinks the array as needed for it to
contain aCount elements. Any new elements are
bitwise copies of a default-constructed T.
CArrayFix<T>::ResizeL(TInt aCount,const T& aRef)
extends or shrinks the array like ResizeL(TInt).
New elements, however, are bitwise copies of aRef.
NB. As a result of these changes, the element type
has to have an accessible default constructor. If
you have a CArrayXxx<TYyy>, and some custom
TYyy::TYyy(TZzz aZzz) exists, a TYyy::TYyy() will
have to be added. A knock-on effect is that C-style
arrays can no longer be supported as element types.
Note that array elements are still bitwise copies,
and will be Mem::Copy()-ed around during their
lifetime. Having the constructor called merely
guarantees that they'll be bitwise copies of a
properly constructed object, rather than random
garbage. In keeping with this, array functions may
construct instances of the element types, but they
will never destroy them. Element types need not
have an accessible destructor.
4. Changed CArrayXxx::InsertIsqL() and added the
new funcion InsertIsqAllowDuplicatesL()
CArrayFix<T>::InsertIsqL(const T& aRef,TKeyArrayFix &aKey)
and
CArrayFix<T>::InsertIsqAllowDuplicatesL(const T& aRef,TKeyArrayFix &aKey)
return the new element's index.
InsertIsqL() leaves with KErrAlreadyExists if a
duplicate is discovered, and
InsertIsqAllowDuplicatesL() inserts the element
after any duplicate. The existing InsertIsqL(),
returning KErrNone or KErrAlreadyExists, and taking
a TAllowDuplicates argument is withdrawn.
In the case of variable-element arrays, the
signatures are
CArrayVar<T>::InsertIsqL(const T& aRef,TInt aLength,TKeyArrayFix &aKey)
and
CArrayVar<T>::InsertIsqAllowDuplicatesL(const T& aRef,TInt aLength,TKeyArrayFix &aKey).
Note that the meaning of InsertIsqL()'s return
value has changed and care should be taken when
porting.
5. Almost all the array manipulation functions in
CArrayXxxBase have become public. This is to allow
code to operate on incoming (typed) arrays in a
type-independent way. It can be argued this reduces
type-safety and encapsulation, but the most
important thing is to guard against accidental
misuse. This is done by providing typed functions
in the template classes overriding--and hiding--all
the unsafe functions.
6. Added functions CArrayXxx<T>::At(TInt anIndex).
They are synonymous with CArrayXxx<T>::operator[]()
and serve to hide the At() functions in the base
classes.
7. Added CArrayFix<TAny>, CArrayFixFlat<TAny> and
CArrayFixSeg<TAny> as well as CArrayVar<TAny> and
CArrayPak<TAny>. They are hand-crafted and somewhat
restricted instances of the templates, for those
who wish to use a generic array; e.g., as a member
of the base class in a template pair. In the case
of CArrayFixXxx<TAny>, the record length is
specified as a constructor parameter.
8. Added functions CArrayXxx::AppendL(), Find(),
FindIsq() and InsertL() taking a reference to T
instead of a pointer. People wishing to switch to
the reference-based API may define the macro
__ARRAY_NO_PTRS__, which will hide the
pointer-based versions.
9. Added class template CArrayPtr<T> extending
CArrayFix<T*>'s interface with a ResetAndDestroy()
function. The function is intended as a type safe
replacement for CArrayFix<CBase*>::DestroyAll().
It is equivalent to a loop delete-ing all (pointer)
elements, followed by Reset().
10. CBufBase::ExpandL(TInt aPos,TInt aLength) makes
room for aLength bytes at aPos. The new contents
are undefined. InsertL(Pos,aPtr,aLength) is
equivalent to ExpandL(aPos,aLength) followed by
Write(aPos,aPtr,aLength).
11. CBufBase::ResizeL(TInt aSize) expands or
deletes from the buffer at the end so that its
Size() becomes equal to aSize. Not to be confused
with CBufFlat::SetReserveL, which has no effect on
the logical size of the buffer.
12. CBufFlat::Capacity() reports the size the
buffer can grow to without reallocation. The buffer
insertion functions are guaranteed not to leave
until the buffers Size() reaches or exceeds its
Capacity(). A flat buffer's capacity is changed
using SetReserveL().
13. Removed the global new operator taking a base
pointer and check size; ie., TAny* operator
new(TUint aSize,TAny* aBase,TInt aCheckSize)
Making sure at runtime that the allocated size is
he same as the supplied buffer size is not a very
common requirement. As it turned out, size checking
was really only required for RHeap and derived
classes. Supplying it with a custom RHeap::operator
new(), as is now the case, is actually a cheaper
solution.
14. Added zero-filling versions of the full set of
available global new operators to CBase and removed
CBase's delete operator.
The delete operator was there only as a workaround
for a problem with the Visual C++ linker. The
problem appears to be fixed in Visual C++ 4.0, so
there is now no point in having the operator.
15. Added pragma's disabling Visual C++ warnings to
do with the generation of copy constructors and
assignment operators to <e32def.h>.
16. Added private, undefined copy constructors and
assignment operators to CBase. Copying and
assignment of CBase-derived classes is now
prohibited by default.
3). Graham
1. Various keyboard changes.
2. Added HAL set and sense functions. Most are not
yet implemented but will be in 059.
4). Steve
1. Debugger:
Further improvement and additions to the debugger classes and the Gdb stub.
Still no bug fixes back form Cygnus to allow source level debugging using
Gdb. Added support for multiple thread debugging, and allowing breakpoints
to be set in ROM which effect the threads you specify rather than all
threads. Finalised the API for the RDebug class which is used by any
debugger or debug stump program. Full details of the E32 debugger class
currently in R:\E32\DOCS\RDEBUG.DOC.
2. Key translator:
Fixed the bug where the modifier status wasn't updated on a modifier key
down - it was updated on the next key up or down.
5). Jane
1. Removed saving and restoring of fs & gs in interrupt code to speed up
X86 version of EPOC.
2.Added support for debugger in finding code address of target processes.
Added MMU functions to support debugger in shadowing ROM. (Both untested).
3.Added process cleanup code to fix process logon - but left it commented
out due to time pressure in meeting API freeze. Will be tested and in
place in 059.
4.Added start of code supporting process and dll loading from RAM, and
added dummy APIs for future additions to this. Rationalised kernel
LoadLibrary functions.
5.Fixed stack scribble in runThread, which was causing an incorrect
return status to be given to logging threads.
6). Roger
Serial LDD reliability improved. Fixed double completion bugs.
Eiger Serial PDD. Turned interrupts off during initial fifo priming.
Etna Serial PDD. Written not able to test due to a (suspected) kernel bug.
Further changes to the serial drivers as of Sat 4th May given
to Colly.
7). Matthew
Preliminary sound Ldd and Pdds for Wins and Eiger. Currently the Wins PDD
pretends to play by making random beeps for the appropriate length of time
and pretends to record aLaw data by filling a bufer with silence in the
appropriate time. The Eiger PDD just plays silence.
8). Pete
Improvements to Pc Card Controller and its user interface.
Simulation of Media Change using F5 key added to WINS (commented out for
now).
Version 0.01.057
================
(Made by Graham, Friday 19th April)
1) Graham
1. Implemented MNT ARMALL, ARM, ARMDEB, ARMREL, ARMUDEB, ARMUREL
BTSTARMALL, BTSTARM, BTSTARMDEB, BTSTARMREL, BTSTARMUDEB,
BTSTARMUREL.
2. Fixed bugs in BMARM\XDUMM.MAK, XKEYB.MAK, and XXYIN.MAK
3. Fixed F32\BMARM\ESHELL.MAK to vary name according to
build - ESHELL.EXE, ESHELLD.EXE, ESHELLU.EXE, ESHELLUD.EXE
4. Updated ARM Rom building system to build debug and unicode
roms as well.
5. Ensured O/S and test programs build in DEBUG and UNICODE
as well as RELEASE mode.
6. Removed redundant LCD contrast handling from
VARMPR\VA_KEYB.CPP
7. Added KE_ETNA.CPP with the help of Roger and Peter.
8. Rationalised variant system, allowing for three MARM
variants. Each variant for a given architecture has a
two character mnemomnic:
PB Protea rack B
PC Protea rack C
P1 Protea version 1
Each variant has an E32\ sub-directory:
\E32\VARMPB
\E32\VARMPC
\E32\VARMP1
Each must contain a VA_CUST.CPP which implements class
Custom and produces an ECUST.DLL which the kernel links to.
These ECUST.DLL's are called CARMPB.DLL, CARMPC.DLL, and
CARMP1.DLL until one of them is selected to become
ECUST.DLL in the ROM.
They must also include keyboard or pointer device
implementations (VA_KEYB.CPP and VA_XYIN.CPP) which
create CAKYPB.DLL, CAKYPC.DLL, CAKYP1.DLL (Arm keyboard
DLL's) and CAXYPB.DLL, CAXYPC.DLL, CAXYP1.DLL (Arm XY
input device DLL's).
Normally, they will also include a VA_HW.CPP which
implements variant-specific hardware functionality. These go
on to produce the variant dll's VARMPB.DLL, VARMPC.DLL,
and VARMP1.DLL. Physical Device drivers (which are intrinsically
Variant-level entities) and custom dll's might want to
link to these DLL's, but the kernel cannot.
They will also contain PDD source.
The upshot of this is that .OBY files have to change.
A typical Protea Rack B .OBY file will begin:
romname=arompb.img
version=0.01
bootbinary=c:\work\emarm\bootrom.bin
romsize=0x400000
romlinearbase=0x50000000
romalign=0x1000
kerneldataaddress=0x80100000
kernelstackaddress=0x80000000
kernelheapmin=0x10000
dataaddress=0x400000
files=
primary=c:\work\emarm\ekern.exe sys\ekern.exe
file=c:\work\emarm\euser.dll sys\euser.dll
file=c:\work\emarm\elocl.dll sys\elocl.dll
secondary=c:\work\emarm\efile.exe sys\efile.exe
file=c:\work\emarm\efsrv.dll sys\efsrv.dll
file=c:\work\emarm\elocal.fsy sys\elocal.fsy
file=c:\work\emarm\ewsrv.exe sys\ewsrv.exe
file=c:\work\emarm\econs.dll sys\econs.dll
file=c:\work\emarm\edisp.dll sys\edisp.dll
file=c:\work\emarm\varmpb.dll sys\varmpb.dll
file=c:\work\emarm\carmpb.dll sys\ecust.dll
file=c:\work\emarm\cakypb.dll sys\ekeyb.dll
file=c:\work\emarm\caxypb.dll sys\exyin.dll
file=c:\work\emarm\ektran.dll sys\ektran.dll
file=c:\work\emarm\ekdata.dll sys\ekdata.dll
file=c:\work\emarm\eshell.exe sys\eshell.exe
A typical Protea Rack C .OBY file will begin:
romname=arompc.img
version=0.01
bootbinary=c:\work\emarm\bootrom.bin
romsize=0x400000
romlinearbase=0x50000000
romalign=0x1000
kerneldataaddress=0x80100000
kernelstackaddress=0x80000000
kernelheapmin=0x10000
dataaddress=0x400000
files=
primary=c:\work\emarm\ekern.exe sys\ekern.exe
file=c:\work\emarm\euser.dll sys\euser.dll
file=c:\work\emarm\elocl.dll sys\elocl.dll
secondary=c:\work\emarm\efile.exe sys\efile.exe
file=c:\work\emarm\efsrv.dll sys\efsrv.dll
file=c:\work\emarm\elocal.fsy sys\elocal.fsy
file=c:\work\emarm\ewsrv.exe sys\ewsrv.exe
file=c:\work\emarm\econs.dll sys\econs.dll
file=c:\work\emarm\edisp.dll sys\edisp.dll
file=c:\work\emarm\varmpc.dll sys\varmpc.dll
file=c:\work\emarm\carmpc.dll sys\ecust.dll
file=c:\work\emarm\cakypc.dll sys\ekeyb.dll
file=c:\work\emarm\caxypc.dll sys\exyin.dll
file=c:\work\emarm\ektran.dll sys\ektran.dll
file=c:\work\emarm\ekdata.dll sys\ekdata.dll
file=c:\work\emarm\eshell.exe sys\eshell.exe
9. Enhanced the KBARM\ rom building system to allow for the
production of all three variant ROMs.
10. Fixed spurious Pen Up events on the digitiser.
11. Added GETSRC verb to MNT.CMD
2) Morgan
1. Completed DEVICE/DRIVER name changes to LDD/PDD.
2. Added operator++() to TTimerLockSpec
3. Added TTimerLockSpec User::LockPeriod(). This returns which
of the TTimerLockSpec periods the clock is currently in.
3) Jane
1. Fixed some problems with the new chunk sheme, notably to do with
closing EPOC chunks.
2. Added a new debug only build of the .def files for X86.
3. Added MMU support for both kernel growth (contigous in linear and
high physical memory) and RAM drive growth (contigous in linear
and low physical memory) - moving other people's pages and page
tables out of the way if necessary. Added TMMU test code to test
these situations.
4. Added a new function to the bit map allocator
AllocFromTopFrom(TInt aPos) which returns the
next free page after the one specified. Tidied
up AllocFromTop() a bit while I was at it.
4) Colly
1. Added User::PageSize() to return the current machine page size.
2. Renamed RHeap::Destroy() to RHeap::Close().
3. Implemented heap sharing for heaps in chunks by having it heaps
own and use an RCriticalSection as well as supporting access counting.
The function TInt RHeap::Open() should be used to open a heap for
sharing which increases the access count. A subsequent RHeap::Close()
will decrement the access count but the heap will only be discarded
if the access count goes to zero. The static function User::ChunkHeap
includes the call to Open(). Fixed address heaps cannot be shared and
calls to Open() will be panicked.
The heaps which are created when a thread is created and which can be
retrieved with a call to User::Heap() should not be closed with a call
to Close() since the chunk in which the heap is created contains the
threads stack as well as the heap. If Close() is called the thread will
be panicked. The constanst RHeap::EChunkStack for the heaps type indicate
this kind of a heap, while RHeap::EChunkNormal indicate a heap created
with User::ChunkHeap(). Type EChunkSupervisor will never be seen
by an user mode code.
A thread is usually created with its own heap, but it can also be
created to use either the current thread's heap or a heap already
created. To use the current threads heap:
RThread t;
TInt r=t.Create(_L("Shared1"),threadEntryPoint,KDefaultStackSize,
NULL,NULL);
The first of the TWO NULLs will cause the routine to share the
current threads heap. i.e. that returned by User::Heap().
To use a heap already created:
RHeap* pH=User::ChunkHeap(_L("Share"),User::PageSize(),0x100000);
test(pH!=NULL);
RThread t;
TInt r=t.Create(_L("Shared1"),threadEntryPoint,KDefaultStackSize,
pH,NULL);
NOTE: In either case above the Heap will be opened and closed
internally so you need not provide any cleanup. If you no longer
wish to retain your copy of the heap in the example above after the
new thread has been created then you can call pH->Close().
Finally note that if thread1 creates thread2 to share its heap and
then exits thread1's chunk will remain in existence until such time
as thread2 exits. This is so since thread2's heap is now in thread1's
chunk. Such are the joys of sharing heaps.
4. Full automated heap growth is now implemented as is RHeap::Compress().
If the adjust to the heaps chunk fails the the kernel server will be
called to attempt to compress all heaps known to the kernel. When
completed a further attempt will be made to adjust the chunk so that
the heap can grow. Remember that a heap will never be compressed
below its minimum size and that heaps can onlybe compressed if they
have free space at the top of the heap.
5. Added a default argument TOwnerType aType=EOwnerProcess to most
of the operating system types CreateLocal(),CreateGlobal() and
Open() functions. Because of the default paramter this change is
seamless all current programs. The meaning of TOwnerType is to
indicate whether the resulting RObject is owned by the Process or
the Thread. Owned by the Process has been the only behaviour allowed
until this change. EOwnerThread will make the thread the owner of the
handle. The effect of being owner by the thread is that when the
thread dies any handles owned by the thread and not closed, will be
closed automatically. Example of process ownership:
RLibrary lib;
test(lib.Load(_L("TESTDLL"));
//
// The library handle will be closed when the process exits
//
User::Exit(KErrNone);
Example of thread ownership
RLibrary lib;
test(lib.Load(_L("TESTDLL"),EOwnerThread);
//
// The library handle will be closed when the thread exits
//
User::Exit(KErrNone);
NB. Although the addition of TOwnerType arguments to the
appropriate function calls has been made, EOwnerThread-type
services have not yet been implemented. This change merely
prepares the way for such an implementation.
6. Implemented the full and correct naming strategy for
objects in the base.
7. The test DLLs T_START1.DLL, T_START2.DLL and T_START3.DLL were
all using a WIN32 function GetTickCount() to delay their startup
which was preventing them from being used as a test under Epoc/32.
Changed to use User::TickCount() and removed Kernel32.lib from
the link dependencies.
5) Gillian
1. Added TDateTime::SetYear() etc functions (Brendan's
accepted proposal E32.51 TDateTime setting functions)
2. Added TTime::- and TTime-= functions for all TTimeInterval classes
(Richard Knights accepted proposal TTime should define operators -
and -=)
3. Extended TTime::DateTime() function to deal with BC dates
4. Added tests for all the above and tidied the test code up a
little.
6) Roger
1. Implemented DFcs under WINS. This allows us to use DFCs
from the serial LDD rather than the non WINs PDD. This gives
much more reliability under WINs and improved throughput under
MX86 and MARM.
7) Steve
Key Translator:
1) Added new modifier EModifierPureKey, which is set when a
ctrl-key combination does not alter the keycode (basically
any key other than Space,A-Z which return 0 to 26 respectively)
2) Fixed bug so that ctrl-space returns a NULL key press
rather than being thrown away
3) TPattern enums moved into E32SVR.H for use by wserv
Debugger:
4) Removed the Gdb stub from the E32 kernel
5) Added Debug and RDebug classes. Debug is on the Kernel side
and provides debugging functions for RDebug on the user side.
A user mode debugger or stub opens a channel to RDebug and
can then debug one or more threads. The RDebug class provides
functions for Single-stepping, setting breakpoints,
reading/writing memory and reading/setting of register
values. Watching of memory addresses will be provided
in a later release
6) Added 'TInt iDataSize' into DPlatProcess for use by the Debug
class for returning the Bss address of a Process
7) Simple program written to run on the rack which waits for
any thread to panic and then displays what has panicked
and why
8) Gdb stub written which communicates between RDebug and Gdb
running on a remote host PC. Currently the Gdb stub only copes with
debugging one thread at a time, and due to problems with Gdb itself,
only limited debugging facilities are available.
8) Pete
1. Added PC Card Controller to WINS and MARM.
9) NOTE to shared chunk users (FBSERV etc). Support for read-only
shared chunks has been withdrawn. Although the API remains, all
shared chunk users should ONLY open for read/write.
Version 0.01.056
================
(Made by Morgan, Sometime soon)
1) Matthew
Bug fixes:
HA-81: In Wins if a E32Dll returns an error this is now correctly
detected.
HA-58: (Just in time debugging added for Kernel Panics) fixed in
KSRC\KS_UTL.CPP
HA-62: (Flat buffers not compressed when cleared) fixed in
UBAS\UB_BUF.CPP.
HA-82 (ReadCancel() doesn't complete TRequestStatus) fixed in
WSRC\WS_WIN.CPP, tested in T_WSIMP.CPP.
HA-73, HA-74, HA-61, HA-52,58,61,62,69,73,74,81,82.
2) Rog
Added:
IMPORT_C void CActive::SetPriority(TInt aPriority);
inline TInt CActive::Priority();
SetPriority() will panic if the AO is active when it is called.
3) SteveT
1: Added:
TBool TRegion::Contains(const TPoint &aPoint);
Simply returns True if the point is contained within the region,
False if not.
2. Added a new template class RRegionBuf<N>
This is a cross between the two existing variants of the TRegion
class, it's black box spec is identical to the RRegion class, you
can have unlimited size regions but have to check for errors, but
a buffer big enough to hold <N> rectangles is included with the
RRegionBuf structure, this is used until it is full up when a
cell will be allocated and the whole rectangle list copied into
the allocated cell, the region will not revert back to using the
buffer even if it shrinks small enough fit.
These regions are chiefly designed to be used as temporary work
space on the stack where they will save a lot of calls to alloc
for trivial rectangle lists. Using these for long term region
storage would be inefficient as when the buffer overflows it is
left lying around empty wasting memory.
3. After calling Close() the region can safely be reused, before
it was left in a dangerous state with a pointer to the old freed
cell.
4) Jane
Changed EPOC to the new process relative chunk strategy. Under
this scheme, the process now owns a chunk, which contains the
.data and .bss (zero-filled data) sections. Each additional
thread now only has one chunk minimally, which contains its stack
and heap. This scheme saves on resources, and will allow the
process to live on if the main thread dies, a change I intend to
make later on.
Added support for shared chunks in EPOC. A global chunk - one
created with RChunk::CreateGlobal() - can be shared by other
processes/threads if they do an OpenGlobal() of the same chunk,
by name.
WARNING! The latter change has necessitated api changes in
RChunk, detailed below.
1. The Create functions have gained an extra parameter, as shown.
IMPORT_C TInt CreateLocal(TInt aSize,TInt aMaxSize);
IMPORT_C TInt CreateGlobal(const TDesC &aName,TInt aSize,TInt
aMaxSize);
The new parameter, aSize, is the number of bytes to initially
commit to the chunk. IT IS NO LONGER NECESSARY TO ADJUST A NEW
CHUNK - it will be adjusted to aSize on creation.
2. OpenGlobal has gained an extra parameter, as shown below.
IMPORT_C TInt OpenGlobal(const TDesC &aName,TBool isReadOnly);
The new parameter, isReadOnly, specifies whether the sharing
process wants readonly access to the chunk. Thus it is now
possible for the creator of a chunk to have read/write access to
it, but for others who share that chunk to be denied that
priviledge.
3. As mentioned, it is now unnecessary to adjust a newly created
chunk. It will be adjusted to aSize bytes on creation.
5) Colly
1. Added Registry and Environment services
6) Graham
1. All release mode tests run on MARM
2. Enhanced the MARM build to include DEBUG and UNICODE modes.
3. Enhanced the Eiger Text Display Deiver to switch between
1bpp, 2bpp, and 4bpp modes.
4. Text Window server allows CTRL-ALT-1, CTRL-ALT-2,
CTRL-ALT4 to switch display modes. The rack now boots up
in 2bpp.mode.
5. Released BOOTROM.BIN. It boots the rack in 2bpp mode, so
the same .BIN file may be used for Text Window Server and
Graphics Window Server ROM's.
6. Added -fno-implicit-templates to the MARM builds and
removed -fvtable-thunks.
7) Peter
1. Added proto-ramdrive.
Version 0.01.055
================
(Made by Morgan, 18 March '96)
1). NickT,
TLex??. I have added two new classes TLexMark8 and TLexMark16 and
the obvious typedef TLexMark. These classes are used to record or
mark a positon in a TLex, hence
TLex8::Mark(TLexMark8& aMark)
which can be followed by, e.g.
TLex8::UnGetToMark(TLexMark8& aMark).
By and large, wherever there was a TLex?? member function which
used the internal mark, e.g. SkipSpaceAndMark, there is a new
member which is passed a TLexMark?? or reference to one.
I have retained the internal mark iMark, changing it to a
TLexMark, and all the existing member function remain, usually as
an inline function which passes the internal mark to the general
member function.
The TLex??::Val() members no longer use the internal mark to
recover from errors but use an automatic TLexMark?? constructed
within the function.
T???Que(Base). I have added a member function Reset() to the Sgl,
DBl and Delta ques which just resets the que to be empty (the
offset remains unchanged).
CArrayFix(Base)/CArrayVar(Base). I have added new member function
which over load the existing InsertIsqL members. The change is an
addition TInt& argument.
On returning from InsertIsqL, this is set to contain the position
within the array of either the new entry or, if the entry exists
and ENoDuplicates is passed, the position of the pre-existing
entry.
2). Morgan,
Plat::TickCount on WINS fixed so 1 tick = 1/10th of a second.
CBufxxx::New is now CBufxxx::NewL. The CArray classes have been
altered to use these.
CActiveScheduler made concrete and constructor made public.
Removed PopAndDestroyAll from TCleanupTrapHandler::Untrap which
now calls CCleanup::PreviousLevel(). This ASSERTS that the
cleanup stack's current level is empty. All Pushes to the clean
up stack must be balanced with a Pop before the Trap unwinds
naturally. +Test code.
Added PushL() and Pop() member functions to TAutoClose so they
can be pushed onto the cleanup stack and are closed automatically
on a leave. +Test code.
Added TReal and TReal96 formating to TDes?::Format
New specifiers are:
%f(%F) - format TReal(TReal96) (was padding)
%e(%E) - format TReal(TReal96) using exponent format
%g(%G) - format TReal(TReal96) using general format
%p(%P) - padding (used to be %f)
and
.n - specify n decimal places
New thread test code, to test Suspend/Resume while the thread is
suspended on a semaphore.
Extended RTimer/CTimer with locked timers for synchronisation to
fractions of a second.
Included USERTYPE.DAT in the release.
3). Jane,
Fixed Exc::Dispatch which was deferencing NULL in certain cases.
Fixed DLogonProcess derivation, which was incorrect under the new
single phase destruct.
Added kernel protection for bad handles in both kernel server and
executive. Now the user thread should get panicked for a bad
handle, rather than the kernel dying when dereferencing 0. Now
that this is in place, I would welcome reports of any remaining
kernel death due to bad parameters, so that we may tighten up any
remaining loopholes.
Fixed CObjectIx::At which was panicking rather than returning 0 in
certain circumstances.
Added CObjectIx::AtL which leaves on a bad handle.
Added low memory handling to the MMU, and enhanced test code to
test that there are no alloc heavens in low memory situations.
Note that the rem page allocator function FreeHomePage() now takes
a physical address as a parameter rather than a linear one.
Added a new type of executive service, EXECUTIVE_SLOW_CONFORMANT
(int 22h on x86), which allows certain carefully chosen kernel
services to go re-entrant (i.e. be called from another slow kernel
executive service). Match8 and Match16 have been changed to this
new type, so that Match can be called from Exec::ThreadNext and
friends, thus allowing find services to work on EPOC.
4). Matthew,
Tiny change to T_CHUNK (x86): now assumes the executable is T_CHUNK
rather than TCHUNK, and the case used on the command-line is not
important.
5). SteveG
Key translation:
================
Combined the keyboard translator files into two source files,
KY_TRAN.CPP and KY_CAPT.CPP.
These make up EKTRAN.DLL, which carries out translating the
scancodes into keycodes and modifiers and handles capture keys.
KD_MC400.CPP makes up the keyboard translator data dll
(EKDATA.DLL). Removed all .data from this DLL by copious use of
const.
Fixed the keytranslator so that modifier keys are returned as
EKeyNull.
CCaptureKey and CKeyTranslator are now defined in e32svr.h for use
by the Window Server. w32keyb.h and w32keyb.inl no longer exist.
In order to use the keyboard translator, theWindow Server must at
startup create a new CKeyTranslator, eg:
CKeyTranslator* KeyTranslator=CKeyTranslator::New();
The translate key function is defined as:
KeyTranslator->TranslateKey(TUint aScanCode, TBool aKeyUp, const
CCaptureKeys& aCaptureKeys, TKeyData& aKeyData)
and an extra function for obtaining the current modifier state
has been added:
TUint KeyTranslator->GetModifierState();
Key Modifiers
=============
EModifier enums are now defined in e32virt.h and are at the top
level. Anyone making use of 'TEvent::EModifierXxxxx' should
globally replace 'TEvent::EModifier' to 'EModifier'.
Removed the TModifier class. A normal TUint should be used in
place of TModifier, and anyone using the modifier functions
IsOn(), IsOff(), TurnOn() etc should do this using | and & etc.
E32 TEvents
===========
Changed the E32 TEvent structure, and renamed it TRawEvent. A
TRawEvent is passed to the Window Server, which will create a
TWservEvent as before. TRawEvent is defined in e32svr.h and no
longer includes the modifier state. The modifier state is added in
in the Window Server for events that require the modifer state,
rather than being worked out and passed around for every event
type.
Changed the event types. Mouse events have been removed and
replaced with EPointerMove and EButtonNDown/Up events. The new
event types, defined in e32svr.h are:
enum TType
{
ENone,
EPointerMove,
EKeyDown,EKeyUp,
ERedraw,
ESwitchOn,
EInactive,
EButton1Down,EButton1Up,
EButton2Down,EButton2Up,
EButton3Down,EButton3Up
};
Changed all occurences of TEvent and TEventBuf to TRawEvent and
TRawEventBuf respectively in the E32 source and header files.
Changed Event.Set() and RawEvent copy constructors etc so they no
longer use the shiftState.
6). Colly,
Changes required to implement the proposal to give DLLs a globally
unique identifier (GUID) which can be checked before trying to
call any of the functions in the DLL. It adds two functions to
RLibrary as well as adding the concrete data type TGuid. Included
is a test program T_GUID along with a test DLL T_UID, all of which
live in TBAS. I have also fixed bugs in the .MAK files for EKTRAN
and EKDATA.
A new version of t_romg.cpp which was broken by changes to
TDes?::Format() (i.e. changing %f to %p for padding).
7). Jal,
Added methods to CSession:
IMPORT_C void ResourceCountMarkStart();
Panics client if CountResources returns KErrGeneral
IMPORT_C void ResourceCountMarkEnd();
Panics client if CountResources != iResourceCountMark
IMPORT_C virtual TInt CountResources();
Default implementation returns KErrGeneral
Version 0.01.054
================
(Made by Morgan, 23 Feb '96)
1). Colly
Removed two phase destruction. Note that all objects derived from
CActive must call Cancel() in their destructors. Note that
Adt::Destroy() has disappeared (replace with delete).
The class TAggregate depended on Adt::Destroy(), so it has
also disappeared (I don't think anyone was using it anyway).
Renamed E32ADT.H to E32BASE.H and the project UADT and TADT to
UBAS and TBAS. Decided not to include E32BASE.H in E32STD.H as
anyone can include E32BASE.H directly and achieve the same effect.
Removed all TBuf_10, TBuf_20 etc variants.
2). Jane
Added an extra flag to TModifier: EModifierDoubleClick=0x00800000
Fixed DLogons which were writing back the wrong status into the
logged thread. The net effect being that now when you try to run a
program which doesn't exist, you don't crash the OS.
Added the window server to the dll startup scheme so that the font
server can be started before it. Look at wsrc\ws_utl.cpp to see
E32's window server startup code.
Added thread relative handles for DServer, DSession and client
DThread in server DThread. This was necessary for proper cleanup
of sessions when server and client threads died. It has the
side-effect of making the WINS implementation much more like the
EPOC one - and will show up any bugs where sessions are used from
another thread.
Added the Window Server to the dll startup scheme so that the font
server can be started before it.
Fixed bug in CObjectIx::Destruct(), HA-19.
3). Matthew
Changed the base to use the new CServer/CSession with ServiceL in
CSession insted of CServer. The new versions of CSession and
CServer are now what used to be called CNewSession and CNewServer.
The windows server and test code use this new scheme.
If you have your own server/session then to convert you must
replace your CServer::ServiceL(RMessage&,CSession&) with a
CSession::ServiceL(RMessage&). In addition, if you have supplied
a CSession::CreateL() it should now be a
CSession::CreateL(CServer&).
Made TSglQueLink::Enque() private and TSglQueBase a friend of
TSglQueLink. Removed calls to Enque in T_SQUE.
Fixed X86 chunk routines. Additionally, changed WINS so that if
you try to create a chunk of negative/zero size it returns
KErrArgument instead of KErrGeneral.
4). SteveG
This change affects the Window Server:
Changed TKeyTranslator::TranslateKey(). It no longer accepts a
TModifier as the second parameter. This function now takes care of
working out and storing the current key modifier states.
Now implemented as:
TBoot TKeyTranslator::TranslateKey(TUint aScanCode, TBool aKeyUp,
const CCaptureKeys& aCaptureKeys, SKeyData& aKeyData);
Altered \wsrc\ws_main.cpp and \wsrc\keytran.h accordingly, and
altered keytran.cpp to work out the key modifier states from the
supplied scancodes.
The keycode translator is now part of E32 as two DLL's: EKDATA.DLL
and EKTRAN.DLL.
Added the stub for the Gdb debugger. This adds two classes, Gdb
and ImpGdb. Class Gdb handles the communication protocol to the
remote PC running the debugger. The ImpGdb class handles all the
implementation specific functions such as returning register
values, setting breakpoints and the sending and receiving of data
packets to the remote PC.
Altered \e32\kex86\ke_int.cpp to pass control to the Gdb stub when
a breakpoint or single step trap occurs, and \e32\kearm\ke_int.cpp
to pass control to the Gdb stub when an undefined instruction is
executed.
5). Morgan
Fixed thread cleanup code to cancel the threads timer if it had
not completed when the thread died. Previously the destructor was
attempting to close it after the thread's heap had been removed.
Made TInt64A::Cmp into a signed compare.
Fixed the DivMod function and other small fixes to get TInt64 code
running on the rack.
TInt64 operator >> now does an ASR. TInt64::Asr() has become
TInt64::Lsr()
Alloc fail tool changes:
__xHEAP_FAILNEXT(n) now fails once on the nth mem alloc.
CTimer::Create has become CTimer::ConstructL.
CActiveScheduler is now concrete.
6). Graham
Incorporated ARM E32 - find GCC porting guide in 'Protea Software Design'.
Modified test programs so that they build under gcc.
Added digitiser code (XYIN) and general ADC control code.
Added compiler support functions for software floating point.
Added 'float' conversion routines to UM_R96.CPP
Removed data from ELOCL.DLL by appropriate use of const in LSRC\*.CPP
**** WARNING TO SERVER WRITERS ****
CSession::CreateL(CServer& aServer) has changed to
CSession::CreateL(const CServer& aServer)
This is a virtual function. If you supply your own version of this
function, then be sure to change its prototype. If you don't then you won't
get a compiler warning, but your program won't work any more.
Version 0.01.053
================
(Made by Morgan, 29 Jan '96)
1). Matthew
Removed all trace of the old date\time classes.
\E32\TCDT\T_FIND, which tests the find handles.
There's also a modified version of \E32\TCDT\T_KERN.CPP, which has had it's
brief TFindXxxx tests expanded to include the ones it previously missed out.
2). SteveT
I'm just putting keyboard repeats into the window server. I've put this change
into \E32\KPWINS\KP_GUI.CPP to block windows auto repeats from getting
through.
line 169:
case WM_SYSKEYDOWN:
case WM_KEYDOWN:
if (!(HIWORD(lParam)&KF_REPEAT))
{
v.Set(TEvent::EKeyDown,PP::Sca....
Kern::AddEvent(v);
}
break;
Another change to KP_GUI.CPP to get the keyboard repeats going properly. This
adds a new TEvent type EInActive that informs me when the E32 window has lost
focus, the change I've done is as below.
case WM_ACTIVATE: // line 207
if ((lParam&0xFFFF)==WA_INACTIVE)
{
v.Set(TEvent::EInActive);
Kern::AddEvent(v);
}
break;
case WM_CHAR:
I'm not sure if this the best solution, presumably for completeness there
should be an EActive event as well, or add a true/false parameter to the event
to say whether it's an active or inactive message.
Of course on the real machine these events will never be used but I don't see
that as a problem.
3). Morgan
Serial drivers for X86 and Eiger platforms.
TLinearSectionRam::CreateRegion now rounds the committed size argument to page
size before calling Map.
4). Natascha
Character set conversion.
New test code (t_chset, t_chset2, t_chcon) for Unicode build
5). Jane
Added User::SetDebugMask to allow the setting of the trace mask around
important sections of code.
Fixed various DSession closing and CServer bugs, including HA-51. EPOCX86 can
now run a test program more than once!!
Fixed a process creation bug.
Version 0.01.052
================
(Made by Matthew, 16 Jan '96)
1). Matthew
Modified the kernel to use the new date/time classes internally. This includes
the addition of new overloaded functions duplicating old ones. This should not
effect the external interface except in a few cases, where some functions have
been renamed XxxOld().
In release 053 the old functions will be removed and some data members will be
changed to the new date/time classes.
2). Natascha
Character set conversion.
Replaced \e32\lsrc\LS_850.CPP with new file \e32\lsrc\LS_LAT1.CPP, which has
the same format:
type table for characters
and conversions for upper case, lower case, folding and collating.
for the Windows ISO Latin 1 character set.
There are 3 test programs:
1) \e32\tlocale\t_chset.mak which writes to a file "chtest.txt" the descriptions
for the characters 32 - 255 together with a description of the character it is
mapped to for each of the upper case, lower case, folding and collating conversions.
It does this by reading from the tables in LS_LAT1.CPP directly. This is designed
to test the mapping tables in LS_LAT1.CPP.
2) \e32\tlocale\t_chset2.mak which produces the same output to a file "chtest2.txt"
and console, but uses the functions provided by the TChar class instead of reading
the tables directly. This is designed to test that the changes made in
\e32\bwins\elocl.mak have taken effect. Note there is no collate output since
TChar has no collate function.
3) \e32\tlocale\t_chcon.mak which produces a console output displaying the
attributes of a range of characters 0xC0-0xCF using functions in TChar. This
tests that the type table in LS_LAT1.CPP is correct.
All 3 test programs read from the text file e32\tlocale\winiso.txt.
Note that currently these new tests do not compile in unicode build.
3). Matthew
Replaced TBool TRegion::Check() with TBool TRegion::IsContainedBy(), which
has the opposite sense, ie it returns ETrue when Check() returned EFalse and
vice-versa.
4). Roger
Added write(0) functionality to the serial LDD.
A request to Write(...) with either a zero length descriptor or an explicit
zero length will not complete until the control lines are asserted in such a
way that a further write would actually send characters on to the line. The
exact behaviour of write(0) depends upon the iHandshaking field in the current
config.
eg.
void WaitForCTS(RComm& aSerial)
//
// Synchronously wait for CTS to be asserted, assumes aSerial is Open.
//
{
TCommConfig cBuf;
TCommConfigV01& c=cBuf();
aSerial.Config(cBuf);
c.iHandshake=KConfigObeyCTS;
TRequestStatus stat;
aSerial.Write(stat,TPtr8(NULL,0),0);
User::WaitForRequest(stat);
}
The XOn/XOff bits of iHandshaking are ignored for Write(0).
There are no changes to the PDD.
5). Jane
Wrote display dll, video device (LDD) and VGA driver (PDD) for EPOCx86.
Fixed ImpHal::DisableInt() which was only pushing 16 bits of flags.
KMaxSectionBase in m32std.h was wrong - fixed.
Added TExec which tests number of exec calls in one second.
6). Graham
Fixed allocation of run addresses to chunks in DPlatProcess::
AllocateDataSectionBase().
7). Roger
Implemented CNewServer and CNewSession to run alongside CServer and CSession as
proposed in MartinT's E32 proposal "ServiceL() should belong to CSession, not
CServer". See E32 proposals for the API.
This code is not part of a fully accepted proposal as yet - the code is included
in the release to A) make further testing with the socket server less painful
and B) allow others to migrate servers to the new scheme if they wish.
Assuming the proposal becomes accepted, CServer and CSession will be replaced
with CNewServer and CNewSession.
8). Matthew
Maths bug fixes and test code.
Version 0.01.051
================
(Made by Matthew, 21 Dec '95)
1). Jane
Implemented dll and device loading for EPOC platforms.
IMPORTANT NOTE
We have decided that when the entrypoint of a dll (E32Dll) succeeds, it should
return KErrNone rather than TRUE. Under WINS, the true entrypoint (_E32Dll)
converts KErrNone to TRUE before returning, but under EPOC this is not
necessary and we get tighter code by being able just to pass on the return
value of E32Dll().
So in release 051 all dll entrypoints must now return KErrNone if successful.
Added functions TBool User::JustInTime() and User::SetJustInTime(TBool) to
allow getting/setting a kernel variable which controls whether the debugger
macro executes its int 3 to do just in time debugging of panics with Visual
C++. The default is ETrue, i.e. just in time debugging is enabled.
All test code which traps deliberate panics should set this variable to
false around the code in question, to prevent Visual C++ firing up. See
TADT\T_CTIMER.CPP
2). Morgan
Changes to TReal96: Changed KMatissaBits back to 53.
Added Normalise and Prepare functions.
GetTReal is now a const function.
3). Gillian
Changes to the date and time classes
The following is a summary of the new classes, but see the report in E32 proposals
(Replacement for the existing date and time classes), and the ensuing discussion
for a fuller description of the classes and the motivation for these changes.
To avoid a name clash, the existing TDateTime class has been renamed TOldDateTime.
This along with TSystemTime, SDaySec, SDate and STime and the static date and time
functions in Userwill be withdrawn in release 053.
The functionality previously in TDateTime is provided by TTime which holds the
number of microseconds since midnight on 1st January 0AD in a TInt64. A TTime
object may be constructed from a TInt64, a TDateTime (see below) or a string
literal. Default construction will set the time 0.00am 1st January 2000AD. This
class also supports comparisons between TTimes, the addition of TTimeIntervals
(see below) to TTimes and the subtraction of TTimes (giving a TTimeInterval as the
result). Such arithmetic operations are allowed to over- or underflow, but an error
is returned if the results of a subtraction are too large to fit in the relevent
(32-bit) TTimeInterval.
The class TTimeIntervalMicroSeconds represents a 64-bit signed difference and the
classes TTimeIntervalSeconds, ...Minutes, ...Hours, ...Days, ...Months, ...Years
all derived from TTimeIntervalBase represent the differences in the rest of the
time bases in a 32-bit signed integer. These classes only support getting, setting
and comparison functions.
The new class TDateTime has been defined for easy user access to TTime. It has
year, month, day, hour, minute, second and microsecond data members, all held as
TInts and therefore replaces the SDate and STime structs. This can hold times longer
than TTime but no checks will be made on construction or assignment. The TDateTime
class will only support getting and setting functions.
The static functions date and time functions previously in User are now in the class
Time.
Omissions - BC dates, string parsing.
Proviso - Due to bug in TInt64 class Time::MaxTTime() and MinTTime() fail comparisons
4). Colly
Removed RThread::Read() and Write() variants taking 2 parameters.
Provided RMessage::ReadL and WriteL functions. These call the appropriate Client
functions, so the code like
myMessage.Client().Read(...)
should now be changed to
myMessage.ReadL(...)
Removed AllocHeaps.
Added preliminary code for support of shared heaps. In functions where a heap was
previously created using given min and max heap sizes there is now an extra argument:
RHeap * aHeap. If this is NULL then everything proceeds as before. Otherwise, the
given heap is used. However, this is not properly implemented as yet and so for now
you should always pass a null pointer.
Replaced the constructor RHeap(THeapType aType,TInt aMinLength,TInt aMaxLength,TInt
aGrowBy) with RHeap(TInt aMaxLength).
5). Matthew
If TCallBack::iFunction==NULL then TCallBack::CallBack() returns 0. The default
constructor now sets iFunction=NULL.
CBufBase::DoInsertL() has been made private and a new overloaded variant of InsertL
has been added.
Added CActiveScheduler::Level(), which returns iLevel.
6). New error codes:
const TInt KErrTimedOut=(-33);
const TInt KErrCouldNotConnect=(-34);
const TInt KErrCouldNotDisconnect=(-35);
const TInt KErrSubSystem=(-36);
const TInt KErrBadLibraryEntryPoint=(-37);
const TInt KErrBadDescriptor=(-38);
Version 0.01.050
================
(Made by Matthew, 12 Dec '95)
1). Roger/Mark
Comms bug fixes.
2). Jal
Circular buffer bug fix.
3). Roger
RThread::Duplicate() fix.
4). Jane
Improved the build system. Added mnt cleanup, mnt cleanwins and mnt
cleanx86 which delete all the intermediate files for all builds, just
WINS and just X86 respectively. A cleanup should always be performed
before the first build of a new release of E32.
Fixed clean-up of a thread's kernel server session when it dies.
DPlatThread::Create() was not opening the thread it created, and thus
the access count was too low, causing death when the thread died. Fixed.
Fixed TTimerInt::TimerComplete() to switch interrupts off during the
non-atomic decrement of the dfc pending flag.
Made CObject::AccessCount() public rather than protected - mainly for use
in debugging.
5). Geert
Changed to a new scheme for boolean values. As the change has considerable
impact there is a fair amount of material here, including some background
information. Feel free to skip anything that looks familiar:
In a statement such as
if (cond) s1;
else s2;
C++ will execute s1 if cond!=0, and s2 if cond==0. In general, C++ treats
boolean values as false if they are equal to zero, and true if they are
anything else. The if statement, ?:, &&, || and ! operators all work on
this assumption.
However, the _result_ of a C++ calculation with boolean values is defined
to be zero for false, and (int) 1 for true: the built-in &&, ||, !, ==,
!=, <, >, <= and >= operators all return either 0 or 1.
Thus, although 1 is the most usual value representing 'true', it is not
the only value that can mean 'true'. It is therefore _bad practice_ to
compare any boolean variable with 1 (or ETrue, or TRUE), to see whether
it's true:
if (x==ETrue) s1;
will only execute s1 if x==1, whereas
if (x) s1;
will execute s1 if x!=0, which is the correct definition of 'true'ness.
The draft ANSI C++ standard includes a 'bool' type that has the right
properties. The TBool introduced here has two main design goals:
(i) when ANSI compilers become widely available, it will be possible to
replace the current type definition with
typedef bool TBool;
and everything will work perfectly
(ii) it is designed to cause the compiler to generate an error message
whenever a TBool is compared with ETrue. This forces you to fix code that
is potentially in error, before your code will successfully compile.
TBool is no longer an enumeration. It is now an integral type best thought
of as the type of boolean operators such as <, ==, !=, etc. The only
significant property of its values is whether they are zero (false) or
non-zero (true). The EFalse and ETrue enumeration constants are available
as boolean literals, but a TBool does _not_ have to be equal to ETrue to
be considered true.
This has some impact on the kinds of expressions you can meaningfully
write using TBools. Comparisons between boolean variables are meaningless,
for instance. On the other hand, a statement such as
if (x==EFalse) s1;
is equivalent to
if (!x) s1;
which is not only more concise but also more expressive in many contexts.
The most common meaningless expressions involving TBools; i.e., the likes
of
if (x==ETrue) s1;
are trapped at compile time, or link time at the latest. Use
if (x) s1;
instead.
Another commonly used construct is
return(x ? ETrue : EFalse);
where the conditional is now entirely redundant. As a side effect of the
definition of EFalse and ETrue, this code no longer compiles. Examples of
other code intended to achieve the same effect are:
return((TBool)(x));
or
if (x) return(ETrue);
else return(EFalse);
or one of many variants. These are not picked up by the compiler.
Comparisons of one TBool to another are not trapped, nor are other
meaningless constructs such as
if (x<=ETrue) s1;
To help the human reader, all boolean values should be declared as TBool,
including: member data; function parameters taking booleans; functions
returning booleans and especially overloaded boolean operators such as
operator==(), operator!=() etc. Where booleans are packed into TInt8s or
the like to save space, consider using a flags word instead.
In rare cases TBools may have to be converted into integer values. This
may be the case when packing booleans into bytes, or when streaming them
out. One elegant and efficient way of doing that is to compare to EFalse;
e.g.,
TUint8 iPresent[aColorComponent]=(TUint8)(aComponentPresent!=EFalse);
Just casting is not sufficient because vital non-zero bits in the incoming
boolean may be lost.
Moreover, it is sometimes useful to assert things about the exact integer
value of a boolean. One example of this is test code. The built-in boolean
operators return either 0 or 1. It may be desirable to specify the same
behaviour for overloaded operators or even ordinary member functions. Use
the FALSE and TRUE macros in those cases; e.g.,
test((des1<des2)==TRUE);
The macros may also be useful when an ordinary integer is regarded as a
boolean. The E32Dll() entry point returns a TInt, for instance. FALSE and
TRUE may be used in that context. Another use is at the interface with
external code, such as the Win32 API. As a final example: a callback
function to be used in the context of a CIdle object might use the macros,
since its TInt return value is interpreted as a boolean.
Note that the conversion to this new scheme is only partially implemented
in the base.
6). Steve
New functions TSize TPoint::AsSize and TPoint TSize::AsPoint return
this as the respective type. Removed overloaded functions in TPoint,
TSize and TRect.
TSize::SetWH renamed to SetSize.
TRect - Functions renamed from Offset to Move and Normalise to
Normalize. New functions: Size, Width, Height, IsNormalized, Center,
SetSize, SetWidth and SetHeight.
Version 0.01.049
================
(Made by Matthew, 21 Nov 1995)
1). Andrew
The constness of the parameters to CCleanup::PushL and
CleanupStack::PushL has gone.
CCleanup and CleanupStack now have an extra PushL overload: This
takes a TCleanupItem, which is callback. This enables any component
to be placed on the cleanup stack by providing a implicit cast to
TCleanupItem: the component will require a static member which conforms
to the TCleanupOperation prototype, with which it can constuct a
TCleanupItem. The overhead of all this is negligible _only_ if the cast
operator is inline!
See the RItem class in the T_CTRAP test code for an example of how to
do this.
It is possible to push a no-data callback on the stack, though the function
must take a dummy TAny * parameter. Such a function can be PushLed
directly, as TCleanupItem provides a constructor from a TCleanupOperation.
2). Jane
Added code for the WINS platform to allow DLLs to startup in a chosen
order. When E32Dll() is first called (aReason==EDllProcessAttach), a new
function UserSvr::InitRegisterCallback(TCallBack t, TInt p) should be
called. This registers t as a callback function with priority p. All the
start-up functionality of E32Dll() should now be moved to the callback.
After all the DLLs have been loaded, the kernel runs through a priority
queue, doing callbacks in the requested order, and waiting on a semaphore
between each call. Before it terminates, the callback function should call
UserSvr::ServerStarted() to signal the semaphore, and allow the kernel to
callback to the next DLL's registered function.
See the t_start files in TADT.
Added support for sharing loading of dlls.
Fixed the thread cleanup code to correctly free resources owned by the
session, and exit cleanly if the thread creation failed due to lack of
heap. Should fix HA-7.
3). Matthew
CObject::Close now panics if the access count becomes negative, new test
code checks this.
In WINS, PP:MapLastError returns KErrDoesNotExist for the NT error code
ERROR_MOD_NOT_FOUND. This fixes HA-22.
Added a function RLibrary::LoadExact which loads a DLL without mangling
the name. To use this you will need F32 build 13.
4). Roger
Added __DEBUGGER() Macro.
Under WINS and MX86 this macro will place an inline int3 instruction into
your code. For ARM builds the macro expands to a SWI instruction.
The macro compiles out under release builds.
Under WINS __DEBUGGER() will cause the application to drop into the
debugger - it will also invoke just in time debugging if your system has
it enabled.
There is no kernel debugger support for ARM or MX86 builds.
The Macro is currently defined in E32STD.h this is a temporary measure
until there is a good area for platform specific pre-processor macros.
Fixed the two DPlatThreads with the same NT thread id in the kernel's
list of threads bug, HA-16 and HA-6.
5). Graham
New ARM code, added function TEiger::BootWaitMilliseconds(), changed
ArmVectorIrq() and CScreenDriverMarm::Blit().
Version 0.01.048
================
(Made by Jane,13 Nov 1995)
1). Colly
If a function has a parameter by reference immediately before the
ellipsis argument as in:
RTest::Printf(const TDesC &aFmt,...)
then there is a problem when using the variable argument macros as
follows:
VA_LIST list;
VA_START(list,aFmt);
since the macro use &aFmt to try and get the address of the argument
on the stack. However this does not work with arguments passed by
reference since &aFmt is the real address of the descriptor. I have
been using a special function User::SetVaArgList() to overcome this
difficulty. However this function does not work with register calling
conventions as for the ARM compiler and so a better solution has been
found. Many thanks to Geert for the solution as follows:
A new class has been defined TRefByValue as follows:
template <class T>
class TRefByValue
{
public:
inline TRefByValue(T &aRef);
inline operator T &();
private:
TRefByValue &operator=(TRefByValue aRef);
private:
T &iRef;
};
The assignment operator is just to stop the compiler whining since
it cannot generate the assignment operator. The trick is to pass a
reference by value and then have a cast to return the refernce again.
So all that needs to change is the function declaration as follows:
RTest::Printf(TRefByValue<const TDesC> aFmt,...)
Note that the TRefByValue is now passed by value so that
VA_START(list,aFmt)
will now work. SetVaArgList has now thankfully been banished.
NOTE: No functions calling these functions with ... should need
to be changed.
As a consequence of this change three pairs of overloaded functions
are now ambiguous:
TDesC::Format(TRefByValue<const TDesC8> aFmt,...); and
TDesC::Format(const TDesC8 &aFmt,VA_LIST aList);
TDesC::AppendFormat(TRefByValue<const TDesC8> aFmt,...); and
TDesC::AppendFormat(const TDesC8 &aFmt,VA_LIST aList);
TLex::Convert(TRefByValue<const TDesC8> aFormat,...);
TLex::Convert(const TDesC8 &aFormat,VA_LIST aList);
Resolved the ambiguity in each case by renaming the function which
takes the VA_LIST argument to end in List, i.e.
TDesC::FormatList(const TDesC8 &aFmt,VA_LIST aList);
TDesC::AppendFormatList(const TDesC8 &aFmt,VA_LIST aList);
TLex::ConvertList(const TDesC8 &aFormat,VA_LIST aList);
2). Colly
A mis-understanding between myself and Nick Twyman caused me to
change EXPORT_C to be defined empty. This is not correct and I have
put it back to the correct #define EXPORT_C __declspec(dllexport)
3). Colly
Fixed a bug in the TReal96 class which then showed up a failure
in the implementation of TReal96. TReal96 on being Set() was always
shifting the mantissa left three and then subtracting 3 from the
exponent. However all the function were not allowing for this. I
have changed the Set() code not to to the shift any longer. So if
real calculations are to be performed the shift will have to be
done before the calculation. GetTReal() and the cast to TReal
normalise as before. GetTReal() had a bug in that it was
normalising *this along the way to converting to a TReal. It should
in fact do nothing and be changed to a const function. Two new
functions need to be added, Normalise() and Prepare(). Normalise()
will do most of what GetTReal() is doing now but will do it directly
on *this, while Prepare() will do the left shift by three.
4). Colly
Changed all executive services to have 4 or less arguments to suit
the calling convention of the GCC compiler. i.e. all arguments are
in registers.
5). Colly
Added the ARM implementation of Epoc/32 for the Eiger chip and finally
got a workable release of the GNU tool chain from Cygnus. Work is now
progressing on getting Epoc/32 running on Eiger.
6). Graham
Various Eiger fixes.
7.) Jane
Changed build system adding the verbs mnt cleanup (deletes everything from \e32sys
and \work\e32\...) and mnt blddef (automated build of all the .def files into
\E32\BWINS and \E32\BMX86 directories). Made several changes to the DEFMAKE tool
to support this.
These should only need to be used by the base team - others can continue to
use mnt bldall etc. as usual.
8). Matthew
Test code for CPeriodic and TDayName etc added.
Fixed rounding bug in um_rtod.cpp (HA-15) & adapted Martin Hardman's test
code.
9). Jane
Fixed HA-13, setting iBase=0 in DestroyAll(), and wrote test code. Note that
DestroyAll() is due to be replaced by a function in a new class CArrayFixFlatCBase
which will subclass CArrayFixFlat<CBase *> and thus can be type safe.
10). Jane
Changed EXE header format in kernel and E32ROM to contain stack & heap maximum
and minimum sizes.
11). Jane
MMU - added allocation of linear regions (chunks) from high memory for DLLs, and
wrote test code.
12). Morgan
Maths fixes.
T_MATH.CPP:
2 sin tests (lines 1317-1321) were failing with the new TReal96 due to inaccurate
values for sin(3) and sin(4).
lntest4 now uses a bit test ( using the 'approx' class) to compare the results taking
into account any bit wobble.
UM_INT.CPP:
Fixed Math::Int(TReal &aTrg,const TReal &aSrc) aSrc.Exp() = KMantissaBits-32.
(Left shifting a TInt by 32 (eg x<<32) results in 0xffffffff when it was required to be 0).
UP_I64.CPP
Added TInt64A::MulTop which returns the top 64 bits of a 64x64->128 multiply.
UM_R96.CPP - TReal96 functions
Set() now writes the correct exponent for a 56 bit mantissa (and is consistent with the
transendental fuctions when KMantissaBits=56)
Added TMathPanics
Added test code for TReal96, RChunks and more tests for Int64
13). Colly
Various X86 keyboard fixes.
14). Martin
Changed Alloc heaven 'dialog' so that address of offending cell is visible.
Added a Replace function to descriptors (courtesy of Brendan), with test code.
Fixed TPtr::Set function to do the right thing with maxlen, modified test code.
15). Graham
Windows server changes.
16). Jane
Added KBX86 and KBARM boot source to PVCS.
Version 0.01.047
================
(Made by Colly, 9 Oct 1995)
1). Changed all TUint to TInt.
2). The UserSvr::RequestEvent(TEvent &anEvent,TRequestStatus &aStatus)
was unworkable for the Epoc/32 micro-kernel variants since the
O/S needs to write the resulting event back in the context of the
interrupt which may not be the same process as that requesting the
event. Like servers, this needs to be written using RThread::Write()
which needs to write to a descriptor in the requesting process. To
this end I have defined:
class TEventBuf : public TPckgBuf<TEvent>
{
public:
inline TEvent &Event() const {return(*((TEvent *)&iBuf[0]));}
};
The function now becomes:
UserSvr::RequestEvent(TEventBuf &anEvent,TRequestStatus &aStatus);
i.e. it takes the packaged event. The actual event can be returned
by using the () operator on the package or by calling Event().
3). The text window server had a bug which was causing the unicode
release build to fail reading the setup parameters in a random way.
4). CObjectIx::Destruct() was deleting NULL object handles. Fixed.
5). Made TRequestStatus a proper class so that it is now strongly typed.
This helps the compiler pick the correct overloaded function as
can happen in the file server for example. Note that there is no
conversion from a TRequestStatus to a TInt. Use the Int() function.
6). ROM sizes are now quoted for the Epoc/32 microkernel builds and
not for WINS as previously.
ROM SIZES
X86 ARM
--- ----
EUSER.DLL 94K 154K
EKERN.DLL 70K 110K
ELOCL.DLL 3K 3K
EFSRV.DLL 27K 41K
----------------------
TOTAL 194K 308K
----------------------
Version 0.01.046
================
(Made by Colly, 2 Oct 1995)
1). Added #defines _L8, _L16, _S8 and _S16 for string literals.
2). Eliminated wait handlers for device drivers. The function
User::AllowRequestsToComplete() is now redundant. Withdrawn.
3). KMinTInt8 and KMinTInt16 were not defined correctly. Fixed.
4). Completed the implementation of RHeap(). The various UserHeap
creation functions now have new arguments, aMinLength,
aMaxLength and aGrowBy. The heap will initially be aMinLength
in size, and can grow to be aMaxLength in size. If there is no
space in the heap then an attempt will be made to grow the heap
in aGrowBy increments. There is a new function Compress() which
will free any excess space at the end of the heap. Compress() will
never shrink the heap to less than aMinLength. The sizing code has
been modified to take account of the RHeap structure at the bottom
of the heap, so that the free size of a newly created heap will
always be >= aMinLength. None of this affects fixed heaps.
5). Changed RThread::Create() to allow the initial size of the heap
to be specified as well as the maximum size of the heap. These
are given as the aHeapMinSize and aHeapMaxSize parameters. All
heaps created in chunks are targets for compression if the system
runs out of memory.
6). Implemented the process handling functions for the first time in
the micro-kernel version, including an interface to allow a loader
server to actually load .EXEs and .DLLs. In a normal system the
loader server will be part of the file server. The 486 version
of Epoc/32 now supports multiple processes, full pre-emptive
scheduling, and execute in place .DLLs and .EXEs.
7). Added User::Beep(TInt aFrequency,TInt aDuration). The frequency
is in hertz so 440 is middle A. The duration is in tenths
of a second. As in Epoc/16 a negative duration indicates that if
the hardware to perform the beep is being used for another purpose
no beep will be sounded. As before if the duration is positive the
beep can hang up the program until the hardware is free to make
the beep. And as before the first beep will return immediately if
the hardware is not busy and the beep will continue in background.
Note that in Epoc/16 the frequency was specified as an interval.
This function is not playing a sound constinuously due to a bug in
Win32. It is however functionally correct. I will fix it in the
next release.
8). The constructor for the TPckg template class was leaving the
length of the descriptor as zero, when it should be the sizeof
the object T. Fixed.
9). Add support for drivers to the kernel. In Epoc/16 there were LDDs
and PDDs. In Epoc/32 a Device is equivalent to an LDD and a Driver
is equivalent to a PDD. The only user mode services for drivers
are TFindDriver which allows all installed drivers to be listed
and User::LoadDriver() and User::FreeDriver(). With the addition
of drivers \E32\KSRC\KS_DEV.CPP got too big to handle so I have
split out channels into KS_CHN.CPP and libraries (DLLs) into
KS_LIB.CPP and put drivers in KS_DRV.CPP.
10).Completed the implementation of the device driver functions in the
kernel and implemented the RDevComm device as well as a WINS driver.
Ax X86 driver for 16450s and 16550s is coming soon. Serial comms lives
again! The comms device and WINS driver are now part of the standard
release of E32 for WINS. The interface to the device is in D32COMM.H
and D32COMM.INL. It is necessary to load both the device driver
and the physical driver in order to use the comms device. An example
of how to do this is in \e32\dpwins\t_comm.cpp.
11).Added a public function CActive::Deque() which will allow the
active object to be removed from the scheduler queue. Deque()
will call Cancel() before dequeing the object. The object must
already be on the scheduler queue to be dequed or else a panic
will result.
12).Added a circular buffer template class CCirBuf<T> to E32ADT.H and
its test program T_CIRC.CPP. This is used by the serial device
to implement receive and transmit buffers. It allows items to be
added at the head of the queue while allowing items to be removed
from the tail of the queue. The buffers size can be changed
dynamically by calling SetLengthL(), although it will discard the
current contents of the buffer. Also added a class CCirBufer
derived from CCirBuf<TUint8> which add Get() and Put() which will
add or remove a single item and are optimised for speed.
13).Added the text window server to the standard build of E32. This has
now been implemented for WINS and EPOC/32-MX86 platforms. The source
of this server is in \E32\WSRC. It uses a screen driver .DLL
to perform character blitting to the screen. The test programs are
in \E32\TWIN. The RConsole class has the following facilities:
RConsole is used to communicate with the text windows server.
Version() Reports client side version information
Create() If necessary, opens a connection to the window server, then creates a default window without displaying
it. The default window characteristics may then be changed using Control() before proceeding to display
the window using Set().
Set() If necessary, opens a connection to the window server. If necessary, creates a window. Then displays
the window with the given title and attaches the given buffer size characteristics to it.
Write() Writes the given text at the current cursor position.
Clear() Clears the whole window and places the cursor at the top left corner.
ClearToEndOfLIne() Clears from the current cursor position to the end of the line
Destroy() Removes the window from the screen. Another may then be opened using Create()/Set().
SetCursorSize() Sets the percentage height of the cursor
SetCursorPosAbs() Places cursor at given absolute position.
SetCursorPosRel() Places cursor relative to current position.
CursorPos() Returns current cursor position
Control() Controls various window characteristics. The text passed to this function may contain near-English
commands. However, only the '+', '-', and upper-case letters are actually interpreted:
'+' Apply subsequent characteristics
'-' Remove subsequent characteristics
'V' Visibility
'C' Cursor on
'S' Scroll bars
'L' Scroll lock
'W' Wrap lock
'M' Maximum Window Size
'N' '/n' is CR and LF
Before interpreting the text, a silent '+' is assumed:
Control(_L("Visibility -Cursor Lock + Scroll"))
This would cause the window to become visible, with no text cursor, no scroll lock active,
but with scroll bars present. Of course, the following command would achieve exactly the same
result, but would not posses the same level of self-documentation or readability:
Control(_L("VS-CL"))
Further more, the next command would achieve the same thing with even more readability:
Control(_L("+Visibility -Cursor -Lock +Scroll"))
Read() Read a character.
ReadCancel() Cancel asynchronous read request
14).Set the priority of the kernel server thread and null thread
correctly on the EPOC/32 platforms.
15).Now allocating data section base addresses correctly so that multiple
threads will now work correctly on the EPOC/32 platforms.
16).Changed THandleBase::Duplicate(RProcess &aProcess) to be
THandleBase::Duplicate(RThread &aThread) since it is usual
to have the remote thread handle and unusual to have the remote
threads process handle. The O/S uses the thread's process as the
handle's source process.
17).RTimer.After() and User::After() were using a duration in ticks. This
has now been changed to a duration in tenths of a second so that it
is platform independent.
18).RProcess RThread::Process() was always returning the current
process rather than the thread's process. Also returning a new
handle based object can fail with out of memory so I have changed
this function to TInt RThread::Process(RProcess &aProcess) so that
it can return the error.
19).Under Windows/NT a mutex once owned by a thread can be waited on again
without locking the thread, on the basis that this protects a thread
from entering deadlock. However this is nonsense since a mutex can
be used to prevent a thread from accessing the resource as
happens in the case of the User::Beep() function. Basically the
mutex is used to lock out threads until the current beep has
completed. What takes the thread out of potential deadlock is the
beep completing in due course. Changed the WINS implementation to
behave correctly and lock the thread.
20).TLex::Val(TReal &) did not fail with a number like _L("1.2e"). Fixed.
21).The default constructor for the TLex class was still being set up for
zero terminated descriptors which were discarded in January. Fixed.
22).TLex::Peek() would happily try and access a character from a default
constructed TLex which resulted in an access violation. Now fixed.
Also dropped inline for Inc(),Peek() and Get().
23).CBufBase::Read(TUint aPos,TDes8 &aDes) is documented as reading up to
aDes.MaxLength() characters, but was in fact reading up to
aDes.Length() characters. Fixed.
24).RTimer was not setting the request status to KRequestPending after
an asynchronous request. Fixed.
25).I have changed EXPORT_C to just be nothing rather than
__declspec(dllexport). For the time being it is still required to
declare functions as EXPORT_C. If you had a function which did
not have a corresponding IMPORT_C then make sure that there is
an IMPORT_C defined somewhere or else the function will not be
exported.
26).Changed the heap checking macros to have understandable names and have
simplified their implementation. I have also made them orthogonal. The
new names and their old equivalents are as follows:
// For the user heap
__UHEAP_MARK MARKSTART
__UHEAP_CHECK(aCount) CHECKNUM1(x)
__UHEAP_CHECKALL(aCount) CHECKTOTALNUM1(x)
__UHEAP_MARKEND MARKEND
__UHEAP_MARKEND(aCount) MARKEND1(x)
__UHEAP_FAILNEXT(aCount) SETFAIL(x,y)
__UHEAP_SETFAIL(aType,aRate) SETFAIL(x,y)
__UHEAP_RESET RESET
// For the kernel heap
__KHEAP_MARK
__KHEAP_CHECK(aCount)
__KHEAP_CHECKALL(aCount)
__KHEAP_MARKEND
__KHEAP_MARKEND(aCount)
__KHEAP_FAILNEXT(aCount) K_SETFAIL(x,y)
__KHEAP_SETFAIL(aType,aRate) K_SETFAIL(x,y)
__KHEAP_RESET K_RESET
// For any RHeap
__RHEAP_MARK(aHeap) MARKSTART1(x)
__RHEAP_CHECK(aHeap,aCount) CHECKNUM2(x,y)
__RHEAP_CHECKALL(aHeap,aCount) CHECKTOTALNUM2(x,y)
__RHEAP_MARKEND(aHeap) MARKEND1(x)
__RHEAP_MARKEND(aHeap,aCount) MARKEND2(x,y)
__RHEAP_FAILNEXT(aHeap,aCount) UH_SETFAIL(x,y,z)
__RHEAP_SETFAIL(aHeap,aType,aRate) UH_SETFAIL(x,y,z)
__RHEAP_RESET(aHeap) UH_RESET
FAILNEXT,UH_FAILNEXT and K_FAILNEXT can be replaced
with __?HEAP_FAILNEXT(1)
It is no longer possible to check a threads heap since this will
not work under Epoc/32 if a thread is in another process.
In the first trial implementation of __?HEAP__FAILNEXT(aCount) I
had not realised that aCount did not do anything. This is now
fixed. Note that aCount==1 fails the next alloc call.
27).The member variable of TScreenInfoV01 were not declared with a lower
case i prefix. Fixed.
28).Released the console classes. The header for the console class in
E32CONS.H. It has an abstract base class CConsoleBase which just
defines a basic set of console functions. It also has CConsoleTextWin
which is the console implementation for the text window server.
29).Changed the WINS platform to use the the CConsoleTextWin instead of
a second Windows/NT console window. The test class now uses the
CConsoleTextWin. The console is released as ECONS.DLL. The
CConsoleTextWin class is defined in the E32TWIN.H header.
30).Changed the test class to use the console. Also added a Getch()
function to the test class. Because it now owns a console object
I have had to rename the test class RTest. I have also added
a Close() member function which will free an allocated console.
31).Added CConsoleBase *Adt::NewConsoleL() which will create a basic
console object. Note that you do not need to be linked to ECONS.LIB
in order to use this or any of the member functions of CConsoleBase.
32).Took the opportunity with the release of the X86 platform to rename
the WINS platform releaseables to be inline with those of the X86
platform. The new names are as follows:
OLD NAME NEW NAME
============ =============
ESTAT.OBJ EEXE.OBJ
ESTAT.LIB EEXE.LIB
EWINS.DLL EUSER.DLL
EWINS.LIB EUSER.LIB
KWINS.DLL EKERN.DLL
LWINS.DLL ELOCL.DLL
For programs the programs which use E32 the only changes to .MAK files
which are significant are as follows:
ESTAT?.OBJ to EEXE.OBJ - The startup object for .EXEs
ESTAT?.LIB to EEXE.LIB - The startup library for .EXEs
if linking with msvcrt20.lib
EWINS?.LIB to EUSER.LIB - The user library
33).Added an inline "construct in place" global new operator.
34).Due to popular demand I have moved the following functions
to a new class of their own CleanupStack.
Adt::PushL(const TAny *)
Adt::PushL(const CBase *)
Adt::Pop()
Adt::Pop(TUint aCount)
Adt::PopAndDestroy()
Adt::PopAndDestroy(TUint aCount)
become
CleanupStack::PushL(const TAny *)
CleanupStack::PushL(const CBase *)
CleanupStack::Pop()
CleanupStack::Pop(TUint aCount)
CleanupStack::PopAndDestroy()
CleanupStack::PopAndDestroy(TUint aCount)
35).For a long time I have been tracking down a race condition under
WINS which resulted in the kernel being hung. This turns out to be
a bug in the Windows/NT implementation of critical sections.
I have replaced the critical section with a mutex which fixes the bug.
36).I have fixed the T_SEMUTX.CPP program which has also long had a
deliberate race condition as part of its test. However the problem
was that sometimes it raced and sometimes it did not. By making each
thread wait different times its possible to always make the race
conditions occur so that the test will always pass consistently.
37).The CIdle class was doing a User::WaitForAnyRequest() in the
DoCancel() function. DoCancel() should just do nothing ofcourse
since the CActive::Cancel() function will do the WaitForAnyRequest().
Many thanks to Brendan for spotting the bug and for providing
the test code t_idle.cpp.
38).Adt::DestroyZ() was never any use, so I have removed it.
39).CSession::CreateL() was defined as pure virtual so that server
implmentors had to define a CreateL() function even, as is often
the case, the function did nothing. I have now supplied a default
implementation which does nothing.
40).CActiveScheduler::Install() would not allow the current scheduler
to be removed by passing NULL. This is now allowed. Note that if
you want to change the scheduler you must first de-install by using
NULL and then replace with the new scheduler.
41).Got most of the base test code working in release mode. For some
unknow reason, some of the test code template classes are not
instaniating in release builds. All tests pass but the following
have the body of their code eliminated.
T_BUF, T_CHAR, T_DES, T_HEAPDB, T_HUF
T_LEX, T_QUE, T_SQUE, T_KEY, T_FLOAT
In getting the test programs to work in the release build almost
all problems wre due to a dependency on the lifetime of
temporaries. In debug builds temporaries are never re-used so they
exist for the duration of the function. However in release builds
they are re-used at the first opportunity. Typical buggy code is
as follows:
class TBug
{
public:
TBuf();
void Set1(const TDesC *aDes);
void Set2(const TDesC *aDes);
private:
const TDesC *iPtr1;
const TDesC *iPtr2;
};
TBuf b;
b.Set1(&_L("Temporary 1"));
b.Set2(&_L("Temporary 2"));
This will work fine in debug builds but will result in iPtr1 and
iPtr2 pointing to the same value. This is because _L is defined
as a constructor for a TPtrC which creates a temporary. The same
automatic space will be used for the temporary.
42).HBufC::NewMax(),HBufC::NewMaxL() and HBufC::NewMaxLC() all ended
up setting the length to the size of the allocated cell which can
be bigger that the requested length. Changed to set the length
to the requested length.
43).Moved MemCopy(),MemCompare(),MemCompareF(),MemCompareC()
MemFill(),MemFillZ() and MemSwap() to a class of their own
called Mem and dropped the Mem prefix. So User::MemCopy() is
now Mem::Copy() etc.
44).Changed TDesC functions Match(),Locate(),LocateReverse() and Find()
to return an unsigned result. They all return KNotFound which is
defined as KMaxTUint if they fail.
45).The message system was not tidying up correctly when a session
was closed by the client or if the client died before closing. The
new implementation of messaging has now fixed this problem.
NOTE
====
20th September 1995.
The X86 implementation of the Epoc/32 platform ran through the
creation and execution of the first user mode process and then
eventually ended up in the NULL process and consequently the idle
loop. The MMU and protection is fully enabled, so this constitutes
the birth of Epoc/32. We hope to have the remainder of the boot
sequence, i.e. file server, window server and shell completed
by the end of the next week.
ROM SIZES
X86 ARM
--- ----
EUSER.DLL 90K 148K
EKERN.DLL 33K 47K
ELOCL.DLL 3K 3K
EFSRV.DLL 28K 42K
----------------------
TOTAL 154K 240K
----------------------
Version 0.01.045
================
(Made by Colly, 30 Aug 1995)
1). Changed the way messaging worked internally. RServer::Receive() used
to get a pointer to the message received. I was hoping to pass this
pointer directly from supervisor space for efficiency, but I have
decided that its not worth the extra overhead of read only shared
memory that wouldbe required. RServer now has a RMessage by value
which receives the contents of the message when it arrives. If the
server needs to hold onto the message then it must either copy
the message in full (I have added a copy constructor and an assignment
operator to allow this) or it must use the new function MessagePtr()
which returns a const RMessagePtr. The only thing you can do with
an RMessagePtr is to complete the message as you do with a normal
RMessage by call RMessagePtr::Complete().
While I was about it I also changes the naming of the accessor
functions I1(),P1() etc. The problem with the names was that on
the client side arguments were being set into an array using normal
indexing, i.e. base 0, while on the server side the names were based 1.
In order to help the conversion I have renamed I to Int and P to Ptr
so that:
I1() is now Int0()
I2() is now Int1()
I3() is now Int2()
I4() is niw Int3()
P1() is now Ptr0()
P2() is now Ptr1()
P3() is now Ptr2()
P4() is niw Ptr3()
Sorry for the inconvenience.
2). Moved a number of constructors in abstract base classes which were
public to protected. This should have no affect other than to stop
them being instantiated.
3). Withdrawn the new(ECleanup) and new(ECleanupObj) options. new(ELeave)
still exists. CBase * is not nescessarily the start of the heap cell
when MI is involved. In general a cast of (TAny *) to a CBase * will
not work unless the TAny * was originally downcast to a CBase *. If
you know the type T of a TAny *ptr then its o.k. to code
(CBase *)(T *)ptr;
but not
(CBase *)ptr;
4). More tiresome CBase * problems. TDblQue::DeletaAll and
TSglQue::DeleteAll were removing each item from the que and then
casting the ptr to a CBase * to call Adt::Destroy(). Withdrawn.
5). CActiveScheduler::Start() was not nesting levels correctly. Fixed.
6). Added TLex?::Offset() and TLex?::MarkedOffset().
7). The various TLex::Val() routines should not change iNext if they
fail to lex a valid number. Fixed.
8). Added TLex?::Val(TReal32 &aReal,TChar aPoint) and
TLex?::Val(TReal64 &aReal,TChar aPoint).
9). Added some extra key difinitions to E32VIRT.H
EKeyBell=0x0007,
EKeyLineFeed=0x000a,
EKeyVerticalTab=0x000b,
EKeyFormFeed=0x000c,
EKeySpace=0x0020
10).Implemented default constructors for TPtrC8 and TPtrC16 which
set the pointer NULL and the length to zero.
11).The X86 version of E32 now builds in unicode.
12).Changed CObjectConIx::Remove(CObjectCon *aCon) so that it can be
passed NULL. It does nothing if aCon is NULL.
13).Added CObjectCon::operator[]() to allow access to all objects in a
container by straight indexing.
Version 0.01.044
================
(Made by Colly, 23 Aug 1995)
1). TDes8::SetMax() and TDes16::SetMax() did not work correctly if the
TDes was from a TBufC.Des() or HBufC.Des(). This caused the
HBufC::NewMax() and HBufC::NewMaxL() to fail to set length to
MaxLength(). Fixed.
2). Added a new type TTrapHandler. This is an abstract class which needs
to be derived to provide a handler to work with the TRAP mechanism.
The trap handler can be installed by calling User::SetTrapHandler()
and can be cleared by passing a NULL pointer. By default there is no
trap handler. Once a trap handler is installed then each time TRAP is
invoked TTrapHandler::Trap() is called. If a leave is called then
TTrapHandler::Leave() is called. If the function being trapped does
not leave then TTrapHandler::UnTrap() is called. Each thread has its
own trap handler. Its not a good idea to install a trap handler while
under a TRAP (exercise for the reader to work out why), so a panic
will be given if this is attempted. The current trap handler can be
retrieved by calling User::TrapHandler().
3). Added a new ADT class CCleanup. The purpose of this class is to
provide an automated cleanup mechanism to go with the TTrapHandler
facility. This class is basically a stack onto which either
allocated cells can be pushed using PushL(TAny *aPtr) or objects
derived from CBase with PushL(CBase *aPtr). The object can
be popped from the stack with Pop() or popped and destroyed with
PopAndDestroy(). It is possible to pop a number of items from the
stack by using the overloaded Pop(TUint aCount) functions.
The object also allows for nesting so that all objects at the
current nesting level can be popped or popped and destroyed with
PopAll() or PopAndDestroyAll(). These functions automatically
decrement the nesting level. The nesting level can be incremented
with NextLevel(). When the object is created the level is zero.
Objects cannot be pushed while the nesting level is zero so it is
necessary to call NextLevel() before doing a PushL().
If the object is destroyed then all items on the stack will also
be destroyed.
The cleanup object keeps a free slot at all times. Thus an object
can always be guaranteed to be added to the cleanup stack. Having
added the object, room is made for another free slot. This may
leave but it will be alright as the object has already been pushed
onto the stack and will be cleaned up. Cleaning up leaves room for
another free slot.
4). Added a new ADT class CTrapCleanup which puts 2) and 3) together to
give a framework for cleanup. All thats necessary to implement this
facility is to call CTrapCleanup::New(). There is no NewL() since
the trap handler can only be installed while not under a TRAP.
Destroying this object will remove the trap handler. Added the static
functions Adt::PushL(const TAny *), Adt::PushL(const CBase *),
Adt::Pop(), Adt::Pop(TUint aCount) and the PopAndDestroy()
equivalents which all use the installed CTrapCleanup object. Note
that the PopAll() variants are not available, since this is done
by the trap handler.
5). Added 2 more types to TLeave, i.e. ECleanup and ECleanupObj. ECleanup
will allocate the storage and leave on error. If successful it will
add the new cell to the cleanup list. ECleaupObj is the same except
that it will add the cell as a CBase derived object. It is possible
to use ::new with ECleanupObj, but you will just get
panicked. It should only be used with CBase::new. Note that any
call to new within a member function in a class derived from CBase
will be calling CBase::new and so will need ECleanup. If creating an
object then ECleanupObj is correct. Using User::AllocLC() is probably
preferable and always call new(ECleanupObj) or new(ELeave).
Added RHeap::AllocLC(), User::AllocLC(), TDesC::AllocLC(),
HBufC::NewLC() and HBufC::NewMaxLC() which all are the same as
the equivalent L functions except that they add the object to
the cleanup list if successful.
Remember that a Pop() of some kind will be required.
6). Added the function to return machine information from the Hardware
Abstraction Layer (HAL). This is retrieved by calling User::HalInfo().
The class is declared in E32HAL.H. Setting functions will be added
in a forthcoming release.
Note that this function takes a TDes8. This is to allow for extensions
to the class as developments proceed apace. The function will always
fill the entire descriptor with zero and then copy the smaller of the
current size of the info class or size of the descriptor. Thus if a
new info class is used with an old O/S all new members are guaranteed
to be zeroed. If an old info class is used with a new O/S only the
appropriate slice of the new info struct is returned. There is a
typedef for a packaged THalInfoV1 called THalInfoV1Buf which can be
passed to User::HalInfo(). Ofcourse later version will be derived
from THalInfoV1 as THalInfoV2 and so on, leaving a clear picture of
what has been added between versions. The object can be retrieved
from the package as follows:
THalInfoV1Buf b;
User::HalInfo(b);
THalInfoV1 &info=b();
test.Printf(_L("Machine name = %S\n"),&info.MachineName());
See the test program \E32\TCDT\T_HAL.CPP for details.
7). The O/S was running DLL startup procedures before starting the file
server and window server threads. It has to do this to allow the
Window and File server DLLs to register their threads so that they
can be started in an ordered manner. However many other servers
like the alarm, comms and secokets servers would also like to start
the server thread from their E32Dll() entry point. The solution is
to hang all starting threads except the Window and File server
threads until the Window and File server threads have started.
8). Changed the RLibrary::Load() function so that it will automatically
add the approriate suffix for the current build. Thus if the file
server wants to load a .DLL called "elocal.fsy" it just uses
"elocal.fsy". The O/S will look for the .DLL names as follows:
Build Source Suffix Target
============ ============ ====== ==============
ansi release "elocal.fsy" none "elocal.fsy"
ansi debug "elocal.fsy" d "elocald.fsy"
uni release "elocal.fsy" u "elocalu.fsy"
uni debug "elocal.fsy" ud "elocalud.fsy"
Because of 8 character name limits the maximum length name of a DLL
can only be 6 characters. If an extension is not supplied it will
be assumed to be .DLL.
9). Added TPtrC8::Set(const TDesC8 &aDes) and TPtr8::Set(const TPtr8 &aPtr)
and the TPtrC16 and TPtr16 equivalents.
10).The resource file \E32\KPWINS\KWINS.RC was including afxres.h from
\msvc20\mfc\include which is not actually required. Fixed.
11).Fixed a bug in TLex::Val(TInt?) which has been lurking from day one
and was scraping by through good fortune.
12).Fixed a bug in creating global operating system objects such as
RSempahores etc.
13).Changed CArrayPakBase to be derived directly from CBase rather
than CArrayVarBase. This was being done to share code but because
of the public inheritance it caused some nasty problems since a
CArrayPakBase is definitely not ISA CArrayVarBase. Users of this
class note that the sort function is SortL() and not Sort() since
it makes a copy of the array as a CArrayVar and then sorts it.
Making the copy can clearly fail. Also note that since the sort is
actually performed on a CArrayVar the key for SortL() needs to be
a TKeyArrVar. Other functions take a TKeyArrPak as normal. No code
should be affected by this change.
14).Added const TArray<T> Array() to each of the array template classes,
which allows a degree of polymorphism amongst the arrays.
TArray<T> only allows const T &operator[]() and Count().
If you want a function to be able to read any of the arrays then
declare it as follows:
void ReadAnyArray(const TArray<TBuf_40> anArray);
It could use the TArray as follows:
TUint count=anArray.Count();
for (TUint i=0;i<count;i++)
test.Printf(_L("%S\n"),&anArray[i]);
Then if you have:
CArrayFixFlat<TBuf_40> *fix;
CArrayFixFlat<TBuf_40> *var;
CArrayFixFlat<TBuf_40> *pak;
They can all be passed to ReadAnyArray() as follows:
ReadAnyArray(fix->Array());
ReadAnyArray(var->Array());
ReadAnyArray(pak->Array());
15).SteveT was getting a weird problem with delete in one of
his CBase derived classes with the virtual destructor calling the
delete from the Windows library. The fix to his problem is to
provide CBase::operator delete() even though its not necessary.
Version 0.01.043
================
(Made by Colly, 21 Aug 1995)
1). Renamed CBufFlat::Capacity() to CBufFlat::SetReserveL().
2). Added the L suffix to all the methods in the ADT classes which
can leave.
CBufBase::InsertL(), CBufFlat::InsertL() and CBufSeg::InsertL().
CArrayFix::AppendL(), CArrayVar::AppendL() and CArrayPak::AppendL().
CArrayFix::InsertL(), CArrayVar::InsertL() and CArrayPak::InsertL().
CArrayFix::InsertIsqL(), CArrayVar::InsertIsqL() and CArrayPak::InsertIsqL().
Note that all occurences of ISQ (uppercase) have been changed to
lower case. Thus FindISQ() has become FindIsq().
Note also that the virtual function InsertL() has been renamed to
DoInsertL(), so that the derived classes do not have to re-define
the two new InsertL()'s in CBufBase.
3). The CArray classes had a kludged way of delaying allocation of the
CBufBase. Fixed.
4). Incorporated SteveT's changes to TPoint, TSize and TRect. His release
notes are as follows:
There are 3 changes to the TRect spec as agreed with Martin Tasker:-
Replaced
TInt TRect::InterSect()
with
void TRect::InterSection() &
TBool TRect::Intersects()
Changed the names of:-
TRect:Union() to TRect::BoundingRect()
TRect::Inside() to TRect::Contains()
I have also removed most of the inline functions from the TPoint,
TSize & TRect functions. The only ones left as inline are the
TPoint & TSize constructors and operator=, although I'm still not
too sure whether they should stay inline or not.
5). Changed CBufBase::Ptr() and CBufBase::BackPtr() to return TPtrs
rather than pointer and length.
Added CBufBase::Read(TUint aPos,TDes8 &aDes)
which will read aDes.Length() bytes.
Added CBufBase::Read(TUint aPos,TDes8 &aDes,TUint aLength)
which will read aLength bytes.
Added CBufBase::Write(TUint aPos,const TDesC8 &aDes)
which will write aDes.Length() bytes.
Added CBufBase::Write(TUint aPos,const TDesC8 &aDes,TUint aLength)
which will write aLength bytes.
Added CBufBase::InsertL(TUint aPos,const TDesC8 &aDes)
which will insert aDes.Length() bytes.
Added CBufBase::InsertL(TUint aPos,const TDesC8 &aDes,TUint aLength)
which will insert aLength bytes.
6). Removed the protected destructor (not actually implemented) from CBase
and changed CBase::Destroy() so that it does not delete this.
Renamed CBase::Destroy() as CBase::Destruct() and all other
virtual Destroy()s to Destruct().
Changed Adt::Destroy() to call delete after the Destruct().
This allows CBase derived objects to be aggregated by value, although
it is not Psion policy to do this (preferring to aggegrate by reference).
Note that there is no longer any requirement to call CBase::Destroy()
from classes derived from CBase.
Note that if aggregating by reference which should be the case for
all Psion code then the object must be destroyed with Adt::Destroy()
rather than the Destruct() function. Its probably a good idea to
search all code for ->Destroy() and check each case. Also make sure
that all classes derived from CBase which have virtual void Destroy()
are changed to virtual void Destruct().
7). CObjectIx, CObjectCon and CObjectConIx could all be created with
optional leave on error. This is not in the spirit of
the ADT classes and so I have removed the option. They will now
always leave on errors. The methods have been renamed where
applicable with the L suffix. These classes were also privately
derived from CArrayFixFlat<T> which was breaking the ISA
relationship with CBase, which prevents use of Adt::Destroy().
They now have a CArrayFixFlat<T> and are derived directly from
CBase. CObject and CObjectCon used to capitalise the name. They
are now case sensitive on the names. Note this affects server
names (watch out SteveT and Brendan).
8). TPckg<T>::operator->() and TPckg<T>::operator()() were returning
const T * and const T & respectively. Fixed.
9). Added HBufC::NewMax() and HBufC::NewMaxL() which allocate an HBufC
of the requested size and then set the length to the maximum length.
Note in the proposals database a function it was agreed to add
a function SetLengthToMax() to TDes. This has been done but I decided
to call it SetMax(). Obviously these functions are available for 8
and 16 HBufC's as well.
10).If multiple inheritance is to be allowed for then the only way to
guarantee that an Adt::Destroy() through a CBase pointer will work
correctly is to have a virtual destructor. This has been implemented
in CBase. No derived classes need to be changed as the compiler will
generate the appropriate destructors automatically. If this seems
like a waste then I have to agree, however it will make us compatible
with the C++ language and all proper C++ implementations. If you want
to know more details then ask me, Gerry or DavidW.
11).The ENTER,CATCH,END_ENTER mechanism had a serious flaw when using
a register calling convention. This has now been replaced with the
pre-processor macros TRAP and TRAPD. These are defined as below:
#define TRAP(_r,_s) {TTrap __t;if (__t.Trap(_r)==0){_s;TTrap::UnTrap();}}
#define TRAPD(_r,_s) TInt _r;{TTrap __t;if (__t.Trap(_r)==0){_s;TTrap::UnTrap();}}
Basically _r is an integer variable which will receive the result of
any User::Leave() and _s is a statement to be executed. It can be any
valid C++ statement, but will normally be a function call.
The difference between TRAP and TRAPD is that TRAPD will declare the
integer variable for you. The integer variable will always be
initialised to 0 before the statement _s is executed. It is possible
to use a number of statements for _s by separating them with ; but
this will possibly lead to failure.
Examples:
CSomething *pS=new(ELeave) CSomething;
TRAPD(ret,pC->ConstructL())
if (ret!=KErrNone)
{
Adt::Destroy(pS);
User::Leave(ret);
}
is the same as
CSomething *pS=new(ELeave) CSomething;
TInt ret;
TRAP(ret,pC->ConstructL())
if (ret!=KErrNone)
{
Adt::Destroy(pS);
User::Leave(ret);
}
If you have a function, say TInt DoSomethingL() and you want to
get the result of the function or the leave then do this:
TRAPD(ret,ret=DoSomethingL())
12).Changed RHeap::Free() to zero the cell it has just freed in the debug
build.
13).Added User::RequestComplete() which will complete a request in for
the current thread.
14).Added a new CDT TCallBack which packages a function taking a TAny *
argument and returning an integer with a TAny * value. It has a two
constructors, the one which does not have a TAny * value will set the
value to NULL. It has one function CallBack which can be used to call
the function passing it the TAny * value. e.g.
class TMyIdle
{
public:
void Run();
static TInt Idle(TAny *aPtr);
};
TInt TMyIdle::Idle(TAny *anObj)
{((TMyIdle *)anObj)->Run();}
TMyIdle idler;
CIdle *pI=CIdle::New();
pI->ConstructL(TCallBack(TMyIdle::Idle,&idler));
15).Added a new active object CIdle which will call back whenever
the active scheduler has scheduled all higher priority objects.
CIdle will re-schedule itself as long as the callback function
returns TRUE. It can be re-started by calling Start() again.
New() and NewL() add the idle object to the scheduler.
16).Changed CPeriodic to use a TCallBack. Note the CPeriodic::RunL()
now always calls the callback.
17).Added TLex8::UnGetToMark() and TLex16::UnGetToMark() which just
reset iNext to iMark.
18).Renamed all the functions which were in the debug build but not in
the release build to have an __Dbg prefix. Also renamed the test
functions __TestInvariant() and __Test to __DbgTestInvariant and
__DbgTest. This is partly as a reminder to users of these functions
that they should only be used inside #if defined(_DEBUG) and partly
to ease producing the .DEF file to control the .DLL build process
using linkage by ordinal. An automated tool will generate the .DEF
file for a .DLL linked by name and will produce the .DEF for the
debug build. It can then produce the .DEF for the release build
by leaving out all the functions starting with __Dbg.
Version 0.01.042
================
(Made by Colly, 3 Aug 1995)
1). All DLLs now link by ordinal.
2). The release versions had a startup bug with some configurations of DLL
useage. DavidW this is what cause the BAFL test code to fail.
3). Includes the first release of the Epoc/32 microkernel platform and
implementation for 486 processor on an IBM/PC.
NOTES
=====
Its a good idea to turn on DEBUG under link so that release EXEs and DLLs
have at least the public symbols for debugging. This can be done for
all build variants. I have done this for all .MAK files in E32 and F32.
Version 0.01.041
================
(Made by Colly, 25 July 1995)
1). RThread::Read() failed when reading a descriptor of the type
generated by TBufC::Des(). Added a test and fixed.
2). Made the NULL thread hang around forever instead of exiting to help
with debugging.
3). Added a new directory BWINS to the group which now has all the .MAK
files used to build the base. If the .MAK is in the same directory
as the source files then the debug databases .PDB files don't store
a full path which causes the debugger to prompt for the source
directory. Putting them in BWINS causes all paths to be stored in the
.PDB. Note that the BLD.CMD files remain where they were they just
pick up the .MAK file from BWINS. If using VC++ then load the .MAK
file directly from BWINS. Moved the startup files from USTAT to
UPWINS and dropped the USTAT directory from the group.
Split the startup module us_stat.cpp into two UP_EXE.CPP for
starting .EXEs and UP_DLL.CPP for starting DLLs.
4). Split EWINS into two .DLLs. EWINS still survives but now contains
just the user mode functions. KWINS is new and contains the kernel.
There is no need to change any .MAK files as it is only the
EWINSxx.DLLs which link to KWINSxx.DLL.
5). Stopped releasing the include file E32CHAR.H.
6). Merged the E32EVNT.H and E32WSRV.H header files into one header file
E32SVR.H which is just for communication with system servers such
as the Window server and File server etc. Moved the functions which
were in the UserWindowServer class to the UserSvr class and gave
the functions better names. Note that I have given the functions in
the UserSvr class more meaningful names. SteveT, these changes will
affect you!
7). Fixed missing external references to _fltused, _adj_fdiv, _adjust_fdiv,
_adjust_fdivr_m64 and _adjust_fdiv_m64.
8). Added the functions to support Global and thread local data in DLLs.
The functions are as follows:
TAny *Dll::Tls() - Returns the Thread Local Storage variable for the
current DLL.
void Dll::SetTls(TAny *aPtr) - Sets the Thread Local Storage variable
for the current DLL.
Usually in the entry point E32Dll() when the process is attached or
when a thread is attached to the DLL some memory will be allocated
on the threads heap. This value will then be saved with Dll::SetTls().
Thereafter it can be retrieved with Dll::Tls().
The following functions are not yet fully implemented:
TBool Dll::GlobalAllocated();
TInt Dll::GlobalAlloc(TUint aSize);
TInt Dll::GlobalRead(TUint aPos,TDes8 &aDes);
TInt Dll::GlobalWrite(TUint aPos,TDesC8 &aDes);
Dll::GlobalAlloc() allocates the global data for the currently
running DLL. Specifying a size of 0 will free the data. The amount
of data allocated can be changed by calling Dll::GlobalAlloc()
repeatedly. It is normal to allocate the global data in the entry
point E32Dll() when a process attaches and when
Dll::GlobalAllocated() returns EFalse. There is no need to free
the data since if the DLL is unloaded the data will be freed. However
it is possible to use some of the allocated data to keep a reference
count which can be incremented on process attach and decremented on
process detach. When the count is zero it can be discarded.
Since the data is kept in the kernel the DLL cannot have direct
access to the data, so it must be read and written using the
Dll::GlobalRead() and Dll::GlobalWrite() functions. It
is considered a panic to write past the current size of the data
but not an error to read past the end of the data.
These functions are implemented in a class of their own since they
need to be statically linked with each DLL or EXE (note than an
EXE is also potentially a DLL) on the WINS platform.
Finally it is a good idea to minimize the size of the global data.
Look at the test DLL \e32\tcdt\t_dll.mak and the test program
\e32\tcdt\t_tdll.mak to see how this works in practice.
9). Now release EXDLL??.PDB files. These come from EXDLL??.OBJ which is
a start up module for EWINS??.DLL, KWINS??.DLL and LWINS??.DLL which
have special initialisation requirements. These are just released as
an aide to debugging.
NOTES
=====
It is now vital that programs are build with proper make files. In
particular any program still linking to the C runtime library MSVCRT20.DLL
will fail to start correctly. Note that we are only talking about the
C runtime library and not the Win32 API libraries kernel32.lib,
gdi32.lib, user32.lib etc. The C runtime library is no longer necessary
as the base is now running entirely independently.
All EXEs should be linked with ESTAT??.OBJ and should have _E32Startup
set as the entry point.
All DLLs should be linked with EDLL??.OBJ and should have _E32Dll set
as the entry point. Remeber that a DLL must now supply a function
E32Dll(). To see and example look at the code in \E32\DPWINS\WS_UTL.CPP.
Everything should be linked with the user library EWINS??.LIB. Apart from
other E32 software nothing else should be necessary.
Make sure that "Ignore all default libraries" is set and that
"Disable exception handling is also checked" and that alignment is
set to 4 bytes.
If you are not sure then start with one of the .MAK files released by
the base and modify it to suit your project.
Version 0.01.040
================
(Made by Colly, 20 July 1995)
1). Converted the kernel to having a Kernel Supervisor Server and an
executive.
2). Replaced the specific exit type of exception with a Panic() category
of Exception.
3). Clean compiled all the platform independent source code with the GCC
compiler with the exception of the sources in UMATH.
4). Added cleanup functionality to the kernel.
5). Incorporated SteveT's fixes to pointer messages with the new screen
surround.
6). Added Martin Dolphin's CArrayPacked classes. Renamed the classes
"Packed" to "Pak". His release notes follow:
This version of CArrayPak inherits from CArrayVar and uses
some virtual functions to achieve code reuse. TKeyArrayPak
inherits from TKeyArrayVar.
ucdt\uc_func.cpp
This has a slightly modified binary search.
This modification guarantees that:
//if no match is found.
//the index of the record logically following the value being searched
//for will be returned in aPos.
uadt\ua_array.cpp
Has the new CArrayPak code plus some other small
modification listed below.
CArrayFixBase::InsertIsq changed to reflect change in BinarySearch.
CArrayVarBase::Find, FindIsq have had unused length parameter
removed, some functions made virtual to achieve code reuse.
8). Fixed further bugs in TInt64 divide and remainder functions as
reported by SteveT.
9). Incorporated SteveT's changes to the region classes.
10).Incorporated the faster versions of User::MemCopy(),User::MemFill()
and User::MemFillZ()
11).Added two template inline functions to align pointers.
inline T *Align2(T *aPtr)
inline T *Align4(T *aPtr)
Align2 will make ((T *)&1)==0
Align4 will make ((T *)&3)==0
and two template functions to align integers.
inline TUint Align4(T aVal)
inline TUint Align2(T aVal)
12).Removed the Notify() and SetNotify methods from RThread and RProcess.
They will re-appear in the file server in due course.
13).Added the executive dispatcher to the kernel.
14).Rationalised the RThread and RChunk read/write routines.
15).Changed CActiveScheduler::Destroy() to just remove active objects
from the schedule queue. It used to destroy them as well. Before
removing each active object it will call CActive::Cancel();
16).Fixed a bug in TLex8::NextToken() and TLex16::NextToken() which
was not checking properly for the end of the buffer. Found by Martin
Dolphin by trying to lex an empty command line.
17).Changed the name of the key matching enumerates as follows:
TKeyArrayCmp to TKeyCmpText
TKeyArrayCmpNumeric to TKeyCmpNumeric
Added another constructor for comparing descriptors and changed
the order of the parameters as follows:
inline TKey(TUint anOffset,TKeyCmpText aType);
At anOffset should be one of the descriptor types, TPtr,TBufC etc
inline TKey(TUint anOffset,TKeyCmpText aType,TUint aLength);
At anOffset should be TText of length aLength.
inline TKey(TUint anOffset,TKeyCmpNumeric aType);
At anOffset should be an integer of some type.
Added support for TInt64s.
This change is propagated to the various TKeyArrayXXX:: classes.
18).Fixed a race condition in the kernel when resuming threads.
19).If a thread panics then it just quietly disappears. If this is
one of the server threads then the program appears to hang for
no reason. To this end I have added new services RThread::Server()
and RThread::SetServer(TBool aState). Any thread marking itself as
a server with RThread().SetServer(ETrue) will have its panics
reported through the messagebox and will then abort the program.
Note that this is done for the main thread as well.
NOTES
All test programs pass in all builds.
Version 0.01.039
================
(Made by Colly, 23 June 1995)
1). Finally removed the dependency on the C runtime libarary.
There are new libraries in t:\msvc21\lib which should all
be copied to c:\msvc20\lib. This is still necessary as the
main operating system .DLL and SteveT's .DLL still link to
the runtime library MSVCRT20.DLL. Also copy
t:\msvc21\system32\*.* to c:\winnt35\system32\*.*
The build for a .EXE has now changed as follows:
a). Select project settings and highlight all 4 builds:
Select the Link tab and the Output category.
Set Entry-point symbol to _E32Startup
(The case is important in _E32Startup)
Select the general category.
Delete all the libraries/object modules.
Make sure "Ignore all Default libraries" is selected.
b). Select each build in turn and set the libraries/object modules
as follows:
Release : \e32sys\estat.obj \e32sys\ewins.lib
Debug : \e32sys\estatd.obj \e32sys\ewinsd.lib
Uni Release : \e32sys\estatu.obj \e32sys\ewinsu.lib
Uni Debug : \e32sys\estatud.obj \e32sys\ewinsud.lib
If in doubt look at one of the test programs.
The build for a .DLL which is linked to Win32 does not need to
change at all.
The build for a .DLL which is linked only to E32 must be changed
as follows:
a). Select project settings and highlight all 4 builds:
Select the Link tab and the Output category.
Set Entry-point symbol to _E32Dll
(The case is important in _E32Dll)
Select the general category.
Delete all the libraries/object modules.
Make sure "Ignore all Default libraries" is selected.
b). Select each build in turn and set the libraries/object modules
as follows:
Release : \e32sys\edll.obj \e32sys\ewins.lib
Debug : \e32sys\edlld.obj \e32sys\ewinsd.lib
Uni Release : \e32sys\edllu.obj \e32sys\ewinsu.lib
Uni Debug : \e32sys\edllud.obj \e32sys\ewinsud.lib
c). Provide a function prototyped as follows:
GLDEF_C TInt E32Dll(TDllReason aReason)
See \f32\sfsrv\fs_utl.cpp for an example of such a function.
The new system cannot be build with the project system at the
moment and must be built with the VC++ IDE. The correct build
order is as follows:
\e32\lsrc\lwins.mak
\e32\kpwins\ewins.mak
\e32\ustat\estat.mak
\e32\ustat\edll.mak
2). Added the fancy graphics screen bitmap of protea to surround the screen.
It does not appear in its full glory on my work machine, but it does on
my home machine. Perhaps SteveT can sort this out for me. I am also
assuming that SteveT will handle the buttons on the imaghe and return
them as key strokes.
3). CServer::RunL() was still using delete to remove a session when
a client disconnected rather than Destroy().
4). Added a protected destructor to CBase which will stop any objects
derived from CBase being placed on the stack.
5). Increased the Window servers stack to 1MByte.
6). TInt64 divide was not working for large intergers.
7). Absorbed SteveT's new region code.
8). Fixed a bug in TLex::Val() which was not dealing with the end of the
descriptor properly. MartinH's fix.
9). Added the TReal to buffer and buffer to TReal functions. The maths
library is now complete. Thanks to MartinH.
10).Fixed a bug in CArrayFixBase::DestroyAll().
11).Moved the TInt64 class from E32MATH.H to E32STD.H and its source
code from umath to ucdt.
12).Took the additions to the bitmap allocator from JaneS
13).New version of enter and leave which should fix previous problems
NOTES
=====
1). T_LEX.CPP failed because the TReal functions now work. I have
commented these out until MH can fix them.
2). T_THREAD.CPP and T_SEMUTX.CPP fail under the unicode debug version.
T_THREAD because their is a race condition in the kernel somwhere
and T_SEMUTX.CPP because there is a bug in the program logic. I will
fix these in the next release.
Version 0.01.038
================
(Made by DavidW, 19 May 1995)
One step backwards before taking two steps forward again!
Put back RRegion::~RRegion to allow the Window Server and GDI to
release new versions quickly, compatible with the latest E32, before
they take more time over the next week to convert to a new RRegion
scheme altogether.
[Added later - fixed INCC.PRJ to release E32DES8.H & E32DES16.H]
Also made a fix to MNT.CMD which meant that only the Release build
versions were being released. The ESTAT*.PDB files weren't being
released either.
Note: T_I64 still fails in UON.
T_SEMUTX fails intermittently (in either UON and UOFF).
Version 0.01.037
================
(Made by Colly, 19 May 1995)
1). Fixed a bug in Math::Rand().
2). Moved the private classes TRectKey and TRectSwap in RRegion
to be declared locally in u_regn.cpp.
RRegion still has a virtual destructor which I have now removed. I
notice that the test code t_regn.cpp does not test either the Close()
or Destroy() functions.
3). Re-organized the entire group.
SUSER has been split into
UCDT - User Concrete Data Types, platform independent
UPWINS - User Wins platform dependent
SOLIB renamed to UADT - User Abstract Data Types
SMATH renamed to UMATH
TUSER renamed to TCDT
TOLIB renamed to TADT
SKERN renamed to KSRC
SWINS renamed to KPWINS
SWINSD renamed to DPWINS
SLOCL renamed to LSRC
4). In line with the above I have renamed E32OLIB.H and E32OLIB.INL
to E32ADT.H and E32ADT.INL.
5). Added class CBitMapAllocator to Adt. This class uses a bitmap to
control allocation of resources. It is used by the PageAllocator
in the micro kernel to allocate free physical pages. Another
potential use is in implementing a block allocation scheme in
a binary file such as a BTree index file.
6). I have changed the way the version numbers are formatted by TVersion.
7). Fixed a bug in RSubSession::Close() which did not check for a NULL
handle before despatching the close message to the server. It is
normal practice to allow a close on something which has never been
opened/created.
8). Recorded the size of components in the release history.
9). The localising code is now released separately as LWINS.DLL. This
is currently included in the base release zip file ewins. Note that
only ewins.dll has a dependency on this file so that no build files
need change.
10).Changed TDblQueIterBase::Wind() and TDblQueIterBase::Rewind()
to TDblQueIterBase::SetToFirst() and TDblQueIterBase::SetToLast()
Also added TDblQueIter<T>::Set(T &aLink) which will start the
iterator on a particular link.
11).Changed TSglQueIterBase::Rewind() to TSglQueIterBase::SetToFirst()
Also added TSglQueIter<T>::Set(T &aLink) which will start the
iterator on a particular link.
12).Added a function Adt::DestroyZ(CBase * &anObject) which will
destroy an object if anObject is not NULL and will then zero
anObject.
13).Added DestroyAll() to CArrayFixFlat and CArrayFixSeg which
assumes that the array is a set of CBase pointers, i.e.
CArrayFixFlat<CBase *>. The only check that is made is the the
record length==sizeof(CBase *). Note that DestroyAll() destroys
all the non-NULL pointers and then calls the normal Destroy().
14).Added a new template class TAggregate to e32atd.h. The idea
behind TAggregate is to automate the desctruction of aggregate
objects in CBase derived classes. Say you have three active
objects owned by your object CMyObject the current way of
writing the class is as follows:
class CMyObject : public CBase
{
public:
CMyObject();
virtual void Destroy();
inline CTimer &Timer(*iTimer);
inline CServer &Server(*iServer);
inline CComms &Comms(*iComms);
private:
CTimer *iTimer;
CServer *iServer;
CComms *iComms;
};
And the Destroy() is as follows:
void CMyObject::Destroy()
{
Adt::DestroyZ(iTimer);
Adt::DestroyZ(iServer);
Adt::DestroyZ(iComms);
CBase::Destroy();
};
With TAggregate you would do it as follows.
class CMyObject : public CBase
{
private:
enum {ETimer,EServer,EComms,EMaxAggregate};
public:
CMyObject();
virtual void Destroy();
inline CTimer &Timer(*((CTimer *)iAgg.iPtrs[ETimer]));
inline CServer &Server(*((CServer *)iAgg.iPtrs[EServer]));
inline CComms &Comms(*((CComms *)iAgg.iPtrs[EComms]));
private:
TAggregate iAgg[EMaxAggregate];
};
And the destructor is as follows:
void CMyObject::Destroy()
{
iAgg.Destroy();
CBase::Destroy();
};
If one of the aggregates is removed or another is added all that
has to be done is add a new enum and the accessor method.
The Destroy() will automatically be correct. Note that there is
no additional overhead for the iAgg.iPtrs[] in the accessors.
15).I have added a new template class TAutoClose to e32std.h which
will add a destructor to any class which has a Close() method.
This is useful for functions in which you want to take advantage
of the compiler automatically destructing the object when it goes
out of scope. e.g.
TInt ReadFile(const TDesC &aFile)
//
// Read a file
//
{
TAutoClose<RFile> f;
TInt r=f.iObj.Open(aFile,KFileStreamText|EFileExclusive);
if (r!=KErrNone)
return(r);
TBuf_100 b;
if ((r=f.iObj.Read(b))!=KErrNone)
return(r);
.....
}
There is no need to call f.iObj.Close() as the compiler will do that
automatically when f goes out of scope. Even if the early return
after f.iObj.Read() is taken the compiler will still call
f.iObj.Close(). There is no overhead to using the TAutoClose class.
16).Added SetMax() to TDes which set the length of the TDes to
MaxLength(). i.e. equivalent to:
TBuf_100 b;
b.SetLength(b.MaxLength());
17).Added TPtrC::Set(const TText *aBuf,TUint aLength) and
TPtr::Set(TText *aBuf,TUint aLength,TUint aMaxLength)
since assignment of a TPtrC is not supported and assignment
of a TPtr means a deep copy rather than a shallow copy.
18).Renamed the files E32DES8.INL and E32DES16.INL if E32DES8.H and
E32DES16.H
Comp Date Bld .text .bss .rdata .data .idata Total
===== ========= === ====== ====== ====== ====== ====== ======
LWINS 17-Mar-95 37 822 32 1344 1092 268 2704
EWINS 17-Mar-95 37 82484 560 6012 1156 2916 92568
.text = The code size (a good indication)
.bss = The uninitialized data size (a good indication)
.rdata = The const data size (a good indication)
.data = The initialized data size (a good indication)
.idata = C++ initialisation + .DLL export table (unreliable indication)
The .idata section is unreliable since it has all .dll refences by name.
As .dll references will be by ordinal rather than by name I expect these
sizes to fall quite a bit.
Note that the current conversion factor from VC++ to GC++ is multiply
by 1.16
NOTES
=====
1). I think that all the heap debug macros in e32std.h should be prefixed
with __ and should be moved to their own include file e32hdbg.h which
is included by e32def.h. I also removed the unnecessary spaces in
their declaration which have been added back in build 035.
2). The functions RHeapDebug() in the RHeap class look like constrcutors
which they are not. The should be declared as returning void and
should also be given a different name. There are a number of comments
in the RHeap class declaration which I have removed.
3). T_thread.cpp fails. Also this program was including the header file
k32kern.h so that is could call Plat::CurrentProcess() to get the
current process. It is a bad idea for any test programs to call any
function in the kernel. This won't be possible on any other platform.
The correct way to get the current thread or the current process is
just to use an RProcess() or RThread() constructor. i.e.
if (RProcess().Mark())
etc.
if (RThread().Priority==EPriorityNormal)
RThread().SetPriority(EPriorityAboveNormal);
This works because the constructor for an RProcess or RThread sets
the RThread or RProcess handle to a special token which means the
currrent process or the current thread. It does no have to be
opened or created in the normal way.
Also the current process can be got from the current thread e.g.
RThread().Process()
P.S. This was covered in the release 26 release notes.
4). T_HEAPDB.CPP also includes k32kern.h (now k32std.h) so that it
can call Kern::UserHeap(). This is unnecessary as there is
already a call User::Heap() which returns the current heap. I have
fixed the test program.
5). T_I64.CPP still fails on divide. I will fix this in the next release.
Version 0.01.036
================
(Made by MartinB, 11 May 1995)
1) New SetThreadAllocFail method in User (MartinH).
2) New macros in e32def.h (MartinH).
3) New Math functions and test code (MartinH),
4) New ASSERT_DEBUGs in RHeap::Alloc.
5) Removed User::SetWSAllocFail, since cannot have window server
dependencies in the base.
6) Improved region code (Lane).
7) Added several "long ptr" qualifiers in P_I64.CPP. MSVC was
treating constants as 16 bit values when moved into (say)
[ebx]. (MartinB).
All test code runs for ASCII DEBUG and UNICODE DEBUG builds (MartinB)
(except T_I64 which does not run in UNICODE).
Version 0.01.035
================
(Made by MartinB, 9 May 1995)
1) Fix to Mul routine in P_I64.CPP.
2) New region code from Steve/Lane.
3) New T_THREAD test code from MartinH.
4) New T_I64 test code from MartinH.
All test code runs for ASCII DEBUG and UNICODE DEBUG builds (MartinB).
Version 0.01.034
================
(Made by Colly, 9 May 1995)
1). In both versions of RSessionBase::SendReceive() the parameter
TAny *aPtr can be passed as NULL.
2). Converted the design E32 to make the categories Kernel, User and
Olib as units. This allows other designs to import these units.
3). Added to RChannelBase overloads for DoRequest() and DoControl() which
allow none, one or two arguments.
4). Added three functions to the TLex classes.
void SkipAndMark(TInt aNumber) which moves the mark along by aNumber.
TPtrC Remainder() which returns the remainder of the buffer after
the mark.
void Inc(TInt aNumber) which moves the pointer on by aNumber.
5). Added IMPORT_C TAny *operator new(TUint aSize,TUint anExtraSize)
to CBase.
6). I have removed the resource file stuff from Olib because I do not
want the base to have a dependency on the file system. Note that in
due course the file server like the window server will live in its own
group and is only included with E32 for convenience while I develop
it. The file server is already completely independent of the operating
system.
I suggest that we have two DLLs called something like HCILI and HCILU.
HCILI would contain user interface independent code and HCILU would
have user interface dependent code. Then a getbld can go something like
this:
GET E32 // The base
GET F32 // The file server
GET W32 // The window server
GET HCIL // Both HCIL DLLs
I originally intended to supply the base as 3 DLLs, i.e.
E32KERN.DLL,E32USER.DLL and E32OLIB.DLL I now intend to supply it as
just two merging E32OLIB.DLL and E32USER.DLL into E32USER.DLL. For
those who are fond of the name OLIB I am quite happy to relinquish
the name and HCILI.DLL could be OLIB.DLL. But OLIB is a funny name
as it stands for Object library which is strange since all libraries
are now object libraries. Maybe its time for OLIB to just disappear.
7). In messages associated with a RSubSession the handle was being passed
in P1(). This was not the best option so I have now changed it to P4().
Note that for a SubSessionCreate message a descriptor is passed in P4()
rather than P1() which a server should use to write back the handle
of the sub session. See \e32\swinsd\ws_main.cpp for an example of the
approriate code.
8). Added Math::Rand(TInt64 &aSeed). This returns a random number in the
range 0 to KMaxTInt (i.e. positive) and updates the seed.
9). Renamed the operating systems Segment to Chunk to avoid confusion on
80x86 platforms with segment registers. Thus RSegment has become
RChunk and User::SegmentHeap has become User::ChunkHeap.
10). The function Test::Next() was assuming a zero terminated string. Fixed.
11). RProcess::CommandLine() was not getting the full command line. Fixed.
NOTES
=====
1). MartinB. Surely HufEncode should belong to class TDes and convert its
argument a TDesC into the TDes rather than belong to TDesC. As well
don't we need a second version of HufDecode called something like
HufDecodeInPlace which will do a decode in place on a TDes since
this is what the resource system does currently. Finally should we
not make a 32 bit version of the resource compiler.
2). There is a #define test in E32TEST.H. All #defines should be in
upper case.
3). Why does RRegion have a virtual destructor, a Close() and a
Destroy(). I suspect that the destructor should go.
4). In TOLIB t_ctimer.cpp and t_cact.cpp both have a #include to
\e32\olib\o_std.h. This is not correct!
5). In TUSER t_heapdb.cpp has a dependency on the window server header
file and in fact uses the window server. This is definitely
incorrect?
6). Can everyone try and make an effort before releasing E32 that
all projects are left in the DEBUG build and that all test
programs do not have windows open and breakpoints left enabled.
Version 0.01.033
================
(Made by MartinB, 4 May 1995)
1) Changed jcxz to a jecxz in P_I64.CPP (!!!)
2) Fixed some alloc heaven in CArrayVarBase::Delete.
3) Improved T_RSC test code.
4) Added MaxSize() to TDes.
5) New RRegion code from Steve.
6) Loads of test code from MartinH.
7) Note u_heap.cpp temporarily includes <stdlib.h> (for
random number generators) for heap alloc failure testing.
This is a temporary measure until the real file handling an
random number generation becomes available.
8) T_HEAPDB requires window server to run (since it tests for window
server heap failure).
All test code runs for ASCII DEBUG and UNICODE DEBUG builds (MartinB).
Version 0.01.032
================
(Made by MartinB, 26 April 1995)
1) Added a new CResourceFile class (and its superclass CFile). CFile
uses standard C files as a temporary measure until Colly
releases the real filing system.
2) Added a KErrFile const to go with the above. Again a temporary
measure.
3) CResourceFile reads resource files produced using our resource
compiler. (S_.RSC and S_.RZC were used in the test code, and
form part of the release of the test code). Note that
CResourceFile also reads compressed resource files. This
meant that:
4) Added Huffman compression for TDes16. Actually this does not
quite work yet, one or two of the test cases are #ifdefed out
in the UNICODE build. However it is 90% there and I have a
good idea of what the problem is (its to do with the unused
byte at the end when the descriptor compresses to an odd number of
bytes).
5) New test code from MartinH.
6) Minor fixes to threads from Colly/MartinH.
NOTES
=====
1) Should we have a TDes::MaxSize() function?
2) All test code runs for ASCII DEBUG and UNICODE DEBUG builds, except
T_RSC does not run in UNICODE.
Version 0.01.031
================
(Made by Colly, 18 April 1995)
1). Changed KEventPending to KRequestPending.
2). Made CActiveScheduler::Start() call the virtual function
WaitForAnyRequest().
3). Fixed ..\rel\ewinsdb.prj to release the estat*.pdb files
rather that wwins*.pdb files.
4). When a thread had an exception or was killed, terminated or
panicked, execution unfortunately continued. Fixed.
5). Added a function User::Dying() which is called by all the kernel
functions just before they kill,terminate,except or panic a thread
or process. This is a very good place for a breakpoint when
debugging. It will catch everything.
6). Added support to dynamically load a DLL and then lookup functions
in the DLL. See class RLibrary.
7). Added support for device drivers. See User::LoadDevice() and
User::FreeDevice() as well as the example device driver in
\e32\swinsd\d_timer.mak and its test program \e32\swinsd\t_devc.mak.
8). Added a constructor to all TFindHandle derived classes to allow
initialisation with the find string.
9). Converted the rose designs to rose 2.525
NOTES
=====
1). The fact that CActiveScheduler::Start() is static is no reason why
the virtual function WaitForAnyRequest() cannot be called. Just use
the static pointer to the scheduler:
theActiveScheduler->WaitForAnyRequest()
All test code runs for ASCII DEBUG and UNICODE DEBUG builds (MartinB).
Version 0.01.030
================
(Made by Colly, 12 April 1995)
1). Removed the virtual destructor in CBase. Added vitrual void Destroy().
CBase::Destroy() now calls delete this. It is now generally necessary
to call the base classes Destroy() in order to get proper destruction
of the object. Note that the DeleteAll methods in TDblQue and TSglQue
only work if the objects on the queue are derived from CBase. Added
a static function Olib::Destroy(CBase *anObject) which will only
destroy the object if anObject is not NULL.
2). Added a static function:
CActiveScheduler * CActiveScheduler::Current();
which return the currently installed active scheduler.
3). In RSubSession::CreateSubSession() was not passing as P1() in the
message the address of the reply so that the subsession handle could
be returned by the server.
4). Creating a semaphore with an initial count other than 0 did not set
the internal count with the initial count although the Windows/NT
semaphore was being set correctly. The same bug applied to Mutexes.
5). When a process was dying its access count was not being decremented
so that if no handles were outstanding the object was not being
destroyed.
6). CObjectIx::Add() and CObjectCon::Add() were closing the object being
added if the add failed. This proves to be unhelpful so they have
been changed to just fail and not do the close.
7). Added the following functions to RThread and RProcess to determine
the reason a thread or process exited.
IMPORT_C TExitType ExitType() const;
IMPORT_C TInt ExitReason() const;
IMPORT_C TName ExitCategory() const;
8). The design of the CPeriodic class made it unusable. This has now been
changed so that the New functions add the active object to the
scheduler. Start() is now defined as:
void Start(TInt aDelay,TInt anInterval,
TPeriodicCallBack aCallBack,TAny *aPtr);
which allows a CPeriodic to be restarted after it has been cancelled.
StartL() has been dropped since Start() is void.
There was also a bug in the RunL() method in that it issued the callback
and then requested the next timer. It should request the next timer and
then issue the callback.
The following merged in by MartinB:
9) Removed double definition of TText8 and TText16 form e32def.h
10) Moved enclosing #endif (matched to #if !defined(__E32DEF_H__)) to
end of e32def.h.
11) Changed make files so that .PDB files are built into \e32sys.
12) Added virtual WaitForAnyRequest to CActiveScheduler. This is not
called from Start, however, since Start is a static function.
After discussion with DW I retained User::WaitForAnyRequest
in Start, until we have time to discuss which functions
should be static.
13) Changed KErrPending to KEventPending.
Version 0.01.029
================
(Made by Martin, 3 April 1995)
1) New alloc testing code does not include filename and lineno
(MartinH).
2) New SglQue test code (DougF).
3) New test code (JalP).
4) Move common functionality of TKeyArrayFix and TKeyArrayVar into
TKey (JalP).
5) Fix to TEnter (DavidW).
All test code runs for ASCII DEBUG and UNICODE DEBUG builds.
Version 0.01.028
================
(Made by Colly, 22 Mar 1995)
1). Definitely the last name changes for the descriptor and buffer classes.
Old Name New Name
======== ========
TDesC TDesC
TDes TDes
TBufBase TBufCBase
TBuf TBufC
HBuf HBufC
TDesR TPtrC
TDesW TPtr
TBufW TBuf
Note that the function:
TDesW DesW()
in TBufBase has now been renamed:
TPtr Des()
Its helpful to consult the Rose class diagram to see why these names
are sensible.
2). Took Steve's new region code.
3). Added the missing #defines for __TEST_INVARIANT.
4). Changed the graphics window to position to 10,10.
5). Fixed the re-entrancy bug with UserWindowServer::Request().
6). Added the fix to stop the beep on ALT + char.
7). Added the code for User::Abort() and User::Exit().
8). User::Panic() was panicking the process and not the current thread
making it impossible to run test threads to see if they panic.
All the test code passes under the DEBUG build.
NOTES
1). The virtual destructor in CActive is calling the virtual DoCancel
which since the destructor is running at the CActive level has
no method to call as its pure virtual. The only reasonable solution
is to introduce a virtual Destroy() function to CBase() which can
do the necessary cleanup and then do the delete.
2). Many of the test programs do not have a standard comment header.
One did not even have a header. This is just careless.
I have fixed them all.
3). Many people when declaring an enum leave a comma on the last
declaration which is untidy.
4). A number of people are decalring automatic variables with capital
letters. Please avoid this practice.
Version 0.01.027
================
(Made by Martin, 16 Mar 1995)
1) Changed TBuf to TBufW, TLcb to TBuf and TLcbH to HBuf.
2) Fixed .lnk files so test code works if built from command line
(Duncan).
3) New T_REF test code (Jal).
4) Added previously missing RRef<T>::AllocL to e32std.inl (Jal).
5) Fixed bug in RRefBase::DoAlloc (Jal).
6) Added invariant to TDateTime (Gill).
7) Improved T_DATE test code (Gill).
8) Improved T_KEY test code (MartinH).
9) Fix to heap checking code (MartinH).
10) Changed T_QUE to use V classes (rather than S classes) (Doug).
11) Made iInterval protected (was private) in CPeriodic (at Steve's
request).
12) This release contains a zip file release (in s:\e32\zip) so that
users should not need to build E32. Only the ASCII DEBUG
version has been released.
All test code (ASCII DEBUG) can now be built and run from the command line
(except T_HEAPDB).
Actions:
1) Now that C classes rely on zero filling for initialisation their
definitions MUST be changed so that they cannot be declared on the
stack.
2) MartinH to fix T_HEAPDB.
3) Steve to complete transformation of CRegion to RRegion.
4) MartinB to complete (or remove) Huffman encoding (did not have
time to do it this release).
5) T_ARRAY and T_VARRAY need more test.Start() and test.Next()
messages (Jal).
6) Many classes still have no __TestInvariant methods (All).
7) CBufSeg has a test class defined under #if defined(_DEBUG) (Jal).
Version 0.01.026
================
(Made by Colly, 11 Mar 1995)
1). Added an operator new() to class CBase which fills memory with zeroes
so that most constructors need do nothing. Note that a constructor
is still required in order to set the name of the class in debug
builds.
2). Changed the RProcess::FileName() and RProcess::CommandLine() functions
to return their result rather than take an them as reference args.
3). Added RHandleBase::Duplicate(RProcess aSrc) which allows a handle from
another process to be duplicated in the current process. This is also
the mechanism by which the pseudo handles for the current thread and
the current process to be turned into real handles. i.e.
RThread self;
self.Duplicate(RProcess());
Note that you will now need to call self.Close() at some stage since
the resource must be freed.
In case you have missed the examples in ..\tuser\t_kern.cpp
instantiating a RThread or RProcess by default give handles to the
current thread and current process respectively. i.e.
RThread().Name() will return the current threads name.
These objects use a pseudo handle since it is not possible to close
these handles since if you could close them they would have to
delete the current thread or current process. Since these are pseudo
handles passing them to another process will not work as in the other
process they will also mean the current process and current thread.
Duplicate overcomes this problem since it gives a real handle to
either the current thread or the current process.
4). Added the RThread::Logon(),RThread::LogonCancel(),RProcess::Logon()
and RProcess::LogonCancel() functions.
5). Cleanup on Thread termination by the kernel now implemented.
6). RThread::Kill(),RThread::Exit(),RProcess::Kill() and RProcess::Exit()
implemented fully.
7). Changed Plat::Panic() and Plat::Fault() to always use the desktop
window for the messagebox.
8). Changed to build options for all variants. Everyone should make a new
.MAK file from T_KERN.MAK as a prototype. Presumably the tool sets
will have to be updated to reflect these changes. Also fixed a number
of link failures which had crept into the system.
9). Note that because of the use User::SetVaArgList() the optimisation
in the release versions to drop stack frames cannot be used.
10). The definition of the private class TLink in CBufSeg is a waste
of space in the headers. So I have declared a forward reference
to the class TBufSegLink and then only need the actual declaration
and implementation in O_BUF.CPP.
The following merged in by MartinB:
11) Uses new toolsets (use TOOLS WINS and TOOLS WINSD to get them).
12) New T_DES test code. (From Duncan).
13) Fixed integer compares in TKeyArrayFix and TKeyArrayVar. (From
Jal).
14) Fixed bug in CArrayFixBase::InsertISQ. (From Jal).
15) Added classes: TSglQueLink, TSglQueBase, TSglQue, TSglQueIterBase
and TSglQueIter. (From Colly). (No test code yet).
16) Added classes: RRefBase and RRef. (From Colly). (No test code
yet).
17) Added Alloc functions that take a size parameter to RRef classes
(at Jal's request).
18) Added __TEST_INVARIANT macro to e32std.h. (from MartinH).
19) Added MartinH's heap checking code. Note took some functions
even though they were not commented - they will be commented for next
release.
20) Took keycode code from DavidB. NOTE: P_STDKEY.CPP still contains
some numbers that should be converted to symbolic constants.
21) Small changes to code in winsd from Steve.
22) Changed User::MemSwap in u_func.cpp so that it does not swap if
memory locations are identical. There is an argument to do
this in the compare routines as well.
23) Moved region to e32std.h and called it RRegion. Steve will implement it as
a proper 'R' in a subsequent release.
ASCII Debug version only was tested.
All test code passes except T_QUE which fails on DeleteAll. Note
that
T_HEAPDB, T_ARRAY, T_CACT, T_VARRAY fail when built from the command
line.
Version 0.01.025
================
(Made by MartinB, 7 Mar 1995)
1) From Gillian: New TDateTime code.
Changed DateAsString() to Format().
Removed 3 unnecessary Add() functions.
Ammended t_time.cpp test code.
Renamed u_time.cpp to u_date.cpp (to lessen confusion with
timer code).
2) From Jal: Bug fix in CBufSeg::Delete() method. New test code.
3) From Duncan: mnt.cmd altered to build math functions and test code.
4) From Duncan: Updated all .lnk files for test code, so that they are built as
windows rather than console applications.
5) From Duncan: Introduced bld.prj in SMATH: this contains all the buildable math
routines (there are some .cpp files in li.prj that have not yet
been converted to E32).
6) From Duncan: Introduced bld.prj in SWINSD: this contains all the buildable cpp
files (there are some .cpp files in li.prj that have not yet
been converted to E32).
7) From Doug: Removed DEBUG friend declarations from Que classes.
8) From Jal: New CRefCountBase and CRefCount classes added to Olib.
9) From MartinH: New TKeyArrayCmpNumeric comparision types for
TKeyArrays. Ammended T_KEY test code.
10) From MartinH: Ammended T_ACT test code.
11) From DavidW: new T_VERSION test code.
12) Minor fixes to test code.
All ASCII DEBUG test code runs. There is one anomally: T_COBJ runs
fine if build inside VC++ but panics with a user panic of 37 if built
from the command line. It was getting late so I decided not to track
this one down.
Version 0.01.024
================
(Made by Colly, 1 Mar 1995)
1). Renamed TPackage to TPckgBuf which packages an object in a TBuf8 and
added TPckgC which packages in a TDesR8 and TPckg which packages in
a TDesW8.
2). Added new Panic function to RMessage which panics the client and
frees the message as well as one to CSession which just panics the
client. This is necessary as the Client() functions return a const
RThread & on which Panic cannot be called.
3). Noticed that Convert(const TDesC &aDes,...) would not work properly
as taking the address of aDes on the stack would fail. Changed to
use the User::SetVaArgList() function. Also removed the version
of Convert which took a string as an argument. Fixed the test
code accordingly.
4). My code in the example window server client side code was being very
naughty and assuming that all arguments were being passed on the
stack (TRUE for VC++, but not TRUE for GCC ARM code generation). Fixed.
5). Removed the function numbers from the RWindowServerBase class as
they can be entirely private.
6). The platform code to get system time was not subtracting 1 from the
day so TDateTime was correctly panicking the kernel on 28 Feb since
it was trying 29 Feb.
Version 0.01.023
================
(Made by Colly, 27 Feb 1995)
1). Moved the region code to SUSER in the file U_REGN.CPP. Moved the
test code from TOLIB to TUSER.
2). The OLIB CServer class was deleting the server object on disconnect
rather than the CSession. Fixed some other bugs as well.
3). Renamed CActive::Run() to CActive::RunL() to indicate that it may
leave.
4). Renamed CServer::Service() to CServer::ServiceL() to indicate that
it may leave.
5). Renamed CServer::NewSession() to CServer::NewSessionL() to indicate
that it may leave.
6). Added the TInt64 class and a number of the maths functions. See
\e32\inc\e32math.h.
7). Completely changed the whole scheme for E32 programs from being
console based to being GUI based. Test programs will write to
a normal Windows/NT console and the GUI window will be ignored.
All GUI programs now need to link with a window server library,
i.e. one of wwins,wwinsd,wwinsu,wwinsud. See the make file in
\e32\tuser\t_gui.mak.
A basic window server which just provides console services can be
found in swinsd in the project wwins.mak until Steve can get his
window server running.
All programs now use:
GLDEF_C TInt E32Main()
for the main program instead of main().
The functions for the basic window server and console are in header
\e32\inc\e32wsrv.h. Steve will provide these and extended functions
by subclassing these in his Window server library.
8). Added a variant to RThread::Read() which allows an offset to be
specified withing the descriptor to allow reading in smaller chunks
in case the user sends over a huge chunk of data.
9). Added the TEvent class and various functions all of which are
only for a Window server. I will discuss these with Steve directly.
The data is in \e32\inc\e32evnt.h.
10). The CArray classes were leaving in their constructors. Fixed by
delaying allocation of the CBufBase till an insert. Increased
the error checking.
11). The kernel was not doing unicode properly since UNICODE was
not defined in \e32\swins\p_std.h before windows.h was included.
12). Added TDes8::Copy(const TDesC16 &aRef) and
TDes16::Copy(const TDesC8 &aBuf) conversions between 8 and 16.
Notes:
Many of the test programs were not keeping test.Start() and
test.End() in balance.
In U_TIME.CPP the unicode build was disabled because Gillian
was using a TLex8 instead of a plain TLex8. I also not that
the API for DateAsString takes the format string as a pointer
and not as a reference. Also the name of the function should
surely be Format().
Version 0.01.022
================
(Made by Martin, 17 Feb 1995)
1) Fixed construction of TLex over strings.
2) New time class from Gillian.
3) Fixed t_buf,t_bflat and t_bseg test code from Jal.
4) Fixed t_lex test code from MartinH.
5) Changed CRegion to RRegion (after consultation with Steve).
6) NOTE: the TDateTime::DateAsString function fails to build under
unicode.
7) K_MES.CPP does not build under UNICODE, search for !!! string to
find where.
Note that there are new wins and winsd toolsets and a new version of
EPR. Get these by doing
TOOLS WINS
TOOLS WINSD
in the usual way.
Version 0.01.021
================
(Made by Colly, 16 Feb 1995)
1). In TUSER t_buf,t_lex do not compile.
2). In TOLIB t_bflat,t_bseg do not compile.
3). In TOLIB t_cact,t_cobj compile but fail. Note t_cact was t_creq.
4). Made the kernel platform function Plat::SetVaArgList(VA_LIST &aList)
public in class User. This function was written assuming the argument
const TDesC &aFmt was the first argument. Using it in
Test::Panic(TInt anError,const TDesC &aFmt
would not work correctly. Changed this function to take a second
argument which says how many bytes to skip before the
const TDesC &aFmt argument. For Test::Panic this is 4 and 0
for all other uses.
5). Renamed CRequester to CActive and CRequestManager to CActiveScheduler.
6). Renamed all T classes which require closing to free their resources
to R classes. I have not renamed CRegion to RRegion in this release
but would propose that we do this (Steve?).
7). Added User::At() and User::After() to put the current process to
sleep for relative and absolute time repectively. These are sync
functions.
8). Implemented the RMessage, RServer and RSessionBase classes and added
the Olib classes CServer and CSession. See the T_SVR.CPP test code
to see how these are used.
9). Renamed t_req.* in TOLIB to t_act.*
10). Added the template class TPackage<T> which will package any type
T in a TBuf<sizeof(T)>. Note the -> and () operator overloading.
TPackage<TVersion> v;
v->iMajor
v().iMajor
This is most useful for passing and receiving non TDesC arguments
to a server so that the server can subsequently read/write to it.
11). Added the minimum,maximum values for all integers in e32std.h look
for KMaxTInt8 etc.
Queries
-------
1). Are we going to implement a 16 bit version of Hufman coding. If not
then we cannot have this functionality as there cannot be a difference
between 8 and 16 bit character versions as far as functionality goes.
2). Someone put #ifdef UNICODE into one of the files in swins. This is
wrong and should have been #if defined(_UNICODE). Although Microsoft
are confused we should always use the _UNICODE form.
3). I think we should rename User::Check and User::Available to have
Heap in their name somewhere.
Version 0.01.020
================
(Made by MartinB, 15 Feb 1995)
1) Removed (most) string functions from descriptors.
2) Fixed bug in unicode Printf.
3) Time class changed to DateTime.
4) Made some queue parameters constant.
5) Tidied up some of the Locale code.
6) Tidied up mnt.bat and renamed it to mnt.cmd.
7) Fixed Format for %S in descriptors.
8) Added Huffman coding to TDesC8 (finally).
9) Added some DateTime validation routines.
10) Removed SetActive and SetInActive functions from CRequestors.
11) Fixed most test code to run with the new descriptors, but there
was too much to do for some (ie t_buf, t_lex, t_bflat).
Version 0.01.019
================
(Made by Colly, 7 Feb 1995)
1). Added the new TTimer concrete data type (CDT).
2). Added the OLIB classes CRequestManager and CRequester.
3). Added the OLIB requesters CTimer and CPeriodic.
4). UNICODE needs to be defined as well as _UNICODE.
5). Fixed a bug in TDblQueIter where neither the inc or dec operators
returned NULL at the end of the queue. Changed the test code to deal
with this. Note that if the iterator is positioned at the end of the
queue it will also return NULL when being casted.
6). Fixed a bug in the TDes::Format(const TDesC &aDes) functons which
when try to set up the VA_LIST were taking the address of aDes and
getting it rather than the expected address of the argument on the
stack. Fixed by using the new User::SetVaArgList() function. The
test code is not testing this part of the code.
7). Added the new static time validation functions to User.
8). The User::WaitForRequest() type functions are now operational.
9). Added the device driver code. Still to write a test device driver
but this will probably be a console device.
10). Changed all the kernel classes to be D something rather than C
something to avoid name clashes with OLIB.
11). Changed the CObject class to allocate the name of the resource so
that NULL can be used to indicate an unnamed object. This has
changed the API's for some of the CreateLocal functions to no
longer require a name, i.e. TSemaphore::CreateLocal().
12). Changed all the API's to the kernel to use const TDesC& rather
than const TName& etc.
13). All tests pass in non-unicode debug.
Version 0.01.018
================
(Made by MartinB, 3 Feb 1995)
1) Improvements to MartinH's test code.
2) Uses new format link files (so needs new tools release).
3) Incorporates Duncan's test code.
4) Improvements to Strings in test code (ie _TL macro).
5) Removed most of the #if defined(_DEBUG) stuff from include files,
but not for the friend classes. Working on a plan for this though.
6) Fixed T_VARRAY .MAK file (was building T_ARRAY).
7) This is a consolidation release.
Version 0.01.017
================
(Made by Colly, 26 Jan 1995)
1) Integrated the changes in preparation for device drivers.
2) Note that the #if defined(_DEBUG) stuff for queues in the
headers is unacceptable.
3) Note that I am not confident of the enumerate for EAllowDuplicates
nor the provision of default parameters.
Version 0.01.016
================
(Made by MartinB, 24 Jan 1995)
All test code passes. (But have not tried UNICODE build).
Now builds with 32bit EBLD. To get this type
TOOLS ETSET
TOOLS WINS
TOOLS WINSD
You can then do MNT BLD etc from the command line.
1) Added _S macro and changed _L macro in preparation for removing
strings from descriptors. Changed code to use _S and _L so that
strings could be easily removed in next release.
2) Took T_TKEY test code from MartinH.
3) Removed Free from CBuf class.
4) Minor bug fixes here and there.
5) Took Que code from Douglas
Version 0.01.015
================
(Made by Colly, 18 Jan 1995)
1). Made the final re-organisation to the descriptors and introduced
the new derived class TDesR. Note that TDesC and TDes are real
abstract base classes as they cannot be directly instantiated.
(They have no contructors). Note that functions like Mid(),Left()
etc. now return a TDesR.
Added the template TLcb class. This class is intended for use
as a member of a struct or class since it needs the minimum
storage space.
This is similar to the TBuf class except that it is a length
followed by the buffer, i.e. no max length. Thus apart from
assigning to it and behaving as a TDesC a TLcb cannot be
manipulated as it was a TDes. However help is at hand since there
is a function DesW() which return a writeable descriptor through
which a TLcb can be manipulated in the same was as a TBuf. i.e.
TLcb<KMaxName> b;
b=_L(" Some spaces");
b.TrimLeft(); // This will fail.
b.DesW().TrimLeft(); // This will work fine.
b.DesW().UpperCase();
If a lot of write operations are to be performed on the TLcb then
it is more efficient to take a copy of the TDesW. i.e.
TDesW w=a.DesW();
Note that there is no public constructor on TDesW for a TLcb
directly as it would need you to pass the maximum length as well
which is best left to the template to do on your behalf.
If a function needs a writeable descriptor then just pass b.DesW()
and all will be well.
As a last final thing for descriptors I have added one final class
TLcbH (H stands for heap). A TLcbH has the property that the TDesW
returned by DesW() has its iMaxLength set to the size of the alloc
cell - sizeof(TUint). A fine feature of this is that the length of
an alloc cell which is always present can now be used to good
purpose. It is also possible to call the TLcbH member functions
ReAlloc() or ReAllocL() on the cell and the get another TDesW
which will have changed its iMaxLength to the new size of the cell.
TLcbH *TLcbH::ReAlloc(); // Returns NULL if fails
TLcbH *TLcbH::ReAllocL(); // Leaves if fails
It is possible to directly construct a TLcbH with the static
functions:
TLcbH *TLcbH::New(TUint aMaxLength) // Returns NULL if fails
TLcbH *TLcbH::NewL(TUint aMaxLength) // Leaves if fails
The TDesC class also has two methods:
TLcbH *TDesC::Alloc(); // Returns NULL if fails
TLcbH *TDesC::AllocL(); // Leaves if fails
which will clone the descriptor on the heap. The size of the TLcbH
will be the length of the descriptor. Remember that these objects
must be freed with either delete or User::Free().
Note that there is a class TLcbBase which is just used to provide a
place to provide the code for the template class and although this
could be placed in the TDesC class this could only be done by
sacrificing the efficiency of the constructors for the TLcb class.
TDesC has so many constructors that TLcbBase is useful in providing a
selector for the base constructor. If this was removed an artificial
enum would have to be added to the constructors in TDesC to ease
selection. Since these are called inline by TLcb this would waste
code.
It is useful to look at the Rose class diagram in \e32\desn\e32.dsn
in the User\Descriptors category.
2). Took the fixed u_time.cpp and new t_time.cpp.
3). Changed the build plan so that all 4 build versions are supported
in all E32 .MAK files and that all releaseable files are in \e32sys
as follows:
Build Name Object directory
========== ================
Win32 Release \work\e32\wins\rel
Win32 Debug \work\e32\wins\deb
Win32 Uni Release \work\e32\wins\urel
Win32 Uni Debug \work\e32\wins\udeb
Build Name .DLLs
========== ================
Win32 Release \e32sys\ewins.dll
Win32 Debug \e32sys\ewinsd.dll
Win32 Uni Release \e32sys\ewinsu.dll
Win32 Uni Debug \e32sys\ewinsud.dll
Build Name .LIBs
========== =====================================
Win32 Release \e32sys\ewins.lib \e32sys\estat.lib
Win32 Debug \e32sys\ewinsd.lib \e32sys\estatd.lib
Win32 Uni Release \e32sys\ewinsu.lib \e32sys\estatu.lib
Win32 Uni Debug \e32sys\ewinsud.lib \e32sys\estatud.lib
The directory \e32\lib has been deleted and replaced with
\e32\rel where the release project files are kept.
As a result of this no generated files get placed in the \e32
source tree, meaning a check -a li should always show no
additional or missing files
4). Fixed most of the death in the unicode build but some test
programs are not building properly.
5). Added the __DECLARE_TEST() macro for adding the test operations
to classes for debug builds. This macro should always be declared
as the last thing in the class as it switches back to public: as
follows:
public:
void __TestInvariant() const;
void __Test() const;
If a DLL is being built the __DLL__ #define should be present and the
macro will generate:
IMPORT_C void __TestInvariant() const;
The operation __TestInvariant() is expected to be supplied for all
classes and should do all the checking that it can to determine that
the object is in a healthy state. If it finds an error it should call
User::Invariant() which will cause a panic. If a class is derived from
a base class then the base class __TestInvariant() should be called
first and then further checking should be done.
This macro should not be added to template functions as the base class
from which the template function is derived should be able to do all
the necessary checking.
The __Test() function is not implemented and is provided to allow
test code a way of directly accessing all the members of a class.
Test code needs only to provide the function and then call it as it
is always assumed to be in the same .exe as the calling program.
Look at e32des8.inl and \e32\suser\u_des8.cpp for an example of how
to implement __DECLARE_TEST().
N.B.
It is expected that all classes will implement this scheme.
6). Taken Gillian's fix to u_loc.cpp which was returning day names
for months.
Version 0.01.014
================
(Made by Colly, 16 Jan 1995)
1). THeap::Available() was not subtracting the header from the cells size.
2). The insert bug in CBufSeg has been fixed.
3). Implemented the new TDes/TBuf plan. This now allows TBufs to be moved
around in memory so that CArray<TBuf_40> is now O.K. Note that TDes8
cannot be instantiated, instead instantiate a TDesW8. TBufs now only
have an overhead of 8 bytes. See TDesC8::Ptr() to understand how
this trickery is accomplished. In general note that the values of the
members of TDesC8 and its derived classes are now meaningless so don't
jump to conclusions. The iLength should be divided by 4 to get the
real length. The bottom two bits provide flags for the Ptr() function.
For TDes8,TBuf8 and TDesW8 iPtr is in fact the maximum length. The
address of the buffer for TBuf8 is assumed to follow iPtr. For a
TDesW8 the real pointer to the buffer follows iPtr.
4). Added the TVersion class and the User::Version() function.
5). In class TLex, renamed Token() to NextToken() and made
MarkedToken() and NextToken() return a TDesC8.
6). Removed the new operator in class CBase. As the cell is no longer
zero filled all relevant fields must be initialised.
7). Added a member variable TText *__iName to CBase when the _DEBUG
flag is set. All constructors of classed derived from CBase should
initialise by using the __DECLARE_NAME macro. For CBufSeg this would
be :
EXPORT_C CBufSeg::CBufSeg(TUint anExpandSize)
//
// Constructor
//
: CBufBase(anExpandSize),iSeg(NULL)
{
__DECLARE_NAME(_L("CBufSeg"));
}
8). Changed the ASSERT1,ASSERT2 and ASSERT3 macros to
__ASSERT_ALWAYS - applied in all builds
__ASSERT_DEBUG - applied only in debug builds
__ASSERT_OPT - applied if __OPT__ is defined
The previous versions assumed that Panic was called, i.e.
#define ASSERT1(c,p) if (!(c)) Panic(p)
This has been changed to allow other functions to be called.
#define __ASSERT_ALWAYS(c,p) if (!(c)) p
This should be used as follows:
__ASSERT_ALWAYS(anIndex<iLength,Panic(EDes8IndexOutOfRange));
9). Further bugs showed up in T_BFLAT which was still assuming that
a TBuf was zero terminated. Changed the code to zero terminate
after construction.
Version 0.01.013
================
(Made by Colly, 12 Jan 1995)
1). Completed the implementation of the descriptor/buffer classes.
2). The TLocale class is now working.
3). Move SDate,STime and SDaySecs out of TTime. Made the members
start with a lower case. Changed the order of members so that
sorting will occur correctly. Changed the filler on STime to be
1/100ths of a second. Provided a service in the kernel to retrieve
the current 1/100ths.
4). Changed TTime to call the kernel to get the current time and TLocale
to get the start of week. The function to set system time is in
User. i.e. User::SetSystemTime(TSystemTime aTime);
5). Moved the static functions from TTime to User.
6). Converted the u_time.cpp to E32 code standards.
7). Converted the u_graph.cpp to E32 code standards.
8). Converted the o_region.cpp to E32 code standards.
9). Fixed the bug if you ran a program from the command line without
the .exe.
10). Changed TDblQue::Next() to be TDblQue::First() and
TDblQue()::Prev() to be TDblQue()::Last(). Changed the
implementation of AddFirst() and AddLast() to take a T * rather
that a TDblQueLink *.
11). Changed the static New()'s in CBufFlat and CBufSeg to return a
pointer to the class rather than to CBufBase.
12). Add a further global new operator which will leave if it cannot
allocate the memory. This is called as follows:
Normally:
TRect *p=new TRect(0,0,10,10);
With leave:
TRect *p=new(ELeave) TRect(0,0,10,10);
13). Renamed TEnter::Throw() to TEnter::Leave();
14). Fixed User::Leave().
15). Add the full queue implemetations.
16). Threads other than the main thread did not have their heap set.
17). Lots more that I have forgotten.
The TLex test code does not pass since it was relying on the zero
terminator and I don't have the time to fix it. There is bug shown
in CBufSeg with the test program T_ARRAY, although not surprisingly
by T_BSEG.
All the test code should now be reviewed and checked.
Version 0.01.012
================
(Made by MartinB, 6 Jan 1995)
1) Fixed death in release 11 below.
2) Descriptor classes essentially complete. Moved iMaxLength from
TDesC to TDes. However must still define unicode-independent
buffers.
3) Passes all test code now (except T_SEM).
Version 0.01.011
================
(Made by MartinB, 6 Jan 1995)
1) Bug fixes to Heap from MartinH.
2) Bug fixes to arrays from Jal.
3) Changed some pointer parameters to references.
4) Changed to new Descriptor class hierarchy. The change is not yet
complete.
5) Some things are now (partially) broken:
T_BUF does not pass all test code (wierd stack death),
T_ARRAY.CPP and T_BFLAT.CPP do not build,
T_LEX does not pass all test code.
Version 0.01.010
================
(Made by MartinB, 4 Jan 1995)
1) Minor bug fix to o_array.cpp.
2) Fixes to slocl to support dynamic loading.
3) Fixes to TLex and TChar code.
4) Converted to using spaces for tabs.
5) Incorporated DWs time class.
6) Moved Steve's CRegion class to SOLIB.
Version 0.01.009
================
(Made by MartinB, 22 Dec 1994)
1) Minor bug fixes and improvements to descriptor code.
2) Now partially buildable under EPR (courtesy of DuncanS). To get
extended toolset type:
TOOLS ETSET
TOOLS WINS
You will also need to set your DOS box to run off a PIF file
(ETSET.PIF in this directory will do), otherwise you will get out of
memory/environment space problems.
Then
ETON WINS
and (in the usual way)
CONT E32 GROUP
DON
BUILD DEB
Then you should be able to do MNT BLDALL. Unfortunately we don't yet
have the technology to build DLLs yet, but we can do CCs and LFs.
This certainly makes it much less tedious to build the test code.
In CONT E32 TUSER type
EBLD ETLI
In CONT E32 TOLIB type
EBLD LI
Version 0.01.008
================
(Made by MartinB, 21 Dec 1994)
1) Took Jal's fixes for CBufSeg class.
2) Added
void Append(const TUint8* aBuf,TUint aLength);
function to TDesBase class.
3) Removed the Assign() functions that were just duplicates of Copy()
from TDesBase.
4) Split data in slocl into country dependent, language dependent and
alphabet (character set) dependent parts. Split not yet complete.
Version 0.01.007
================
(Made by MartinB, 20 Dec 1994)
1) Produces e32winsu.* and e32statu.* on UDEB and UREL builds.
2) Moved to warning level 4.
3) operator= changed to return reference in TPoint, TSize and TRect classes
4) Converted CBuf* classes to constant reference convention.
5) Changed TLex to use descriptors.
Version 0.01.006
================
(Made by MartinB, 20 Dec 1994)
1) #defined _UNICODE on UDEB and UREL in e32ver.h in preparation
for epr building.
2) Converted TLex* class to constant reference convention.
3) Renamed TSuffix to TDateSuffix.
Version 0.01.005
================
(Made by MartinB, 19 Dec 1994)
1) First version with buffers replaced by descriptors. Note that
..\inc\e32db16.h
is a copy of
..\inc\e32db8.h
with 8 replaced by 16 throughout, and
..\suser\u_dsbf16.cpp
is a copy of
..\suser\u_dsbf8.cpp
with 8 replaced by 16 throughout.
This is necessary since it seems impossible to use templates in
this case (this is because there seems to be no way to manually
instantiate the template so that it can be placed in the DLL).
2) Passes all test code except T_BFLAT (which I didn't get to work on
version 004) and T_SEM (which I'm not sure about).
3) TThread class broken? It may well work but I have not yet looked
into the implications for this class.
4) Made this version for a "safe" one to come back to.
5) U_LEX*.CPP and U_SEG.CPP can now be much improved by using
Descriptors instead of temporary buffers.
Version 0.01.004
================
(Made by MartinB, 19 Dec 1994)
1) Minor fixes to SLOCL tables.
2) Defined ASSERTn and ASSERT_VALIDn macros.
3) Last version before new TDes and TBuf classes.
Version 0.01.003
================
(Made by MartinB, 14 Dec 1994)
1) Incorporates TPoint, TSize, TRect & TRegion classes.
2) Incorporates test code for above.
3) Moved TCheckedHeapWalk declaration into THeap (ie nested class
declaration), partially because of name class with TSize (above).
Version 0.01.002
================
(Made by MartinB, 13 Dec 1994)
1) Incorporates buf fixes to TChar, TLex & TBuf classes.
2) Incorporates test code for above.
3) First working UNICODE version.
Version 0.01.001
================
(Made by Colly, 10 Dec 1994)
1) First release.