Multithreading Considerations

*-----------------------------------------------------------------------------------

 

* .---------------

.

 

*

 

* some storage

<----------------

pointer to shared storage

*

(called MyPtr in module A)

* '---------------

'

(saved as a static variable in module B)

*Module A

*Global variables in Module A

D MyPtr

 

S

*

 

 

D SomeStorage

S

10A

based(MyPtr)

C

eval

 

SomeStorage =

'Init value'

 

C

callp

 

ProcB(MyPtr)

 

.2/

C

eval

 

SomeStorage =

*BLANKS

.3/

*-----------------------------------------------------------------------------------

 

 

 

 

*Module B

*Global variables in Module B

D SavedPtr

S

 

*

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

D SomeStorage

S

 

10A

based(SavedPtr)

 

 

 

 

 

 

 

 

 

 

* ProcB in module B

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

P ProcB

 

B

 

 

export

 

 

 

 

 

 

 

 

 

 

 

 

 

D ProcB

 

PI

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

D

PtrParm

 

 

*

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

C

 

 

 

eval

SavedPtr = PtrParm

 

 

 

.6/

 

 

 

 

 

 

 

 

C

 

 

 

return

 

 

 

 

 

 

 

.7/

 

 

 

 

 

 

 

 

P

 

 

 

E

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

* ProcB2 in module B

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

P ProcB2

 

B

 

 

export

 

 

 

 

 

 

 

 

 

 

 

 

 

D ProcB2

 

PI

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

D

PtrParm

 

 

*

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

C

 

 

 

if

 

SomeStorage = 'Init value' .8/

 

 

 

 

 

 

 

 

C

 

 

 

....

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

C

 

 

 

return

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

P

 

 

 

E

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Figure

73. Example of Sharing Data in a Multithreaded Environment

 

 

 

 

 

 

 

When

ProcA

calls

ProcB .2/(line),no

other

 

thread can access the storage

to

by

MyPtr, since

both module

A

and

and module

B

are

being

used

ProcB

saves

the pointer in module B's static.6/) andstoragereturns(line(line

 

 

.7/). Now, no

thread

is

active

in

module

B,

so another thread is fr

B.

If

another

thread

calls

ProcB2,

 

it

is

possible

that

the

first

line.3/ before,

at

the

same

time,

or

after

the second.8/. thread proc

The

 

order

of these events is not

defined;

the

code

used

to

tes

'Init

value'

could succeed one

time

 

and fail the next time.

 

 

You

 

can

synchronize

access

to

the

shared

data,

by

using logic

in

using synchronization techniques provided by C or by platform functio details, refer to the Multithreaded Applications document under the topic at the following URL:

http://www.as400.ibm.com/infocenter/

How

to Avoid Deadlock

Between

Modules

 

 

 

 

 

 

 

 

In

some

situations,

it may be necessary for you to control

the

sy

modules using facilities other than the THREAD(*SERIALIZE) control speci

keyword.

For

example, consider the situation where two procedures

a

called

at the

same

time:

PROC1 and

PROC3. Even

though there

is

no

a

sive

calling;

if

PROC1 calls PROC4,

it

will wait for MOD2 to

unlock;

an

calls

PROC2,

it

will

wait

for MOD1

to

unlock. The

procedures

will

not

Chapter 10. Calling Programs and Procedures159

Page 183
Image 183
IBM AS/400 manual How, To Avoid Deadlock, Example, consider the situation where two procedures Called, Blanks

AS/400 specifications

The IBM AS/400, now known as the IBM iSeries, is a midrange computer system that has been a cornerstone of enterprise computing since its introduction in 1988. Designed to provide a robust platform for business applications, the AS/400 is celebrated for its reliability, scalability, and integrated database capabilities.

One of the key features of the AS/400 is its Integrated Operating Environment, which blends hardware and software resources seamlessly. This integration allows businesses to execute diverse workloads, ranging from traditional applications to modern web-based services, all on a single platform. The operating system, OS/400 (now IBM i), offers a rich set of APIs and tools for developers, simplifying application development and management.

Another standout characteristic of the AS/400 is its built-in database, DB2 for i. This powerful relational database management system allows for efficient data handling and provides advanced features such as support for SQL, XML, and JSON, making it easier for businesses to manage their data and integrate it with other systems. The database's tight integration with the operating system enables high performance and security.

In terms of scalability, the AS/400 can accommodate small businesses as well as large enterprises, with the ability to support hundreds of users simultaneously. Its architecture allows for easy upgrades in hardware, meaning that organizations can scale their systems without replacing the entire infrastructure.

Security is another critical attribute of the AS/400. With a sophisticated security model, it offers built-in user authentication, access control, encryption, and auditing capabilities to protect data and applications from unauthorized access.

The AS/400 also supports multiple programming languages, including RPG, COBOL, Java, and PHP, giving organizations the flexibility to choose the development tools that best fit their needs. This diversity helps maintain legacy applications while also developing new ones that leverage modern technologies.

Moreover, the platform supports both traditional green-screen interfaces and modern graphical user interfaces, allowing organizations to transition smoothly into contemporary user experience paradigms.

Overall, the IBM AS/400 stands out as a resilient, flexible, and secure computing platform that enables organizations to effectively manage their business operations, streamline processes, and adapt to changing market demands. Its unique combination of integrated features and capabilities ensures that it remains relevant in today's fast-paced technology landscape.